Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2007.06.17;
Скачать: [xml.tar.bz2];

Вниз

Ошибка "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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.038 c
2-1180348039
Чип
2007-05-28 14:27
2007.06.17
Фильтрация через компонент table (по 1 значению)


2-1179912719
evg123
2007-05-23 13:31
2007.06.17
Разрешающая способность


2-1179961169
delphino
2007-05-24 02:59
2007.06.17
operator not applicable to this operand type


6-1164628055
Yurij-7
2006-11-27 14:47
2007.06.17
LDAP и работа с ним


2-1179903497
RomanLN
2007-05-23 10:58
2007.06.17
как в DBgrib вять(присвоить) содержимое нужной ячейки





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