Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
 Аватар для Shambler-AdMec
11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53

OpenOffice, AODL.dll и VS 2010 - вывод данных в виде таблицы OpenOffice

23.04.2014, 09:23. Показов 4695. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня.
Третьего дня столкнулся с нуждой вывода данных в виде таблицы OpenOffice (*.ods). Помня, как это было просто в Delphi, благодаря модулю uOffice, стал искать что-то похожее для Visual Studio. Нашел библиотеку AODL.dll, написанную как раз на C# для работы с офисом - wiki.services.openoffice.org/wiki/AODL
И хотя проект, судя по всему, давно не обновлялся, основные функции по работе с OpenOffice он исполняет и этого достаточно.

Собственно, дальше примера кода, выдранного из одной статьи (http://www.ibm.com/developerwo... index.html - пункт 4), дело не пошло. Я пытался заставить часть кода работать в цикле, но не преуспел в этом.

Вот он:

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
//создаем новый документ типа электронная таблица
             SpreadsheetDocument spreadsheetDocument = new SpreadsheetDocument();
             spreadsheetDocument.New();
             //создаем новую таблицу
             Table table = new Table(spreadsheetDocument, "First", "tablefirst");
             //создаем новую ячейку, без дополнительных стилей
             Cell cell = table.CreateCell("cell001");
             cell.OfficeValueType = "string";
             //устанавливаем границы
             cell.CellStyle.CellProperties.Border = Border.NormalSolid;
 
            //создаем новый параграф
             Paragraph paragraph = 
             ParagraphBuilder.CreateSpreadsheetParagraph(spreadsheetDocument);
             //добавляем в него - текст
             for (int i = 1; i <= 4; ++i)
             {
                 paragraph.Node.InnerText = "";
                 paragraph.TextContent.Add(new SimpleText(spreadsheetDocument, "test" + i));
                 //теперь добавляем созданный параграф в ячейку
                 cell.Content.Add(paragraph);
                 //MessageBox.Show("paragtaph values is: " +paragraph.Node.InnerText);
                 //ячейка, содержащая текст появится на пересечении строки с индексом 2 и 
                 //колонки с индексом 3
                 //все предыдущие колонки и строки будут созданы автоматически
                 //table.RowCollection[0].CellCollection[0].Content.Add(paragraph);
 
                 table.InsertCellAt(2, i, cell);
                 //MessageBox.Show("cell value is: " +cell.Node.InnerText);
                 //осталось вставить готовый объект с таблицей в документ и сохранить его     
             }
             spreadsheetDocument.TableCollection.Add(table);
             spreadsheetDocument.SaveTo("c:\\c#\\simple.ods");
Результат: переменная изменяется в цикле правильно, однако в файл сохраняется только её последняя версия и только в последнюю ячейку в цикле. Все остальные ячейки, которые цикл охватывает в строке "table.InsertCellAt(2, i, cell);" остаются пустыми. Помещал строку "spreadsheetDocument.TableCollection.Add (table);" в цикл, но результат тот-же самый.

Вопросы: как можно обновлять объект table в конце каждого шага цикла? Или как можно сделать вставку ячеек в таблицу нужное количество раз?

Возможно, кто ни будь из вас работал с OpenOffice как-то иначе и более результативно? Подскажите пожалуйста.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.04.2014, 09:23
Ответы с готовыми решениями:

Вывод XML в виде структурированной таблицы данных
Всем доброго дня. У меня такой вопрос, как реализовать форму, на которой будет простая кнопка &quot;Загрузить XML&quot; и при окончании...

Запись данных в OpenOffice.Calc 4.1.1
Всем привет,кто знает как связать C# и OpenOffice Calc? Мне нужно с программы отправить туда данные в определенные ячейки и сохранить файл,...

Запись данных из datagrid в OpenOffice.Calc 4.1.2
делала как здесь https://www.cyberforum.ru/windows-forms/thread1486867.html но выводит ошибку что программа старая. Может кто знает как...

2
 Аватар для Shambler-AdMec
11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53
25.04.2014, 11:59  [ТС]
все ещё актуально
0
 Аватар для Shambler-AdMec
11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53
29.04.2014, 08:51  [ТС]
Додумался вставить в пределы цикла создание экземпляра cell типа Cell. Однако, все это работает как то странно - ячейки в координаты (1,i), где i - шаг цикла, вставляются в таблицу абы как. Не там, где задано

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 for (int i = 1; i <= 4; ++i)
             {
                 Cell cell = table.CreateCell("cell001");
                 cell.OfficeValueType = "string";
                 //устанавливаем границы
                 cell.CellStyle.CellProperties.Border = Border.NormalSolid;
 
                //создаем новый параграф
                 Paragraph paragraph = 
                 ParagraphBuilder.CreateSpreadsheetParagraph(spreadsheetDocument);
                 //добавляем в него - текст
             
                 paragraph.Node.InnerText = "";
                 paragraph.TextContent.Add(new SimpleText(spreadsheetDocument, "test" + i));
                 //теперь добавляем созданный параграф в ячейку
                 cell.Content.Add(paragraph);
                 table.InsertCellAt(1, i, cell); 
             }
             spreadsheetDocument.TableCollection.Add(table);
             spreadsheetDocument.SaveTo("c:\\c#\\simple.ods");
Добавлено через 17 часов 56 минут
C#
1
table.InsertCellAt(1, i, cell);
в этой строке заменил переменную i на 1, после чего в ods-файле получил заполненный столбик B2:B5 со значениями соответственно test4-test1. Уже что-то похожее на реальный результат, хотя как-то перанус.... но работает!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.04.2014, 08:51
Помогаю со студенческими работами здесь

Вывод данных на форму в виде таблицы
Здравствуйте! Уже третий день бьюсь и не могу решить задачу: программа считает некоторые значения (хранятся в массивах), далее эти...

Открытие таблицы OpenOffice Calc
Хочу открыть таблицу, созданную под OpenOffice, считать от туда значение ячейки в элемент Memo. Я сделал это для таблицы, созданной в Excel...

Установить ширину столбца таблицы (Writer, OpenOffice)
Всем привет. Нужно установить ширину столбца таблицы Writer. На VBA код такой: oTblColSeps = oTable1.TableColumnSeparators ...

При переведе из OpenOffice Calc в HTML пропадают границы таблицы
Помогите, бьюсь второй день. При переводе прайс из OpenOffice Calc в HTML, пропадают крайние вертикальные границы. Ничего не помогает....

Подключить базу данных OpenOffice
есть база данных созданная в OpenOffice версии 4.1.1 с расширением .odb и Lazarus версии 1.2.6 нужно эту базу подключить все...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru