C Builder操作Excel表实现技巧讲解
创始人
2024-06-23 02:01:12
0

C++编程语言应用范围广泛,可以帮助我们轻松的实现各种功能需求。比如今天为大家接受的对Excel表的操作。那么接下来我们就一起来看看C++ Builder操作Excel表的相关实现方法。希望能够为大家带来一些帮助。#t#

Microsoft Excel作为一个功能强大的电子表格处理软件,已经得到了广泛的应用。在数据库应用软件开发过程中,如果能实现数据库与Excel文件的数据交换,那么一方面能增加数据库数据的来源,另一方面也能方便用户对数据库数据的进一步处理。

C++ Builder是一个可视化快速应用程序开发工具,它提供的OLE Automation机制使得开发人员在应用程序中就能调用Excel,实现数据交换。

在C++ Builder中调用Excel,首先要为Excel建立一个OLE对象,然后通过设定该对象的属性和调用该对象的方法来操纵Excel。C++ Builder通过CreateOleObject()来建立OLE对象;用OlePropertySet(propname,value)来设置OLE对象的属性;用OlePropertyGet(propname)获得OLE对象的属性;通过OleFunction(oleFuncName,[val,...])和OleProcedure(oleProcName,[val,...])来调用OLE对象的方法。

C++ Builder中使用OLE自动化操纵Excel,必须掌握Excel的自动化对象及VBA关于Excel的对象方法和属性,这些都在Microsoft Office(完全安装)的VBAXL8.HLP帮助文件中可以找到,在此就不再赘述。下面以将数据库中的数据转到Excel工作薄中为例,说明C++ Builder操作Excel表的具体方法。

首先新建一个表单Form1,保存单元文件Unit1.cpp,保存工程文件Project1.bpr。然后在表单中加入数据访问控件TTable,将Name属性设为Table1,DatabaseName属性设为BCDEMOS,TableName属性设为Country.db。在表单中加入一个按钮控件TButton,将其Name属性设为Button1,Caption属性设为 “转换为Excel文件”。双击Button1,在Button1Click()函数中加入如下代码:

  1. Variant ex,newxls;   
  2. int i,j=1;   
  3. try   
  4. {   
  5. ex=CreateOleObject(″Excel.Application″); //启动Excel   
  6. }   
  7. catch(...)   
  8. {   
  9. ShowMessage(″无法启动Excel″);   
  10. }   
  11. ex.OlePropertySet(″Visible″,(Variant)true); //使Excel启动后可见   
  12. newxls=(ex.OleFunction(″Workbooks″)).OleFunction(″Add″);
    //新建一个工作薄   
  13. Table1-〉Active=true;   
  14. //打开数据库   
  15. Table1-〉First();   
  16. for(i=0;i〈Table1-〉FieldCount;i++)   
  17. //将字段名写到工作薄的***行   
  18. {   
  19. (ex.OleFunction(″Cells″)).OlePropertySet(″Item″,(Variant)1,
    (Variant)(i+1),(Variant)Table1-〉Fields[i]-〉FieldName);   
  20. }   
  21. while(!Table1-〉Eof)   
  22. //将数据库中的记录依次写到工作薄中   
  23. {   
  24. jj=j+1;   
  25. for(i=0;i〈Table1-〉FieldCount;i++)   
  26. {   
  27. (ex.OleFunction(″Cells″)).OlePropertySet
    (″Item″,(Variant)j,(Variant)(i+1),   
  28. (Variant)Table1-〉Fields[i]-〉AsString);   
  29. }   
  30. Table1-〉Next();   
  31. }   
  32. newxls.OleFunction(″SaveAs″,(Variant)filename);   
  33. //保存工作薄,filename是工作薄的全文件名   
  34. ex.OleFunction(″Quit″);   
  35. //退出Excel,释放OLE对象  

 

注意,要使用OLE自动化对象,在编译之前还必须在Unit1.cpp文件前面加上#include ″ComObj.hpp″。

运行程序就可以实现将数据库中的数据转换到Excel工作薄中。同样的道理,使用OlePropertyGet()函数,也可以将Excel工作薄中的数据读到数据库中去。

以上C++ Builder操作Excel表代码在Windows 98操作系统、C++ Builder 3.0下调试运行通过。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...