分享
 
 
 

如何用C++ Builder存取Excel数据

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

一.用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.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;下面我们再介绍另一种脱离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。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有