---- 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::Ole(函数名,参数….);
// 运行对象的函数
void Variant::OleProcedure(过程名,参数….);
// 运行对象的过程

其头文件“vclutilcls.h”必须嵌在用户程序中,
对于这四个长长的方法名可在程序中用宏语句重新定义一下:
#define PG OlePropertyGet
#define PS OlePropertySet
#define FN Ole
#define PR OleProcedure

例如对于VB的提交语句:
Ex.ActiveWorkBook.ActiveSheet.Cells(1,2).=3
为便于理解在C++Builder对应的语句可分解为如下四句:
Variant t1=Ex.OlePropertyGet("ActiveWorkBook");
Variant t2=t1.OlePropertyGet("ActiveSheet");
Variant t3=t2.OlePropertyGet("Cells,1,2);
t3.OlePropertySet("",3);
可去掉中间变量将这四句合为一句,就是:
Ex.PG("ActiveWorkBook").PG("ActiveSheet").
PG("Cells",1,2).PS("",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).
For i = 1 To 10: For j = 1 To 10
Sh1.Cells(i, j). = i * 100 + j
Next j: Next i
Wb.save: Wb.Close: Ex.Quit
End Sub ’ - - - - - -- - - - - - - - - - -

#i nclude "Unit1.h" // C++Builder程序片段
#i nclude "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("");
for (int i=1;i<=10;i++)
for (int j=1;j<=10;j++)
Sh1.PG("Cells",i,j).PS("",i*100+j);
Wb.PR("Save"); Wb.PR("Close");
}

---- 使用这种方法的程序运行时,必须保证系统中同时有MS OFFICE;下面我们再介绍另一种脱离MS OFFICE也能存取Excel表格的方法。
---- 二.用ODBC数据库技术存取Excel

---- ODBC就是开放式数据库链接标准,不同种类的数据库只需提供各自的ODBC 驱动程序就可按相同的命令操纵,微软同样为Excel提供了ODBC驱动程序,我们可在程序中象数据库一样存取Excel表格。定义好ODBC数据源后,实际试验中并没有如想象的那样简单,在控件Table的属性TableName中总是检索不到表名,同样也没有相关的资料可供查阅。通过对Excel的分析,终于发现了问题的关键所在:ODBC的表名并不就是Excel的工作表名(如Sheet1),在Excel 表格中必须对要求操作的行列区域定义一个“名称”作为数据库的表名,该区域的首行各列必须是字段名(否则首行数据会当成字段名),可以定义多个表名。具体操作步骤如下:

---- 1.在Excel上定义“表名”:

---- 运行Excel程序,打开或新建一表格,按下鼠标左键选择一片区域(起始行先填上字段名),再将鼠标位置点到左上角的地址栏,输入一表名如ABC,或者在菜单上选:“插入(I)”-“名称(N)”-“定义(D)”,再输入表名(若已定义, 可在此处删除掉),存盘退出(假定文件名取为c:Book.xls),若嫌字段名行多余,存盘前可隐藏掉;

---- 2.定义ODBC数据源:

---- 从Windows桌面“我的电脑"进入“控制面板”,双击“32位ODBC”图标,运行“用户DSN”中的“添加(D)"后选“Excel Driver(*.xls)", 再点“完成”便弹出对话框,在“数据源名(N)"右边填一名称,如:excel01,在“版本(V)"上选“Excel97", 点中“选项”取消“只读”,在“选定工作目录”中,选定Excel文件名(本例 c:Book1.xls),再点“确定”直至退出;

---- 3.设置Database控件避免登录检查:

---- 运行C++Builder,在Form1中加上Data Access的三个控件:Database1、 DataSource1、Table1,加入Database1的目的是为了避免打开数据库时出现登录框,为此双击此控件弹出一对话框,在Alias name中选ODBC数据源名(本例为Excel01),在Name中填上一新的别名(本例取Excel02),再点“Defaults” 出现一批参数缺省值,最后取消Options中的两项“Login prompt"与"Keep inactive connect”,点OK退出;

---- 4.设置其它控件属性:

---- 将Table1的属性DatabaseName选为步骤3中的新别名Excel02,再将另一属性TableName选为步骤1的表名(本例为ABC);将控件DataSource1的属性 DataSet选为Table1;双击Form1,在FormCreate事件子程序内加上一句 Table1- >Open( );

---- 5.查看数据库内容:

---- 为了直接看到Excel数据,在Form1中再加上Data Controls的控件DBGrid1 和DBNavigator1,将两者的属性DataSource都选为DataSource1,双击Table1 的属性Active将值改为true,等待数秒就可看到DBGrid1中出现数据,最后恢复Tabel1- >Active为false;

