Модераторы: MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как быстро записывать данные в Excel 
:(
    Опции темы
pavelv
Дата 24.7.2008, 07:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 245
Регистрация: 5.2.2006

Репутация: нет
Всего: нет



Всем привет.
Стандартно работаю с Excel, но отчеты очень долго создаются. Вчера сел, думаю буду оптимизировать запросы и опа-на: время на запросах 30сек, а время на запись данных 2.5минуты. Sql конечно нуждается в оптимизации, но думаю для начала нужно с записью разобраться.
В отчете использую:
1)Excel.ActiveWorkBook.Sheet[1].Cells[i,j].EntireRow.Insert;
2)Excel.ActiveWorkBook.Sheets.Item[Sheet].Range[range] := Value;

Может есть какая-нибудь возможность более быстро заносить данные в xls документ? Или допустим создать переменную, как бы образ документа и с ней работать а потом перекинуть всё разом в Excel. Может ещё какой вариант, кто как выкручивался в общем? smile
PM MAIL   Вверх
v00d00
Дата 24.7.2008, 09:29 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 142
Регистрация: 28.12.2005

Репутация: нет
Всего: нет



Попробуйте сначала записать данные в TMemo. Разделение данных между ячейками - #9, перевод строки - #13. Далее копируете полученный текст в буфер обмена. Выделаете область ячеек в Excel'e такого же размера, и вставляете туда выделенный текст.


что то в этом духе:

Код

    mem.SelectAll;
    mem.CopyToClipboard;

    ExcelApp.Workbooks[1].WorkSheets['Grid Data'].Range['A1:B10'].Select;
    ExcelApp.Selection.NumberFormat := '@';
    try
      ExcelApp.Workbooks[1].WorkSheets['Grid Data'].Paste;
      ExcelApp.Workbooks[1].WorkSheets['Grid Data'].Range['A1'].Select;
    except
    end;


Или посмотрите компонент для работы с Excel'ем

http://www.torry.net/authorsmore.php?id=3262

Это сообщение отредактировал(а) v00d00 - 24.7.2008, 09:35
PM MAIL   Вверх
pavelv
Дата 24.7.2008, 09:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 245
Регистрация: 5.2.2006

Репутация: нет
Всего: нет



С Memo не очень идея нравится. Компоненты только платные или бесплатный есть?
PM MAIL   Вверх
Albinos_x
Дата 24.7.2008, 18:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Evil Skynet
****


Профиль
Группа: Комодератор
Сообщений: 3288
Регистрация: 28.5.2004
Где: X-6120400 Y-1 4624650

Репутация: 15
Всего: 108



я описывал здесь вариант
http://forum.vingrad.ru/topic-84634.html


--------------------
"Кто владеет информацией, тот владеет миром"    
Уинстон Черчилль
PM MAIL ICQ   Вверх
pavelv
Дата 25.7.2008, 04:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 245
Регистрация: 5.2.2006

Репутация: нет
Всего: нет



Спасибо, глянул вроде понятно smile.
На следующей неделе постараюсь протестировать ExcelApplication на скорость записи данных, а там отпишусь стоит или нет заморачиваться в случае подобных проблем.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi: ActiveX/СОМ/CORBA"

Rrader
Girder

Запрещено:

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами


  • Литературу по Delphi обсуждаем здесь
  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Delphi
  • Вопросы по SQL и вопросы по базам данных, не связанные с Delphi, задавать здесь

Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Rrader, Girder.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Delphi: ActiveX/СОМ/CORBA | Следующая тема »


 




[ Время генерации скрипта: 0.1100 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.