如何操作C++ Builder实现对Excel97 的挪用
当前位置:以往代写 > C/C++ 教程 >如何操作C++ Builder实现对Excel97 的挪用
2019-06-13

如何操作C++ Builder实现对Excel97 的挪用

如何操作C++ Builder实现对Excel97 的挪用

我们在举办数据库软件的开拓时,一般都要举办大量的报表设计,固然我们可以操作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举办巧妙的配置,就可以或许设计出具有专业程度的报表。

    关键字:

在线提交作业