DELPHI7 DBGRID 导出EXCEL

uses comobj;


function TSocialInsuranceForm.ExportDBGrid(DBGrid: TDBGrid; SheetName: string): boolean;//直接保存,不显示EXCEL
var
c, r, i, j: integer;
app: Olevariant;
TempFileName, ResultFileName: string;

begin

try
result := True;
app := CreateOLEObject('Excel.Application');
// app.WorkBooks.Add(xlWBatWorkSheet);
except
Application.MessageBox('Excel没有正确安装!','警告',MB_OK);
result := False;
exit;
end;

SaveDialog1.DefaultExt := 'xls';
SaveDialog1.FileName := SheetName;

if SaveDialog1.Execute then
TempFileName := SaveDialog1.FileName
else
Exit;

app.Workbooks.add;
app.Visible := false;
Screen.Cursor := crHourGlass;
DBGrid.DataSource.DataSet.First;
c := DBGrid.DataSource.DataSet.FieldCount; // 列
r := DBGrid.DataSource.DataSet.RecordCount; //行
Application.ProcessMessages;

for i := 0 to c - 1 do
app.cells(1, 1 + i) := DBGrid.DataSource.DataSet.Fields[i].DisplayLabel;

for j := 1 to r do
begin
app.activeSheet.Columns[3].numberformatlocal:='@'; // 设置第三列为文本格式
// app.activesheet.rows[2].numberformat:='@'; //设置第二行为文本格式
for i := 0 to c - 1 do
app.cells(j + 1, 1 + i) := DBGrid.DataSource.DataSet.Fields[i].AsString;
DBGrid.DataSource.DataSet.Next;
end;

ResultFileName := TempFileName;

if ResultFileName = '' then
ResultFileName := '数据导出';

if FileExists(TempFileName) then
DeleteFile(TempFileName);

app.Activeworkbook.saveas(TempFileName);
app.Activeworkbook.close(false);
app.quit;
app := unassigned;
end;


procedure TsocialInsuranceForm.ExportBtnClick(Sender: TObject);
begin //导出按钮

try
Screen.Cursor := crHourGlass;
ExportDBGrid(SocialInsuranceDbg, '导出数据.xls'); //暂时将导出的文件名称为“导出数据.xls”(的execl文件)
application.MessageBox('导出数据完成','提示',0+64);
finally
Screen.Cursor := crDefault;
end;

end;


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/729024/viewspace-564891/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/729024/viewspace-564891/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值