Форум: "Основная";
Поиск по всему сайту: 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.027 c
1-32819           tall                  2002-03-27 14:17  2002.04.11  
run-time error


1-32876           RUS1                  2002-03-29 12:46  2002.04.11  
Работа с битами и байтами


3-32657           Брат                  2002-03-20 09:10  2002.04.11  
Не открывается таблица....


3-32652           clarin                2002-03-19 14:24  2002.04.11  
Сортировка по вычислимому полю в TQuery


1-32789           NIC2                  2002-03-31 11:55  2002.04.11  
WebBrowser