const
CXlsBof: array[0..5] of Word = ($809, 8, 00, $10, 0, 0);
CXlsEof: array[0..1] of Word = ($0A, 00);
CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
CXlsNumber: array[0..4] of Word = ($203, 14, 0, 0, 0);
CXlsRk: array[0..4] of Word = ($27E, 10, 0, 0, 0);
procedure XlsBeginStream(XlsStream: TStream; const BuildNumber: Word);
begin
CXlsBof[4] := BuildNumber;
XlsStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
end;
procedure XlsEndStream(XlsStream: TStream);
begin
XlsStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
end;
procedure XlsWriteCellRk(XlsStream: TStream; const ACol, ARow: Word;
const AValue: Integer);
var
V: Integer;
begin
CXlsRk[2] := ARow;
CXlsRk[3] := ACol;
XlsStream.WriteBuffer(CXlsRk, SizeOf(CXlsRk));
V := (AValue shl 2) or 2;
XlsStream.WriteBuffer(V, 4);
end;
procedure XlsWriteCellNumber(XlsStream: TStream; const ACol, ARow: Word;
const AValue: Double);
begin
CXlsNumber[2] := ARow;
CXlsNumber[3] := ACol;
XlsStream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber));
XlsStream.WriteBuffer(AValue, 8);
end;
procedure XlsWriteCellLabel(XlsStream: TStream; const ACol, ARow: Word;
const AValue: string);
var
L: Word;
begin
L := Length(AValue);
CXlsLabel[1] := 8 + L;
CXlsLabel[2] := ARow;
CXlsLabel[3] := ACol;
CXlsLabel[5] := L;
XlsStream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel));
XlsStream.WriteBuffer(Pointer(AValue)^, L);
end;
procedure TForm1.Button1Click(Sender: TObject);
var
FStream: TFileStream;
I, J: Integer;
begin
FStream := TFileStream.Create('c:\e.xls', fmCreate);
try
XlsBeginStream(FStream, 0);
for I := 0 to 99 dofor J := 0 to 99 dobegin
XlsWriteCellNumber(FStream, I, J, 34.34);
// XlsWriteCellRk(FStream, I, J, 3434); // XlsWriteCellLabel(FStream, I, J, Format('Cell: %d,%d', [I, J])); end;
XlsEndStream(FStream);
finally
FStream.Free;
end;
end;
Программа на Delphi, которая создает файл Excel без использования OLE (Object Linking and Embedding). Программа использует компонент TFileStream, чтобы записать данные в файл с именем "c:\e.xls".
Программа определяет несколько констант (CXlsBof, CXlsEof и т.д.), которые представляют собой заголовок и подвал Excel-файла. Она также определяет три процедуры: XlsBeginStream, XlsEndStream и три других процедуры, которые пишут данные в поток.
В обработчике события Button1Click программа создает новый файл, используя TFileStream.Create, а затем начинает запись потока, используя XlsBeginStream. Затем программа проходит по 100 строкам и столбцам, записывая число ячейки (34.34) в каждом положении, используя XlsWriteCellNumber.
Альтернативное решение:
Вместо определения отдельных процедур для записи ячеек с различными типами данных можно создать одиночную процедуру, которая принимает указатель на данные и длину параметров. Это позволит записывать ячейки с любым типом данных.
Обновленная версия программы:
procedureXlsWriteCell(XlsStream:TStream;constACol,ARow:Word;pData:Pointer;pDataLen:Integer);beginCXlsNumber[2]:=ARow;CXlsNumber[3]:=ACol;XlsStream.WriteBuffer(CXlsNumber,SizeOf(CXlsNumber));ifpDataLen>0thenXlsStream.WriteBuffer(pData^,pDataLen);end;procedureTForm1.Button1Click(Sender:TObject);varFStream:TFileStream;I,J:Integer;beginFStream:=TFileStream.Create('c:\e.xls',fmCreate);tryXlsBeginStream(FStream,0);forI:=0to99doforJ:=0to99dobeginXlsWriteCell(FStream,I,J,@IntToDouble(34.34),SizeOf(Double));end;XlsEndStream(FStream);finallyFStream.Free;end;end;functionIntToDouble(val:Integer):Double;beginResult:=val+0.0;// конвертируем целочисленное значение в вещественноеend;
В этой версии программа создает одиночную процедуру XlsWriteCell, которая принимает указатель на данные и длину параметров, и пишет данные в поток. Функция IntToDouble используется для конвертации целочисленного значения в вещественное.
Эта APPROACH позволяет записывать ячейки с любым типом данных, включая строки, целые числа и дробные числа. Вы можете модифицировать процедуру XlsWriteCell, чтобы обрабатывать различные типы данных, используя функцию TypeOf для определения типа данных, а затем записывая его соответствующим образом.
Создание Excel-файла без использования технологии OLE.
Комментарии и вопросы
Получайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.