11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53
1

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

23.04.2014, 09:23. Показов 3776. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
23.04.2014, 09:23
Ответы с готовыми решениями:

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

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

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

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

2
11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53
25.04.2014, 11:59  [ТС] 2
все ещё актуально
0
11 / 10 / 3
Регистрация: 27.02.2013
Сообщений: 53
29.04.2014, 08:51  [ТС] 3
Додумался вставить в пределы цикла создание экземпляра 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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
29.04.2014, 08:51
Помогаю со студенческими работами здесь

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru