快速导出记录集到Excel

 
  
{
功能:将数据集的数据导入Excel;
用法:With ExportXls.Create(TDataSet(ADOQuery1)) do
Try
Save2File(SaveDialog1.FileName, True);
finally
Free;
end;

}

unit uExportXls;

interface

uses
DB, Classes;

var
CXlsBof:
array [ 0 .. 5 ] of Word = ($ 809 , 8 , 0 , $ 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 );
CXlsBlank:
array [ 0 .. 4 ] of Word = ($ 201 , 6 , 0 , 0 , $ 17 );

type
TFldRec
= record
Title:
string ;
Width: Integer;
end ;

ExportXls
= class (TObject)
Private
FCol: word;
FRow: word;
FDataSet: TDataSet;
Stream: TStream;
FWillWriteHead: boolean;
FBookMark: TBookmark;
procedure IncColRow;
procedure WriteBlankCell;
procedure WriteFloatCell( const AValue: Double);
procedure WriteIntegerCell( const AValue: Integer);
procedure WriteStringCell( const AValue: string );
procedure WritePrefix;
procedure WriteSuffix;
procedure WriteTitle;
procedure WriteDataCell;

procedure Save2Stream(aStream: TStream);
Public
procedure Save2File(FileName: string ; WillWriteHead: Boolean);
constructor Create(aDataSet: TDataSet);
end ;
function ExportToXLS( const FileName: string ; DataSet: TDataSet): Boolean;
implementation

uses SysUtils;

function ExportToXLS( const FileName: string ; DataSet: TDataSet): Boolean;
begin
Result :
= False;
with ExportXls.Create(DataSet) do
try
Save2File(FileName, True);
Result :
= True;
finally
Free;
end ;
end ;

constructor ExportXls.Create(aDataSet: TDataSet);
begin
inherited Create;
FDataSet :
= aDataSet;
end ;

procedure ExportXls.IncColRow;
begin
if FCol = FDataSet.FieldCount - 1 then
begin
Inc(FRow);
FCol :
= 0 ;
end
else
Inc(FCol);
end ;

procedure ExportXls.WriteBlankCell;
begin
CXlsBlank[
2 ] : = FRow;
CXlsBlank[
3 ] : = FCol;
Stream.WriteBuffer(CXlsBlank, SizeOf(CXlsBlank));
IncColRow;
end ;

procedure ExportXls.WriteFloatCell( const AValue: Double);
begin
CXlsNumber[
2 ] : = FRow;
CXlsNumber[
3 ] : = FCol;
Stream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber));
Stream.WriteBuffer(AValue,
8 );
IncColRow;
end ;

procedure ExportXls.WriteIntegerCell( const AValue: Integer);
var
V: Integer;
begin
CXlsRk[
2 ] : = FRow;
CXlsRk[
3 ] : = FCol;
Stream.WriteBuffer(CXlsRk, SizeOf(CXlsRk));
V :
= (AValue shl 2 ) or 2 ;
Stream.WriteBuffer(V,
4 );
IncColRow;
end ;

procedure ExportXls.WriteStringCell( const AValue: string );
var
L: Word;
begin
L :
= Length(AValue);
CXlsLabel[
1 ] : = 8 + L;
CXlsLabel[
2 ] : = FRow;
CXlsLabel[
3 ] : = FCol;
CXlsLabel[
5 ] : = L;
Stream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel));
Stream.WriteBuffer(Pointer(AValue)^, L);
IncColRow;
end ;

procedure ExportXls.WritePrefix;
begin
Stream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
end ;

procedure ExportXls.WriteSuffix;
begin
Stream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
end ;

procedure ExportXls.WriteTitle;
var
n: word;
begin
for n : = 0 to FDataSet.FieldCount - 1 do
WriteStringCell(FDataSet.Fields[n].DisplayLabel);
// 显示标签名
end ;

procedure ExportXls.WriteDataCell;
var
Idx: word;
begin
WritePrefix;
if FWillWriteHead then
WriteTitle;
FDataSet.DisableControls;
FBookMark :
= FDataSet.GetBookmark;
FDataSet.First;
while not FDataSet.Eof do
begin
for Idx : = 0 to FDataSet.FieldCount - 1 do
begin
if FDataSet.Fields[Idx].IsNull then
WriteBlankCell
else
begin
case FDataSet.Fields[Idx].DataType of
ftSmallint, ftInteger, ftWord, ftAutoInc, ftBytes:
WriteIntegerCell(FDataSet.Fields[Idx].AsInteger);
ftFloat, ftCurrency, ftBCD:
WriteFloatCell(FDataSet.Fields[Idx].AsFloat);
else
if Assigned(FDataSet.Fields[Idx].OnGetText) then
WriteStringCell(FDataSet.Fields[Idx].Text)
else
WriteStringCell(FDataSet.Fields[Idx].AsString);
end ;
end ;
end ;
FDataSet.Next;
end ;
WriteSuffix;
if FDataSet.BookmarkValid(FBookMark) then
FDataSet.GotoBookmark(FBookMark);
FDataSet.EnableControls;
end ;

procedure ExportXls.Save2Stream(aStream: TStream);
begin
FCol :
= 0 ;
FRow :
= 0 ;
Stream :
= aStream;
WriteDataCell;
end ;

procedure ExportXls.Save2File(FileName: string ; WillWriteHead: Boolean);
var
aFileStream: TFileStream;
begin
FWillWriteHead :
= WillWriteHead;
if FileExists(FileName) then
DeleteFile(FileName);
aFileStream :
= TFileStream.Create(FileName, fmCreate);
try
Save2Stream(aFileStream);
finally
aFileStream.Free;
end ;
end ;

end .

 

转载于:https://www.cnblogs.com/dyz/archive/2010/02/05/1664492.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值