中华网通行证
用户名 密码
  科技动态 硬件广场 下载基地 网络教室 网络冲浪 科学博览 移动时代 手机上网 桌面壁纸 科技商情  

如何在Delphi中操作Excel
穆永 2001-02-26 13:45:17

  在数据库应用软件的开发过程中,经常需要把数据转换成Excel文件,让用户作进一步的数据处理。而Delphi是开发数据库应用系统的常用工具,那么,如何在Delphi中操作Excel呢?

  我们知道,在Microsoft Office软件中有一种内嵌的编程语言VBA,它是一种宏语言,利用它,你可以编写出功能强大的代码,如打开文件、修改数据、保存数据和设置字体等。另一方面,Microsoft Office软件中的宏能以VBA代码的形式记录下你的操作过程。因此借助宏操作,可以很轻松地实现某一功能,并把这些代码稍作修改嵌入到你的软件中。但是VBA也存在一个缺点,它必须有Microsoft Office作平台,在哪里编写,必须在哪里执行。例如在Excel下编写的一段VBA代码,则它只有在Excel下才能运行。因此,笔者的方法就是把VBA代码嵌入到Delphi中,从而实现用Delphi操作Excel。
  下面,我们以Delphi程序为例,说明这种调用方法:

  Unit excel;

  interface

  uses

  Windows,Messages,SysUtils,Classes,Graphics,Controls,Forms,Dialogs, StdCtrls,ComObj;

  //ComObj是操作OLE对象的函数集

  type TForm1 =class(TForm)

  Button1: TButton;

  procedure Button1Click(Sender: TObject);

  private

  { Private declarations }

  public

  { Public declarations }

  end;

  var

  Form1: TForm1;

  implementation

  {$R *.DFM}

  procedure TForm1.Button1Click(Sender: TObject);

  var

  eclApp,WorkBook:Variant;

  //声明为OLE Automation 对象

  xlsFileName:string;begin

  xlsFileName:=‘ex.xls‘;

  try

  //创建OLE对象Excel Application与 WorkBook

  eclApp:=CreateOleObject(‘Excel.Application‘);

  WorkBook:=CreateOleobject(‘Excel.Sheet‘);

  except

  ShowMessage(‘您的机器里未安装Microsoft Excel。‘);

  Exit;

  end;

  try

  ShowMessage(‘下面演示:新建一个XLS文件,并写入数据,最后关闭它。‘);

  workBook:=eclApp.workBooks.Add;

  eclApp.Cells(1 , 1):=‘字符型‘;

  eclApp.Cells(2 , 1):=‘Excel文件‘;

  eclApp.Cells(1 , 2):=‘Money型‘;

  eclApp.Cells(2 , 2):=10.01;

  eclApp.Cells(1 , 3):=‘日期型‘;eclApp.Cells(2 , 3):=Date;

  WorkBook.saveas(xlsFileName);

  WorkBook.close;

  ShowMessage(‘下面演示:打开刚创建的XLS文件,并修改其中的内容,然后,由用户决定是否保存。‘);

  WorkBook:=eclApp.workBooks.Open(xlsFileName);

  eclApp.Cells(2 , 1):=‘Excel文件类型‘;

  if MessageDlg(xlsFileName+‘文件已被修改,是否保存?‘,mtConfirmation, [mbYes, mbNo], 0) = mrYes then

  WorkBook.save

  else

  workBook.Saved := True; //放弃修改

  WorkBook.Close;

  eclApp.Quit;

  //退出Excel Application

  //释放VARIANT变量

  eclApp:=Unassigned;

  except

  ShowMessage(‘不能正确操作Excel文件。可能是该文件已被其他程序打开, 或系统错误。‘);

  WorkBook.close;

  eclApp.Quit;

  //释放VARIANT变量

  eclApp:=Unassigned;

  end;

  end;

  end.

  经过上述操作过程后,我们就可以很放心地将数据库中的数据转换成Excel文件了。

赛迪网



相关报道
Delphi在网络数据库中的应用 (2001-02-26 11:14:12)
巧用Delphi制作溅射屏幕 (2000-12-28 14:05:18)
如何在Delphi中实现ASP编程 (2000-12-28 14:02:16)
 
更多本栏目内容
??Windows 2000系统安全设置攻略
??Dreamweaver编写CSS需要掌握的技巧
??使用Flash MX过程中的3个小技巧
??拖IE9网站图标到Win7任务栏 精彩好礼任你拿
??从此不再耗流量?Google离线地图试用
??给瑞星添加移动存储自动杀毒功能
??一周壁纸榜单 靓丽风景伴您欢度周末
??金山网络七款软件齐升级 炫丽界面贺新春
??提升网站流量和权重 百度热榜排第一
预警:电商促销引钓鱼 七夕网购需谨慎

本站检索



中华网推荐

·国家级治脑病新药思维源
·中藏药治疗脑病新突破
·治类风湿,强直性脊柱炎
·养肾·痛风·长寿
·肝病泌尿脑萎缩新药介绍
·强直性脊柱炎康复乐园
·让中医辩证不孕不育
·国医治股骨头坏死一绝
·乙肝为何久治不愈?
·二千元垄断批发做老板
·中医中药专治前列腺
·治牛皮癣白癜风已成现实
·专治痛风病的白衣天使
·不孕不育的杏林奇葩
·专卖店零售管理系统





   

网络教室编辑信箱