Главная страница
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.47 MB
Время: 0.021 c
6-1164628055
Yurij-7
2006-11-27 14:47
2007.06.17
LDAP и работа с ним


15-1179701551
P
2007-05-21 02:52
2007.06.17
Какая религия Вам ближе?


3-1174897322
DelphiLexx
2007-03-26 12:22
2007.06.17
Как заставить fibs понимать внутренние и внешние параметры Execut


2-1180015207
Я Гость
2007-05-24 18:00
2007.06.17
ADO + paradox + cp1251


3-1174936697
ChainickDenis
2007-03-26 23:18
2007.06.17
Что-то не соображу как запрос сформировать, пожскжите плиз...