- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
用CBuilder存取Excel文件
用C++Builder存取Excel文件
---- C++Builder是Borland公司继Delphi之后又一成功的产品,她集VB、VC++ 及 Delphi 的优点于一体而深得C语言爱好者的青睐。由于多数操作者爱用 MicroSoft公司的Excel组织数据,为此本文介绍了用C++Builder存取Excel 文件的两种方法。 ---- 一.用OLE技术操纵Excel ---- OLE(对象链接与嵌入)是微软提出的标准,是应用程序间交换数据、相互操作的一种方式,MS OFFICE 提供了很强的 OLE 服务功能,VB、Delphi 及C++Builder等语言都可以以客户方式向Excel提交命令,以存取其数据,其中VB和Delphi最为简单,在语法上就采用类VBA的语句,本报九九年第48期的《在Delphi中操作Excel》一文曾介绍了Delphi的做法。我们原以为C++Builder照搬Delphi,结果语法编译都未能通过,查不到这方面具体介绍的资料。经反复试验方知:原来C++Builder采用间接的办法,利用变体类Variant所提供的四个“方法”向OLE服务程序提交操纵命令: ???Variant??Variant::OlePropertyGet(属性名,参数….);??// 取对象属性???Void?????Variant::OlePropertySet(属性名,参数….);??// 设置对象属性?????Variant??Variant::OleFunction(函数名,参数….);????// 运行对象的函数???void?????Variant::OleProcedure(过程名,参数….);???// 运行对象的过程其头文件“vcl\utilcls.h”必须嵌在用户程序中,对于这四个长长的方法名可在程序中用宏语句重新定义一下: ???????????#define???PG???OlePropertyGet???????????#define???PS???OlePropertySet???????????#define???FN???OleFunction???????????#define???PR???OleProcedure例如对于VB的提交语句:??Ex.ActiveWorkBook.ActiveSheet.Cells(1,2).Value=3为便于理解在C++Builder对应的语句可分解为如下四句:??????????Variant t1=Ex.OlePropertyGet(ActiveWorkBook);??????????Variant t2=t1.OlePropertyGet(ActiveSheet);??????????Variant t3=t2.OlePropertyGet(Cells,1,2);?????????????????????t3.OlePropertySet(Value,3);可去掉中间变量将这四句合为一句,就是:???Ex.PG(ActiveWorkBook).PG(ActiveSheet).PG(Cells,1,2).PS(Value,3);??我们将下面的VB程序片段改成对应的C++Builder程序以供参考:Private Sub Command1_Click()????? Visual??Basic程序片段????Dim??Ex??As??Object,Wb??As Object, Sh1 As Object????Set??Ex = CreateObject(Excel.Application)????Ex.WorkBooks.Open(c:\book1.xls)????Set??Wb = Ex.Activeworkbook????Set??Sh1 = Wb.ActiveSheet????Text1.Text = Sh1.Cells(1, 1).Value????For??i = 1 To 10: For??j = 1 To 10????????Sh1.Cells(i, j).Value = i * 100 + j????Next j: Next i// 本文转自 C++Builder研究 - /article.asp?i=20d=8d0grf????Wb.save: Wb.Close: Ex.QuitEnd Sub????- - - - - -- - - - - - - - - - - #include Unit1.h????????// C++Builder程序片段#include vcl\utilcls.h??// util classes实用类说明/
您可能关注的文档
- FW043新蕾儿童教育集团(策划书).doc
- 第五章 采购管理习题.doc
- 电气化铁路建设项目物资采购管理浅谈.doc
- 上海的文化景观模式之厕所文化.doc
- 绿地新都会招商.doc
- 大洋百货市场情况分析.doc
- 山东威海市局关于加强报废车行业监管的思考.doc
- 超声波探测单面焊接头根部缺陷方法研究.pdf
- 第五册第三单元备课.doc
- 八年级上《科学》第一章 生活中的水 复习资料【精装版】.doc
- 2023年江苏省镇江市润州区中考生物二模试卷+答案解析.pdf
- 2023年江苏省徐州市邳州市运河中学中考生物二模试卷+答案解析.pdf
- 2023年江苏省苏州市吴中区中考冲刺数学模拟预测卷+答案解析.pdf
- 2023年江苏省南通市崇川区田家炳中学中考数学四模试卷+答案解析.pdf
- 2023年江西省吉安市中考物理模拟试卷(一)+答案解析.pdf
- 2023年江苏省泰州市海陵区九年级(下)中考三模数学试卷+答案解析.pdf
- 2023年江苏省苏州市高新二中中考数学二模试卷+答案解析.pdf
- 2023年江苏省南通市九年级数学中考复习模拟卷+答案解析.pdf
- 2023年江苏省南通市海安市九年级数学模拟卷+答案解析.pdf
- 2023年江苏省泰州市靖江外国语学校中考数学一调试卷+答案解析.pdf
文档评论(0)