当前位置:七道奇文章资讯编程技术VC/C++编程
日期:2011-03-22 13:54:00  来源:本站整理

<b>若何操纵C++ Builder实现对Excel97 的调用</b>[VC/C++编程]

赞助商链接



  本文“<b>若何操纵C++ Builder实现对Excel97 的调用</b>[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

我们在举行数据库软件的开辟时,普通都要举行大量的报表计划,固然我们可以操纵crystal report 或程序自带的报表工具举行报表计划,但是当触及到要计划多重报表或穿插报表时、我们普通城市感到自己力不从心.有时固然想操纵excel作为前台报表,但却找不到相关接口只能作罢.其实我们只要知道excel的接口构造,就可以够便利的实现对excel的调用.

原理:在excel 中程序接口普通分为3层 ,辨别为:exelapplication、excelbook、excelsheet 此中exelapplication代表excel程序,excelbook代表excel程序当前的工作本,excelsheet代表excelbook当前激活的表格,因此在启动excel程序时要按此序辨别启动,这样就可以实现对excel报表的操作.

现举例为例介绍以下:

1、在import type library中加入 excel8.olb,在\include 子目录下生成excel_tlb.h文件.

2、在bcb4.0中form1中增添button1、button2、button3、table1,并存盘为project1.

3、在unit1.h中加入头文件 #include "..\excel_tlb.h"

在private中加入

private:  

tcom_application application;   file://定义excelapplication对象//

worksheetptr  worksheet; // 定义excelsheet对象//

rangeptr   firstcol ;           file://定义列对象//

rangeptr   range             file://定义表格操作范围//

4、在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"); //成立该表的名称//
}

5、在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++;
}
   }

6、在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举行巧妙的设置,就可以够计划出具有专业水平的报表.


  以上是“<b>若何操纵C++ Builder实现对Excel97 的调用</b>[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>hosts是什么 hosts文件在什么位置 若何改正hosts</b>
  • <b>在 Windows 8 中手动安装语言包</b>
  • <b>五个常见 PHP数据库问题</b>
  • Windows中Alt键的12个高效快速的利用本领介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • <b>详解MySQL存储历程参数有三种范例(in、out、inout)</b>
  • <b>Win8系统恢复出来经典的开始菜单的办法</b>
  • <b>Win8系统花屏怎么办 Win8系统花屏的办理办法</b>
  • <b>Windows 7系统下无线网卡安装</b>
  • <b>为什么 Linux不需求碎片整理</b>
  • <b>Windows 8中删除账户的几种办法(图)</b>
  • <b>教你如安在win7下配置路由器</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .