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 "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:ook1.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?/td>
gmail.com