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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 29.09.2005, 15:27   #1  
petergunn is offline
petergunn
Участник
 
118 / 274 (10) ++++++
Регистрация: 30.08.2005
Адрес: Tyumen
Thumbs down ComWordDocument_RU - медленная работа
Axapta 3.0 SP3

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

Суть топика скорее сводится к медленной работе метода ComWordDocument_RU.InsertFieldValue(). Небольшие манипуляции с профайлером кода показывают что основное время тратится на вызов ComWordDocument_RU.FindField.
Посмотрим на код этого метода:
PHP код:
protected COM FindField(MSOfficeBookMark_RU _bookMark)
{
    
COM fieldsFieldFieldTmp;
    
int i;
    ;

    try
    {
        if (
m_comDocument)
        {
            
Fields =  m_comDocument.FormFields();

            if (
substr(m_comApplication.version(), ,1) >= '9'// Word 2000 and later
            
{
                
field fields.item(_bookMark);
            }
            else
            {
                 for (
i=i<= fields.count() ; i+=1)
                 {
                      
fieldTmp fields.item(i);

                      if (
fieldTmp.name() == _bookMark)
                      {
                            
field fieldTmp;
                            break;
                      }
                 }

                 if (! 
field)
                 {
                      
info(StrFmt("@DIS12564"_bookMark));
                 }

            }

        }
        else
        {
            
info(StrFmt("@DIS6408"this.GetApplicationName()));
        }
    }

    catch(
exception::error)
    {
        
info(StrFmt("@DIS12564"_bookMark));
    }

    return 
field;

а вот это уже интересно:

PHP код:
            if (substr(m_comApplication.version(), ,1) >= '9'// Word 2000 and later
            
{
                
field fields.item(_bookMark);
            }
            else
            {
                 for (
i=i<= fields.count() ; i+=1)
                 {
                      
fieldTmp fields.item(i);

                      if (
fieldTmp.name() == _bookMark)
                      {
                            
field fieldTmp;
                            break;
                      }
                 }

                 if (! 
field)
                 {
                      
info(StrFmt("@DIS12564"_bookMark));
                 }

            } 
Судя по комментарию ( DIS-слой ) для Word2000 и более поздних выбор поля должен происходить с использованием быстрой конструкции fields.item(_bookMark). На деле же из-за коряво написанного условия определения версии приложения
PHP код:
            if (substr(m_comApplication.version(), ,1) >= '9'// Word 2000 and later 
поиск поля заваливается в цикл с последовательным перебором полей документа.
Кому не лень, может загрузить Word и посмотреть major номер версии приложения - для Word2002 это будет что-то типа "10.2627.2625", соответсвенно проверка
if( substr( '10.2627.2625', 1, 1 ) >= '9' ) еще долго не вернет TRUE и будет обрекать счастливых обладателей последних версий продуктов от Microsoft на длительное ожидание

Небольшая модификация условия: ( в потомке или непосредственно в ComWordDocument_RU - кому как нравится )
PHP код:
 if( str2intm_comApplication.version() ) >= // Word 2000 and later 
приводит к заметному оживлению вывода в Word при условии что он не древнее Word2000.

Ну вот пожалуй и все что удалось накопать.
Старый 06.10.2005, 08:21   #2  
tumev is offline
tumev
Участник
 
30 / 10 (1) +
Регистрация: 12.09.2005
Привет!

Подкидывали идею о замене кусочка кода (для стареньких версий Word):
..........
for (i=1 ; i<= fields.count() ; i+=1)
{
fieldTmp = fields.item(i);
.........
На следующее:

int fieldsCount ;
.......
fieldsCount = fields.count();
for (i=1 ; i<= fieldsСount ; i++)
{
fieldTmp = fields.item(i);
.............
Старый 06.10.2005, 09:25   #3  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
еще можно не спрашивать версию приложения каждый раз а запомнить при первом вызове.
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Доступ к меню "Работа с документами" Kuat DAX: Администрирование 4 16.11.2007 17:07
Совместная работа заказчика и исполнителя в разных или одном слое? Кузин Владимир В. DAX: Программирование 6 08.08.2006 10:02
Опции темы Поиск в этой теме
Поиск в этой теме:

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

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

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

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