如何利用C++ Builder 4.0 Enterprise实现对Excel97 的调用

本文介绍如何使用Excel作为报表工具,并提供了具体的程序实例。通过在C++Builder中调用Excel的程序接口,可以轻松地实现复杂报表的设计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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进行巧妙的设置,就能够设计出具有专业水平的报表。
(作者:孙航东)



Trackback: http://tb.blog.youkuaiyun.com/TrackBack.aspx?PostId=3078


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值