Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
74 / 54 / 17
Регистрация: 10.07.2014
Сообщений: 329

OpenOffice чтение документа xls

01.12.2014, 11:48. Показов 3135. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В данной теме мне помогли с файлом DOC(X)
Считать текст из doc (docx) файла используя LibreOffice
Там спасибо

Не по теме:

Кстати, если можно - переименуйте ту тему с заглавием типа "Считать текст doc(x) используя OpenOffice"

А как прочитать .xls файл используя OpenOffice?
А конкретно интересует метод чтения данных из ячейки
То есть открыть документ, прочитать ячейку, закрыть документ..
На текущем этапе код
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
String LoadOpenOffice(String nf)
{
  Variant App;
  Variant Desktop;
  String s;
  try {
    try {
      App = Variant::CreateObject("com.sun.star.ServiceManager");
      Desktop = App.OleFunction("createInstance", WideString("com.sun.star.frame.Desktop"));
    } catch (...) {
      return "";
    }
    int Bounds[2] = {0, 0};
    Variant OpenParams = VarArrayCreate(Bounds, 1, varVariant);
    Variant MyStruct = App.OleFunction("Bridge_GetStruct",WideString("com.sun.star.beans.PropertyValue"));
    MyStruct.OlePropertySet("name", WideString("Hidden")); // Устанавливаем атрибут "Скрытый"
    MyStruct.OlePropertySet("value", true);
 
    OpenParams.PutElement(MyStruct, 0);
    // Открытие файла
    Variant ODocument = Desktop.OleFunction("LoadComponentFromURL",
        WideString("file://localhost/"+nf), WideString("_blank"), 0,OpenParams); // И открываем документ с этим атрибутом
 
    // Делаем все, что нужно
//?
    // Закрываем документ
    ODocument.OleFunction("close", true);
    ODocument = Unassigned();
 
    // И завершаем Десктоп
    Desktop.OleFunction("terminate");
    Desktop = Unassigned();
  } catch (...) {
    Desktop.OleFunction("terminate");
    Desktop = Unassigned();
    return "";
  }
    return s;
}
Вызывает except на этапе открытия....
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.12.2014, 11:48
Ответы с готовыми решениями:

Чтение xls/xml.
У меня есть файл xls 30000 записей. Читаю литературу везде написано, что запускается эксель и читаются уже данные. Нельзя не запуская...

Чтение и сохранение информации из .xls (Excel)
Всем еще раз привет) у кого есть какие идеи, как при помощи OLE открыть файлик, оценить размерность матрицы, и радостно записать ее в...

Печать документа xls
Здраствуйте, подскажите пожалуста как реализовать программу в Windows Forms Application, в которой при нажатии на кнопку распечатывался...

5
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33378 / 21502 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 11
01.12.2014, 12:10
Цитата Сообщение от krv Посмотреть сообщение
Вызывает except на этапе открытия....
Вот ты будешь смеяться, но никакого except-а нет, xls-файл прекрасно открывается. Передавай правильный (и полный) путь к xls-файлу...
1
74 / 54 / 17
Регистрация: 10.07.2014
Сообщений: 329
01.12.2014, 12:43  [ТС]
Виноват.
Действительно туплю. Оказалось Calc банально не установлен.. Writer ставил, а Calc почему-то пропустил...

Остался вопрос - какая ф-ция дает доступ к ячейке?...
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33378 / 21502 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 11
01.12.2014, 12:50
Лучший ответ Сообщение было отмечено krv как решение

Решение

Здесь я показывал: Работа с ячейкой OpenOffice Calc , на Билдер сам переведи
0
74 / 54 / 17
Регистрация: 10.07.2014
Сообщений: 329
02.12.2014, 11:44  [ТС]
Всё таки не смог подобрать имя для свойства.
А главное - не знаю где смотреть.. Поэтому и спрашиваю...
Вот функция:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
String __fastcall TForm1::fromOOCell(int Row, int Column)
{
  Variant Sheet;
  Variant Cell;
  Variant Under;
  try{
    Sheet = ODocument.OlePropertyGet("Sheets",0);
    Cell = Sheet.OlePropertyGet("CellByPosition",Row, Column);//(1)
    Cell = Sheet.OlePropertyGet("Cells",Row, Column);//(2)
    String s = Cell;
    Under = Cell.OlePropertyGet("Font").OlePropertyGet("Underline");//(3)
    int UnderRes = Under;
    return s;
  } catch(...) {
    Application->MessageBox(L"Ошибка чтения ячейки OpenOffice Calc!",L"Ошибка",MB_OK+MB_ICONERROR);
  }
  return "";
}
Аналогично Делфи-строки такие:
Delphi
1
2
  Sheet := Document.getSheets.getByIndex(0);
  Cell := Sheet.getCellByPosition(5, 2); // 5 столбец 2 строка --- вот это перевести
Что написать вместо (1) или (2) - эти варианты не срабатывают
И будет ли правильной строка (3) ? А то я к ней дойти не могу...
В общем случае интересует строковое значение ячейки и подчеркнут ли текст в ней каким либо образом.
Константы подчеркивания разберу потом на примерах, просто знаю что 0 - никак не подчеркнуто
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33378 / 21502 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 11
02.12.2014, 12:07
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// ...
        Variant ODocument = Desktop.OleFunction("LoadComponentFromURL",
            WideString("file://localhost/" + nf), WideString("_blank"), 0,
            OpenParams); // И открываем документ с этим атрибутом
 
        Variant OTables = ODocument.OleFunction("getSheets");
        Variant OTable = OTables.OleFunction("getByIndex", 0);
 
        Variant oCell = OTable.OleFunction("getCellByPosition", 1, 0); // 0 строка, 1 столбец
        Variant oCellCursor = oCell.OleFunction("getText").OleFunction("createTextCursor");
        WideString txt = oCell.OleFunction("getText").OleFunction("getString");
 
        ShowMessage(txt); // Вывод
 
        // Закрываем документ
// ...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.12.2014, 12:07
Помогаю со студенческими работами здесь

Чтение формата *.xls
Требуется обработать документ формата *.xls (где присутствует объединение итп), провести кое-какие вычисления и вывести результат....

Чтение файла xls и перезапись данных в файл txt
Задача Файл xls в нем данные (текст и числа), алгорит читает файл xls и перезаписывает данные в файл txt

Чтение из документа Word
никак не могу понять как это сделать, а в инете инфы чё-та вообще об жтом нет... сделал по примеру хз откуда, вот так oDoc =...

Чтение XML-документа
Проходит без ошибок,какой функцией прописать ip адрес,пользователь,и пароль, и какие нужны команды для терминала? в pro файл вписал : ...

выгрузка в xls с открытием в OpenOffice
при выгрузке форм в xls Open Office отображает при открытии краказяблы, после открытия в exel и сохранении в формате xls win2000/XP Open...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru