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

Вниз

Ошибка "OLE error 800A03EC" при передаче StringGrid в Excel   Найти похожие ветки 

 
Darvin ©   (2007-05-25 13:46) [0]

Здрасвтвуйте!
Передаю данные из StringGrid в Excel таким способом:

function SaveAsExcelFile(AGrid: TStringGrid; ASheetName, AFileName: string): Boolean;
const
 xlWBATWorksheet = -4167;
var
 Row, Col: Integer;
 GridPrevFile, S: string;
 XLApp, Sheet, Data: OLEVariant;
 i, j: Integer;
 D : Double;

 function RefToCell(ARow, ACol: Integer): string;
 begin
   Result := Chr(Ord("A") + ACol - 1) + IntToStr(ARow);
 end;

begin
 Data := VarArrayCreate([1, AGrid.RowCount, 1, 20{AGrid.ColCount}], varVariant);
 for i := 0 to 20{AGrid.ColCount} - 1 do
   for j := 0 to AGrid.RowCount - 1 do begin
     S := AGrid.Cells[i, j];
     // Конвертирование в число
     try
       D := StrToFloat (S);
       Data[J + 1, I + 1] := D;
     except
       Data[J + 1, I + 1] := S;
     end;
   end;

 Result := False;
 XLApp := CreateOleObject("Excel.Application");
 try
   XLApp.Visible := True;
   XLApp.Workbooks.Add(xlWBatWorkSheet);
   Sheet := XLApp.Workbooks[1].WorkSheets[1];
   Sheet.Name := ASheetName;
   Sheet.Range[RefToCell(1, 1),
               RefToCell(AGrid.RowCount, 20{AGrid.ColCount})].Value := Data;
 finally
 end;
end;

Так вот, для небольших таблиц, например 20 x 15, все работает, а для таблиц 61 x 15 выдается ошибка OLE error 800A03EC в строке:
   Sheet.Range[RefToCell(1, 1),
               RefToCell(AGrid.RowCount, 20{AGrid.ColCount})].Value := Data;

Как можно такое победить?


 
Darvin ©   (2007-05-25 13:48) [1]

Прошу прощения, для возникновения ошибки комментарии {AGrid.ColCount} надо раскрыть, а 20, стоящую перед ними удалить. Если этого не сделать, ошибки не возникнет.



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

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

Наверх




Память: 0.45 MB
Время: 0.031 c
2-1180444247
ыавпып
2007-05-29 17:10
2007.06.17
таблицы в MSAccess


1-1177139483
Ламонов Олег
2007-04-21 11:11
2007.06.17
Лишняя инфа


9-1153902502
Илья Щукин
2006-07-26 12:28
2007.06.17
Ошибка компиляции


1-1176968507
Oleg_teacher
2007-04-19 11:41
2007.06.17
Как не закрить форму?


2-1180172140
antonyan
2007-05-26 13:35
2007.06.17
1C





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский