Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 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. Там все очень подробно и очень много чего.



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

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

Наверх





Память: 0.45 MB
Время: 0.005 c
4-33017
Sheva
2002-02-12 11:26
2002.04.11
Выполнение ShellExecute.


1-32839
LiNkS
2002-03-29 09:32
2002.04.11
ListBox


3-32664
GenBr
2002-03-20 12:33
2002.04.11
ClientDataSet


1-32901
Clon
2002-03-29 20:26
2002.04.11
Необходимо реализовать Drag&Drop из TDBGrid в другой контрол...


1-32734
Locked
2002-03-30 08:08
2002.04.11
Помогите пожалуйста!!!





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский