如何利用C++ Builder 4.0 Enterprise实现对Excel97 的调用
来源:互联网 发布:淘宝店铺的主图尺寸 编辑:程序博客网 时间:2024/05/22 09:40
2000年08月08日 09:30:00
我们在进行数据库软件的开发时,一般都要进行大量的报表设计,虽然我们可以利用Crystal Report 或程序自带的报表工具进行报表设计,但是当涉及到要设计多重报表或交叉报表时、我们一般都会感到自己力不从心。有时虽然想利用Excel作为前台报表,但却找不到相关接口只能作罢。其实我们只要知道Excel的接口结构,就能够方便的实现对Excel的调用。
原理:在Excel 中程序接口一般分为3层 ,分别为:ExelApplication、Excelbook、Excelsheet 其中ExelApplication代表Excel程序,Excelbook代表Excel程序当前的工作本,Excelsheet代表Excelbook当前激活的表格,因此在启动Excel程序时要按此序分别启动,这样就能实现对Excel报表的操作。
现举例为例介绍如下:
一、在Import Type Library中加入 Excel8.olb,在/include 子目录下生成Excel_TLB.h文件.
二、在BCB4.0中Form1中添加Button1、Button2、Button3、Table1,并存盘为Project1。
三、在Unit1.h中加入头文件 #include "../Excel_tlb.h"
在Private中加入
Private:
TCOM_Application Application; file://定义ExcelApplication对象//
WorksheetPtr Worksheet; // 定义ExcelSheet对象//
RangePtr FirstCol ; file://定义列对象//
RangePtr Range file://定义表格操作范围//
四、在Button1的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button1Click(TObject *Sender)
{//启动Excel//
const int xlWBatChart = -4109;
const int xlWBatWorksheet = -4167;
if (! Application)
Application = CoApplication_::Create(); file://建立于Excel程序的连接//
Application-
Application-
Worksheet = Application-
Worksheet-
}
五、在Button2的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button2Click(TObject *Sender)
{//添加数据//
int i, j;
Table1-
Table1-
Table1-
for( i=0;i>Table1-
Worksheet-
Table1-
j=2;
while( !Table1-
{
for( i=0;i>Table1-
Worksheet-
Table1-
j++;
}
}
六、在Button3的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button3Click(TObject *Sender)
{//表格设置//
Range = m_Worksheet-
Range-
Range-
Range-
FirstCol = m_Worksheet-
FirstCol-
FirstCol-
FirstCol-
FirstCol-
}
以上程序在C++ Builder 4.0 Enterprise + Pwin98中实现。
通过以上程序可以看出,只要我们在程序中对Excel进行巧妙的设置,就能够设计出具有专业水平的报表。
(作者:孙航东)
原理:在Excel 中程序接口一般分为3层 ,分别为:ExelApplication、Excelbook、Excelsheet 其中ExelApplication代表Excel程序,Excelbook代表Excel程序当前的工作本,Excelsheet代表Excelbook当前激活的表格,因此在启动Excel程序时要按此序分别启动,这样就能实现对Excel报表的操作。
现举例为例介绍如下:
一、在Import Type Library中加入 Excel8.olb,在/include 子目录下生成Excel_TLB.h文件.
二、在BCB4.0中Form1中添加Button1、Button2、Button3、Table1,并存盘为Project1。
三、在Unit1.h中加入头文件 #include "../Excel_tlb.h"
在Private中加入
Private:
TCOM_Application Application; file://定义ExcelApplication对象//
WorksheetPtr Worksheet; // 定义ExcelSheet对象//
RangePtr FirstCol ; file://定义列对象//
RangePtr Range file://定义表格操作范围//
四、在Button1的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button1Click(TObject *Sender)
{//启动Excel//
const int xlWBatChart = -4109;
const int xlWBatWorksheet = -4167;
if (! Application)
Application = CoApplication_::Create(); file://建立于Excel程序的连接//
Application-
Application-
Worksheet = Application-
Worksheet-
}
五、在Button2的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button2Click(TObject *Sender)
{//添加数据//
int i, j;
Table1-
Table1-
Table1-
for( i=0;i>Table1-
Worksheet-
Table1-
j=2;
while( !Table1-
{
for( i=0;i>Table1-
Worksheet-
Table1-
j++;
}
}
六、在Button3的OnClikc事件中添加如下代码:
void __fastcall TForm1::Button3Click(TObject *Sender)
{//表格设置//
Range = m_Worksheet-
Range-
Range-
Range-
FirstCol = m_Worksheet-
FirstCol-
FirstCol-
FirstCol-
FirstCol-
}
以上程序在C++ Builder 4.0 Enterprise + Pwin98中实现。
通过以上程序可以看出,只要我们在程序中对Excel进行巧妙的设置,就能够设计出具有专业水平的报表。
(作者:孙航东)
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=3078
- 如何利用C++ Builder 4.0 Enterprise实现对Excel97 的调用
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 如何利用C++ Builder 5.0 Enterprise 创建用户自己的网上聊天程序
- 利用C++Builder实现Google的Web服务
- 利用C++Builder 中OLE自动化功能实现调用Word进行报表制作
- 利用C++Builder 6 中OLE自动化功能实现调用Word进行报表制作
- 利用C++Builder 中OLE自动化功能实现调用Word进行报表制作
- 利用C++Builder 中OLE自动化功能实现调用Word进行报表制作
- C++Builder、C#、VC调用 C++Builder制作的DLL
- 附录1 利用V C的MCIWnd控件实现对AVI格式多媒体文件的实时调用
- 利用VB实现对IE的调用与控制
- 特效天地——位图卷轴
- 特效天地——淡入淡出(真彩模式)
- 特效天地——线条渐变
- Oracle数据库碎片整理
- 给你的FileSystemObject对象加把锁
- 如何利用C++ Builder 4.0 Enterprise实现对Excel97 的调用
- 如何解决visual interdev的调试问题
- vbscript错误代码及对应解释大全
- jscript错误代码及相应解释大全
- 直接访问WebBrowser控件中的HTML源码
- 用Delphi实现远程屏幕抓取
- 利用Hook技术实现键盘监控
- VB中Winsock控制的UDP协议的使用
- 在FLASH中调用ASP