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服务程序提交操纵命令:
VariantVariant::OlePropertyGet(属性名,参数….);
// 取对象属性
VoidVariant::OlePropertySet(属性名,参数….);
// 设置对象属性
VariantVariant::OleFunction(函数名,参数….);
// 运行对象的函数
voidVariant::OleProcedure(过程名,参数….);
// 运行对象的过程
其头文件“vclutilcls.h”必须嵌在用户程序中,
对于这四个长长的方法名可在程序中用宏语句重新定义一下:
#definePGOlePropertyGet
#definePSOlePropertySet
#defineFNOleFunction
#definePROleProcedure
例如对于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()' VisualBasic程序片段
DimExAsObject,WbAs Object, Sh1 As Object
SetEx = CreateObject("Excel.Application")
Ex.WorkBooks.Open("c:ook1.xls")
SetWb = Ex.Activeworkbook
SetSh1 = Wb.ActiveSheet
Text1.Text = Sh1.Cells(1, 1).Value
Fori = 1 To 10: Forj = 1 To 10
Sh1.Cells(i, j).Value = i * 100 + j
Next j: Next i
Wb.save: Wb.Close: Ex.Quit
End Sub'- - - - - -- - - - - - - - - - -
#include "Unit1.h"// C++Builder程序片段
#include "vclutilcls.h"// util classes实用类说明
//…省写此处原一段代码
//请在此处插入上面提及的四个宏定义语句
void __fastcall TForm1::Button1Click(TObject *Sender)
{Variant Ex,Wb,Sh1;
Ex=Variant::CreateObject("Excel.Application");
Ex.PG("WorkBooks").PR("Open","c:\book1.xls");
Wb=Ex.PG("ActiveWorkBook"); Sh1=Wb.PG("ActiveSheet");
Edit1->Text=Sh1.PG("Cells",1,1).PG("Value");
for (int i=1;i<=10;i++)
for (int j=1;j<=10;j++)
Sh1.PG("Cells",i,j).PS("Value",i*100+j);
Wb.PR("Save"); Wb.PR("Close");
}
---- 使用这种方法的程序运行时,必须保证系统中同时有MS OFFICE;
分享到:
相关推荐
c++builder最基本的操作excel读写控制
用C++Builder中的OLE技术存取Excel表数据.pdf
编译环境: Windows 7 Service Pack 1 C++ Builder Embarcadero RAD Studio XE Version 15.0.3890.34076 代码参考: 余文溪的《C++ STL --数据结构与算法实现》原书代码为控制台。 这里用 C++ Builder代码演示
Borland C++Builder 5.0 (简介) Borland C++Bilder 5.0是Interprise(Borland)公司推出的基于C++ 语言的快速应用程序开发(Rapid Application Development,RAD)工具,它是最先进的开发应用程序的组件思想和...
C++Builder 导出数据到EXCEL表格 C++Builder 导出数据到EXCEL表格 C++Builder 导出数据到EXCEL表格 C++Builder 导出数据到EXCEL表格
讲述C++Builder操作Excel的对像,很实用, 有代码。
C++ Builder调用Delphi的pas文件实例
C++Builder数据库连接Excel.rar C++Builder数据库连接Excel.rar C++Builder数据库连接Excel.rar
介绍C++BUILDER中进行文件操作的几种方式
在C++builder2010中,封装了ole对象,用户可以通过一个友好的类来操作和使用ExcelVBA的各种功能,如合并单元格,设置数值,添加公式等等。
C++ Builder更改生成的EXE文件图标
C++Builder 5 安装文件1文件 共4个文件
Borland C++ Builder 6 帮助文件,内容丰富,大小 20 Mb。
C++Builder5 and C++Builder6编程实例精解编程实例精解(包含 Builder6 PDF档)
C++Builder 5 安装文件3文件 共4个文件
C++Builder 5 安装文件2文件 共4个文件
《c++ builder 6程序设计教程(第二版)》系统地介绍了在windows环境下利用c++ builder进行应用程序开发的方法,主要内容包括c++ builder常用组件的使用、mdi多文档应用程序设计、文件操作与文件管理、数据库应用程序...
C++Builder 6的文件和文件夹操作