AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 30.10.2006, 10:42   #1  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Вывод в Excel в формате XML и ширина колонок
В коллективном эксперименте по экспорту данных в Excel на скорость был упомянут метод экспорта данных в XML. Замечательная идея: не нужен сам Excel для формирования книги, работает быстро, можно сразу задать форматирование, нарисовать рамочки, задать нужный тип ячеек (текст, число, дата) и т.д... Но я лично столкнулся с одной неприятной особенностью, по крайней мере, в Excel 2003 SP2 (v11.8012.6568): если выводить данные в файл и потом открывать его в Excel
X++:
str                         filename;
str                         buf;
TextBuffer                  tb;
ComExcelDocument_Ru         excel;
// ...
tb.setText(buf);
tb.toFile(filename);
excel.open(filename, false);
то все замечательно, форматирование получается полностью такое, как написано. Если же обходиться без промежуточного файла и выводить данные в Range
X++:
#define.xlRangeValueXMLSpreadsheet(0x0000000B)
str buf;
int cnLines;
COM sheet;
COM range;
// ...
range = sheet.range("A1:G" + int2str(cnLines));
range.value(#xlRangeValueXMLSpreadsheet, buf);
то форматирование работает полностью, за исключением того, что не устанавливается ширина колонок в соответствии с тем, что написано в XML-данных
PHP код:
#define.LF ('\n')
str b;
;
= @'<Table ss:ExpandedColumnCount="7" x:FullColumns="1" x:FullRows="1" ss:StyleID="s01">' #LF +
    
@' <Column ss:Width="27.75"/>' #LF +
    
@' <Column ss:Width="37.5" ss:Span="1"/>' #LF +
    
@' <Column ss:Width="300" ss:Index="4"/>' #LF +
    
@' <Column ss:Width="67.5"/>' #LF +
    
@' <Column ss:Width="45" ss:Span="1"/>' #LF; 
Кто-нибудь сталкивался с таким? Очень уж не хочется плодить кучу временных файлов... Может, я что-то в тэгах Table не так указываю? Не ставить же ширину колонок "вручную" через COM
Старый 30.10.2006, 10:45   #2  
AndyD is offline
AndyD
Участник
КОРУС Консалтинг
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
 
2,560 / 2479 (88) +++++++++
Регистрация: 20.08.2005
Да, есть такое дело. Пока решил через COM (или с использованием шаблонов)
__________________
Axapta v.3.0 sp5 kr2
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
ПФР в формате xml, Microsoft реализовал? или как всегда... Ивга DAX: Функционал 5 12.02.2009 16:28
Вывод картинки в Excel Zlojbarsuk DAX: Программирование 1 14.08.2008 14:21
Маленькое замечание про вывод в Excel NNB DAX: Программирование 11 23.06.2008 16:23
Вывод в Excel в определнный Worksheet... soin DAX: Программирование 1 22.10.2004 13:53
Сохранение настроек GRID (ширина и порядок колонок) liza DAX: Программирование 1 25.07.2003 22:20
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 14:17.