快速业务通道

用C++Builder存取Excel文件

作者 佚名技术 来源 程序设计 浏览 发布时间 2012-06-30

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
   Wb.save: Wb.Close: Ex.Quit
End Sub '' - - - - - -- - - - - - - - - - -
#include "Unit1.h"    // C++Builder程序片段
#include "vcl\utilcls.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.P

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号