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

原创 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->set_Visible(0, true);//打开Excel程序//

Application->Workbooks->Add(xlWBATWorksheet);//创建只含有一个ExcelSheet的ExcelBook//

Worksheet = Application->Workbooks->get_Item(1)->Worksheets->get_Item(1);//取得该表对象//

Worksheet->Name = WideString("database Date");//建立该表的名称//

}

  

  五、在Button2的OnClikc事件中添加如下代码:

void __fastcall TForm1::Button2Click(TObject *Sender)

{//添加数据//

int i, j;

   Table1->DatabaseName="DBDEMOS";

   Table1->TableName="Author.db";

  Table1->Open( );

  for( i=0;i<Table1->FieldCount;i++)

Worksheet->Cells->set__Default(1,i,Table1->Fileds->Fileds[i]->FiledName);//在指定的位置加入字段名//

Table1->First();

j=2;

while( !Table1->Eof( ))

{

for( i=0;i<Table1->FieldCount;i++)

Worksheet->Cells->set__Default(j,i, Table1->Fields->Fileds[i]->AsString);////在指定的位置加入数据库的内容//

Table1->Next( );

j++;

}



  }



六、在Button3的OnClikc事件中添加如下代码:

void __fastcall TForm1::Button3Click(TObject *Sender)

{//表格设置//

  Range = m_Worksheet->get_Range("C1:F20");//设置表格操作范围//

  Range->Font->size=12;//设置字体大小//

  Range->Columns->Interior->ColorIndex = 3;//设置表格表格颜色//

  Range->Borders->LineStyle = xlContinuous;//设置表格边框//

  FirstCol = m_Worksheet->Columns->get__Default(3 );//取得当前表格的第三列对象//

  FirstCol->ColumnWidth = 25;       // 设置对象宽度//

  FirstCol->Font->Bold = true;        // 设置字体属性为加粗//

  FirstCol->Font->Italic = true;       file://设置字体的种类//

  FirstCol->Font->Color = clBlue;     // 设置字体的颜色//

}

   以上程序在C++ Builder 4.0 Enterprise + Pwin98中实现。

   通过以上程序可以看出,只要我们在程序中对Excel进行巧妙的设置,就能够设计出具有专业水平的报表。
(作者:孙航东)

borland c++ builder 4.0

  • 2017年07月27日 17:41
  • 79.96MB
  • 下载

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

2000年08月08日 09:30:00 我们在进行数据库软件的开发时,一般都要进行大量的报表设计,虽然我们可以利用Crystal Report 或程序自带的报表工具进行报表设计,但是当涉及到...
  • softart
  • softart
  • 2007年10月27日 06:54
  • 148

C++builder 中的接口类

继承自VCL的类,只能单继承。要实现多个父类继承,可以实现接口。interface a :public IInterface { int n; virtual void setName(i...
  • chinayu2007
  • chinayu2007
  • 2015年05月08日 14:51
  • 599

C++Builder建立及调用DLL

C++Builder建立及调用DLL DLL简称动态链接库,是Windows中程序的重要组成部分。想象一下,一个程序需要多人共同完成开发,怎么个共同法?这时我们就要考虑把程 序分为好几个模块,团队...
  • qq_36096752
  • qq_36096752
  • 2016年11月28日 15:37
  • 1499

C++ Builder调试技术

C++ Builder调试技术 在软件开发过程中,调试是一个重要的环节,调试技能也是开发人员所必须掌握的重要技能。现在的开发工具,如C++ Builder,通常都提供了强大的调试器。一个好的调试器,加...
  • zhengyongchen
  • zhengyongchen
  • 2004年10月19日 12:15
  • 6693

怎样在C++ Builder中创建使用DLL

版权声明请尊重原创作品。转载请保持文章完整性,并以超链接形式注明原始作者“tingsking18”和主站点地址,方便其他朋友提问和指正。  动态链接库(DLL)是Windows编程常遇到的编程方法,下...
  • tingsking18
  • tingsking18
  • 2006年07月04日 11:13
  • 1415

RAD Studio, Delphi, C++Builder 10.1 Berlin第二季优惠活动

RADStudio, Delphi, C++Builder 10.1Berlin 第二季优惠活动   优惠一:自2016 年5月20日起至2016年6月20日为止,在限时优惠期间,凡新购Delphi...
  • EmbarcaderoChina
  • EmbarcaderoChina
  • 2016年05月23日 11:03
  • 1367

C++ Builder 2010 如何调用Vs2008创建出的C++的DLL

1.创建一个VS2008的C++的DLL工程 2.导出DLL结果为C方式,即如下代码示: #pragma once #include"TestClass.h" #ifdef INTERFACE...
  • wziyx513225244
  • wziyx513225244
  • 2013年01月08日 17:34
  • 1573

快速使用 C++ Builder IDE 心得

人比较懒,做事的时候总喜欢找点捷径。用 BCB 也有一段时间了,总结出来一些使用 IDE 的捷径,希望给用 BCB 的朋友们带来一点方便。这些看似很简单的的技巧,使用好了确能给你的编程工作提高不少效率...
  • shadowstar
  • shadowstar
  • 2002年05月15日 09:22
  • 1724

C++ Builder 模拟键盘操作

键盘对于每个操作电脑的人员来说是最熟悉不过的了。键盘上的按键可分为两类: 按下后会在电脑的输入窗口上出现对应字符的按键,如字母键和数字键等,我们称之为字符键;按下后虽然看不到字符但会产生控制作用的按键...
  • C_S_D_N_USER
  • C_S_D_N_USER
  • 2014年08月26日 16:24
  • 2169
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何利用C++ Builder 4.0 Enterprise实现对Excel97 的调用
举报原因:
原因补充:

(最多只允许输入30个字)