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 XE10环境下,连接和操作Excel文件作为临时或替代数据库的应用程序是一种常见的需求。这个源码下载提供了实现这一功能的实例。通过分析压缩包中的文件,我们可以了解如何利用C++ Builder的VCL组件库和...
1. 包含头文件:在使用 C++Builder 操作 Excel 之前,需要包含 Comobj.hpp 和 Utilcls.h 头文件,这两个文件提供了自动化对象的相关函数。 2. 自动化对象:C++Builder 提供了四个 Ole Object Class 函数来包装 ...
C++ 中的文件读写操作是编程过程中常用的操作之一,C++ Builder 提供了多种方法对文件进行操作。在本节中,我们将对 C++ 中的文件读写操作进行总结。 基于 C 的文件操作 在 ANSI C 中,对文件的操作分为两种方式,...
### 使用C++Builder中的OLE技术存取Excel表数据 #### 概述 本文旨在探讨如何在C++Builder环境中运用OLE技术实现对Excel表格数据的读写操作。通过具体实例,详细介绍了实现这一功能的具体步骤和技术要点。 #### C++...
在C++Builder中,开发人员经常需要将应用程序中的数据导出到常见的电子表格格式,例如Microsoft Excel。在这个示例中,我们看到一个使用AdvStringGrid控件和VCL(Visual Component Library)组件来实现从数据库读取...
本主题聚焦于如何利用C++Builder将数据导出到Excel表格,这对于数据分析、报表生成以及数据共享等场景至关重要。 在C++Builder中实现数据导出到Excel通常涉及以下步骤: 1. **引入必要的库**:首先,你需要包含...
### C++Builder 6 的文件和文件夹操作详解 #### 内容摘要 本文主要介绍了在C++Builder 6环境中如何高效地进行文件与文件夹的相关操作,包括但不限于文件对话框的应用、文件与文件夹的基本管理、文本文件的读写、...
本实例探讨了如何在C++ Builder环境中调用Delphi编写的PAS(Pascal)文件,这涉及到接口设计、动态链接库(DLL)的使用以及跨语言的类型映射等关键知识点。 首先,Delphi是一种基于Pascal语言的开发工具,其编译后...
在Excel 2003兼容性方面,C++Builder XE通常能很好地处理xls格式的文件,因为xls是Excel早期版本广泛使用的文件格式。开发者需要确保在写入数据时,选择正确的文件格式,并正确设置工作簿的兼容模式,以确保在不同...
C++Builder是一款由Embarcadero Technologies开发的集成开发环境(IDE),主要针对C++语言,为Windows平台提供快速应用程序开发(RAD)解决方案。C++Builder5和C++Builder6是该系列的不同版本,分别发布于2001年和...
2. Excel API:C++Builder可以借助Microsoft Office的API,如Microsoft Excel Object Library,来直接操作Excel文件。这通常涉及到COM(Component Object Model)接口,通过COM接口,开发者可以在不启动Excel应用...
C++Builder作为一个强大的集成开发环境(IDE),提供了一种高效的方式与Microsoft Excel进行交互,允许开发者读取、写入甚至修改Excel文件中的数据。这里我们将深入探讨如何在C++Builder中实现这一功能。 首先,你...
C++Builder 6是一款由Borland公司(后被Embarcadero Technologies收购)开发的集成开发环境(IDE),主要用于C++编程语言的应用程序开发。它结合了强大的编译器、调试器、可视化设计工具和其他实用功能,为开发者...
三、C++Builder 6 的优势 1. 快速应用开发:通过组件拖放和事件驱动编程,使得非专业程序员也能快速开发出功能丰富的应用。 2. 高性能:编译器优化能力强,生成的代码运行速度快。 3. 扩展性:支持第三方组件和库,...
C++ Builder更改生成的EXE文件图标
通过研究这些代码,你可以更深入地了解如何在C++Builder 2010中使用OLE技术操作Excel,并且可能也能学习到如何封装和复用二进制文件操作的代码。这将极大地提升你的C++编程能力和跨应用集成技能。
### C++Builder 存取多媒体数据到 SQL Server 数据库的方法 #### 摘要 本文主要探讨使用 C++Builder 将各种图像媒体数据存取到 SQL Server 数据库的方法。通过介绍具体的实现步骤和技术细节,旨在为开发人员提供一...
C++ Builder 2007 是一款由Embarcadero Technologies公司推出的集成开发环境(IDE),专注于C++语言的编程工具。它集成了编译器、调试器、代码编辑器和项目管理工具,旨在帮助开发者高效地创建Windows应用程序。这款...