---- 注意:程序编译前,必须将刚打开的表关闭,即:使Table1- >Active为false, 否则程序运行时报告出错,因为Excel表总是被ODBC以“独占”方式打开;

---- 我们使用的是C++ Builder 4.0专业版,电子表格为Excel 97。
---- 经老妖试验,在win2000,Excel 2000,C++ Builder 6.0中使用正常。

用OLE技术操纵Excel相关推荐

  1. powerbuilder 通过ole对象操纵excel

    powerbuilder 通过ole对象操纵excel Ole_object.Workbooks.add//新建一个Excel文件  Ole_object.Workbooks.Open("F ...

  2. 在PowerBuilder中利用OLE技术调用Excel

    实现原理     OLE(对象链接与嵌入) 是一种Window程序之间实现共享数据与功能的面向对象技术,目前流行的Windows 和 Macintosh 操作系统平台都支持 OLE 对象.借助OLE不 ...

  3. VS用OLE方式对Excel进行读写操作

    OLE技术(Object Linking and Embedding,对象连接与嵌入)OLE是一种面向对象的技术,利用这种技术可开发可重复使用的软件组件(COM). 一.Excel对象模型. Appl ...

  4. ABAP 程序完成EXCEL文件的导入导出,OLE技术的应用

    今天主要学习了使用微软的OLE技术,用ABAP程序完成excel文件的导入导出处理. (一)常用的OLE函数: CALL METHOD  ,  CALL OBJECT ,   FREE OBJECT ...

  5. OLE技术专题——第一讲:OLE概述

    引言-概述 OLE/ActiveX/COM技术是MS的核心应用技术,只有彻底洞察其理论精髓,才能以不变应万变. 我们首先从OLE谈起. 一.过去的OLE和今天的OLE 作为COM技术前身的OLE,其最 ...

  6. 全面深入学习OLE技术

    全面深入学习OLE技术 引言(问题的提出) 1.如何将同步软件的联系人/日历/任务/邮件等信息导入到微软的OutLook软件中 为了解决此问题,就需要用到微软的OLE技术. 涉及相关技术有:OLE,O ...

  7. 关于OLE技术!(OLE/ActiveX/COM)

     此文系转载,原贴地址: http://blog.csdn.net/sdzg_wq/archive/2006/11/03/1365404.aspx. 引言-概述 OLE/ActiveX/COM技术是M ...

  8. 【转】全面深入学习OLE技术

    原文地址:http://blog.csdn.net/littletigerat/archive/2009/11/03/4760869.aspx 全面深入学习OLE技术 全面深入学习OLE技术 引言(问 ...

  9. java连接Excel数据库读取,写入,操纵Excel表格

    java连接Excel数据库读取,写入,操纵Excel表格 (2009-11-15 14:21:03) 转载 标签: java excel 连接 杂谈 分类:技术文档 java连接MicroSoft ...

最新文章

  1. Apache Kafka源码分析 – Log Management
  2. excel制作录入和查询系统_excel表格制作成绩查询系统攻略:让学生隐私更安全!
  3. aws iam 架构图_使用IAM保护您的AWS基础架构
  4. 求出1到某个数的所有素数
  5. 八数码——路径寻找问题
  6. CodeSmith Professional 5与VS2010有冲突
  7. 备份类型 事务日志_SQL SERVER备份策略
  8. 利用Flash XMLSocket实现”服务器推”技术
  9. Word2Vec与文章相似度
  10. 2015人生感悟哲理
  11. 非北京户口的驾照到期换证小攻略(仅供参考)
  12. 【转载】Linux下用dd命令扇区读写SD卡
  13. 菲尔兹奖得主陶哲轩:解题的策略
  14. 拓展KubeVela模块,看addon如何助力开放生态
  15. python 通讯录 字典_Python实现命令行通讯录
  16. Component(组件)的创建
  17. python统计水仙花数个数_Python一句代码实现找出所有水仙花数的方法
  18. vue单应用在ios系统中实现微信分享功能
  19. 谈谈你对Spring Boot的理解?
  20. 自制Microbit图形化编程小车

热门文章

  1. 联筑赚:盘扣脚手架构件维护保养及退场验收规范
  2. 168_优先级以及任务饿死
  3. 武汉php前景,武汉光谷东发展前景怎么样?看完你就明白了
  4. 张宇1000题高等数学 第二章 数列极限
  5. 神经科学探索脑第二章答案
  6. Linux-2.4.0 下半部机制分析
  7. 上机管理系统java_机房上机安排管理系统,基于B/S模式下的JAVA系统
  8. 如何在html显示当前时间
  9. 使用react开发dapp应用实战-宠物认领
  10. MobaXterm 是什么