F
fghyxxe
Unregistered / Unconfirmed
GUEST, unregistred user!
procedure TOperateSTrGrid.XlsWriteCellLabel(XlsStream: TStream; const ACol,
ARow: Word; AValue: string);
var
L: Integer;
const
{$J+}
CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
{$J-}
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;
function TOperateSTrGrid.StringGridToExcel(AGrid: TStringGrid;
AFileName: string;R1,R2,C1,C2 : Integer): Boolean;
const
{$J+} CXlsBof: array[0..5] of Word = ($809, 8, 0, $10, 0, 0); {$J-}
CXlsEof: array[0..1] of Word = ($0A, 00);
var
FStream: TFileStream;
I, J: Integer;
begin
R1 := FristRow; //第一行
R2 := FinallyRow; //最后一行
C1 := FristCol; //第一列
C2 := FinallyCol; //最后一列
if R1 = 0 then
R1 := 1;
if C1 = 0 then
C1 := 1;
if R2 = 0 then
R2 := AGrid.RowCount;
if C2 = 0 then
C2 := AGrid.ColCount;
FStream := TFileStream.Create(PChar(AFileName), fmCreate or fmOpenWrite);
try
CXlsBof[4] := 0;
FStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
for i := C1-1 to C2 do
for j := R1-1 to R2 do
XlsWriteCellLabel(FStream, I, J, AGrid.cells[i, j]);
FStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
Result := True;
finally
FStream.Free;
end;
end;
上面的两个函数在导出Excel时,当数据量比较小的时候,比如说AGrid.Cells[1,1]的数据量比较少的时候.就可以正常的导出到Excel中.可是它数据量太大的时候,如AGrid.Cells[1,1]中的字符串有几千个字的时候.就会在打开Excel时出现:不能读取文件,用文本文件打个这个Excel文件时,里面的数据却存在.请问这是怎么一回事呀?
大家帮帮忙呀.
ARow: Word; AValue: string);
var
L: Integer;
const
{$J+}
CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
{$J-}
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;
function TOperateSTrGrid.StringGridToExcel(AGrid: TStringGrid;
AFileName: string;R1,R2,C1,C2 : Integer): Boolean;
const
{$J+} CXlsBof: array[0..5] of Word = ($809, 8, 0, $10, 0, 0); {$J-}
CXlsEof: array[0..1] of Word = ($0A, 00);
var
FStream: TFileStream;
I, J: Integer;
begin
R1 := FristRow; //第一行
R2 := FinallyRow; //最后一行
C1 := FristCol; //第一列
C2 := FinallyCol; //最后一列
if R1 = 0 then
R1 := 1;
if C1 = 0 then
C1 := 1;
if R2 = 0 then
R2 := AGrid.RowCount;
if C2 = 0 then
C2 := AGrid.ColCount;
FStream := TFileStream.Create(PChar(AFileName), fmCreate or fmOpenWrite);
try
CXlsBof[4] := 0;
FStream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
for i := C1-1 to C2 do
for j := R1-1 to R2 do
XlsWriteCellLabel(FStream, I, J, AGrid.cells[i, j]);
FStream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
Result := True;
finally
FStream.Free;
end;
end;
上面的两个函数在导出Excel时,当数据量比较小的时候,比如说AGrid.Cells[1,1]的数据量比较少的时候.就可以正常的导出到Excel中.可是它数据量太大的时候,如AGrid.Cells[1,1]中的字符串有几千个字的时候.就会在打开Excel时出现:不能读取文件,用文本文件打个这个Excel文件时,里面的数据却存在.请问这是怎么一回事呀?
大家帮帮忙呀.