Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2011.05.29;
Скачать: CL | DM;

Вниз

Как оптимизировать чтение excel документа   Найти похожие ветки 

 
msgipss   (2007-03-20 16:41) [0]

Здравствуйте знатоки,
задача следующая: нужно сохранить содержимое excel документа в html формате.
Сразу скажу, что родной метод объекта excel (сохранить как html) не подходит по многим причинам.
Делаем программно следующее:
1. создаем объект excel, загружаем в него документ
2. построчно разбираем его активные области (чтение всех необходимых свойств ячеек)
3. собираем html в нужном нам виде.

Все работает, но достаточно медленно. Работа второго пункта очень тормозит. Получение каждой ячейки, чтение всех ее свойств.

Подскажите варианты оптимизации, если они возможны ? Или программно из внешнего приложения нельзя получить ту производительность (или близкую) которой достигает родной метод excel"я.
Возможно ли прочитать документ (все свойства всех ячеек) в многопоточном режиме (разделив между ними документ на части).

Заранее благодарен за любую информацию по данному вопросу


 
umbra ©   (2007-03-20 19:14) [1]


> Возможно ли прочитать документ (все свойства всех ячеек)
> в многопоточном режиме

нет.

> Получение каждой ячейки, чтение всех ее свойств.
>

а это обязательно? неужели у каждой ячейки разные свойства? Может быть, можно читать диапазонами?


 
msgipss   (2007-03-20 19:46) [2]

>нет.
нельзя прочитать  в многопоточном режиме потому что сервер excel - sta?

>а это обязательно? неужели у каждой ячейки разные свойства? Может быть, >можно читать диапазонами?
к сожалению нужно читать каждую ячейку *(, или стоп, что значит читать диапазонами ? Имеется в виду что можно прочитать в какую нить структуру указанный range и потом его обрабатывать в памяти ? Если так можно сделать - подскажите пожалуйста как это сделать ?


 
umbra ©   (2007-03-21 17:20) [3]


> нельзя прочитать  в многопоточном режиме потому что сервер
> excel - sta?

да :) . Но можно насоздавать кучу копий файла и работать с каждой отдельно. Но это уже извращение, по-моему

> Имеется в виду что можно прочитать в какую нить структуру
> указанный range и потом его обрабатывать в памяти ?

Не слышал о таком.

А как к экселю доступ получаете? Раннее связывание должно быть быстрее.


 
msgipss   (2007-03-23 08:56) [4]

>А как к экселю доступ получаете? Раннее связывание должно быть быстрее.
использую компонент с палитры, используется таблица типов, а значит и раннее связывание - насколько я помню - да ?

мдаа, плохо конечно, что все так медленно *(, аналогичный скрипт написанный на vba (в том же документе либо в загруженной надстройке) работает в разы быстрее (раз в 6-7). Должно быть конечно медленнее, но не в разы же *((.
наверное придется по якутски делить логику на vba и delphi



Страницы: 1 вся ветка

Текущий архив: 2011.05.29;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.008 c
3-1245114768
Богдан
2009-06-16 05:12
2011.05.29
обновление dbgrid


15-1297348833
delphi_developer
2011-02-10 17:40
2011.05.29
Программирование под iPhone


4-1248154627
Dmitriy
2009-07-21 09:37
2011.05.29
Открытые окна и Область рабочего стола.


1-1255414815
Игорь
2009-10-13 10:20
2011.05.29
ConstrainedResize


2-1297929463
marales
2011-02-17 10:57
2011.05.29
ini файл