Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.11;
Скачать: [xml.tar.bz2];




Вниз

Конвертация таблицы в Excel 


AndrewK   (2002-03-28 14:10) [0]

Добрый день.

Конвертирую таблицу в Excel c использованием TExcelApplication следующим образом:

var TabGrid : Variant;
...
TabGrid := VarArrayCreate([0,(R - 1),0,(C - 1)],VarOleStr);
...
TabGrid[I,J] := dbGrid.Columns.Items[J].Field.AsString;
...
Worksheet.Range[Worksheet.Cells.Item[1,1],Worksheet.Cells.Item[R,C]].Value := TabGrid;
...

Данные переносятся, все вроде бы нормально, однако при попытке выполнить какие-нибудь операции в самом Excel с данными, например суммировании колонки, выясняется, что все ячейки заполнены строками. Если в эти ячейки зайти клавишей F2 (т.е. запустить редактирование) и нажать Enter, то строка переводится в число, что и требовалось. Очень не удобно.

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



AndrewK   (2002-03-28 15:12) [1]

Сам разобрался.
Кому интерестно:

Переписываем

TabGrid := VarArrayCreate([0,(R - 1),0,(C - 1)],VarVariant);
...
TabGrid[I,J] := FieldToVariant(dbGrid.Columns.Items[J].Field);

И пишем функцию:

function FieldToVariant(Field:TField):OLEVariant;
begin
Result := "";
case Field.DataType of
ftString, ftFixedChar, ftWideString, ftMemo,
ftFmtMemo: Result := """" + Field.AsString;
ftSmallint, ftInteger, ftWord, ftLargeint, ftAutoInc:
Result := Field.AsInteger;
ftFloat, ftCurrency, ftBCD: Result := Field.AsFloat;
ftBoolean: Result := Field.AsBoolean;
ftDate, ftTime, ftDateTime: Result := Field.AsDateTime;
end
end;

Все заработало.



Strannik_   (2002-03-31 09:04) [2]

Здраствуй ты не знаешь как програмно поменять формат ячеек после записи в них данных, и ты не мог бы скинуть мне свою прогу на мыло я сейчас как раз разбираюсь с Excel



KSergey   (2002-03-31 14:42) [3]

Друзья!
Зайдите просто на сайт "Королевство Delphi" и в разделе "Hello, World!" прочитайте статьи по связи с MS Excel. Там все очень подробно и очень много чего.




Форум: "Основная";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.11;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.023 c
3-32693           Sergant               2002-03-21 12:43  2002.04.11  
Отображение удаленных записей в Grid е


1-32740           skovorodka            2002-03-29 14:29  2002.04.11  
Как сделать неправильной формы кнопку >:) не надо называть меня л


1-32879           Kazah_Progr           2002-03-29 15:20  2002.04.11  
Какое событые возникает при минимизации формы (свернуть)


1-32768           GMV                   2002-03-30 22:27  2002.04.11  
Memo1.Text


1-32886           Толик                 2002-03-27 16:11  2002.04.11  
И снова про вызовы функций-членов