基于VBAExcel报表设计与实现.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于VBAExcel报表设计与实现

基于VBAExcel报表设计与实现   摘要:在MFC实际应用过程当中,所要处理的数据量较大时,当从数据库读取数据,使用本身自带的控件来显示打印大批记录时,就会出现响应慢,有时会出现无法响应的情况,应用程序显示处于忙碌状态,并且会消耗大量的系统内存资源,为了解决上述问题,本文采用了在VC环境中调用VBA对象,将数据库中的数据动态生成Excel数据报表的方法来打印记录,并具体给出详细设计过程,并验证其方法的可行性。   关键词:VC++ Excel VBA 数据报表   1 概述   Excel VBA程序开发中主要利用VBA的对象中成员函数来对大批数据进行数据处理,其特点是速度快、通用性好、执行效率高。Excel对象模型主要由Application、Workbook、Worksheet 、Range 、Style和Chart对象等以及Workbooks集合、Worksheets集合、Sheets集合和Styles集合其他很多对象。其中Application对象代表Excel应用程序,Workbook对象代表一个工作簿,Worksheet对象代表一张工作表,Style对象代表某一区域的样式, Chart 对象代表工作簿中的图表,Range 对象代表某一单元格、行列或选定区域。Workbooks集合代表是当前程序中所打开的全部的Workbook工作簿对象的集合,Worksheets集合代表是工作簿当中所有Worksheet工作表对象的集合。VBA对象调用的格式:对象名.属性名或对象名.方法名。   2 实验平台搭建   本文采用ADO是基于OLE DB数据库访问技术接口,后台数据库采用Access来实现,首先,在VC++中引用入Msado15.dll,初始化Com接口,并创建智能指针,_ConnectionPtr接口open方法联接数据源,打开数据库。_RecordsetPtr接口open方法来打开数据表,并向指定的数据库发送sql查询语句,返回记录休。然后,启动创建Excel文件,并生成相应报表记录。   2.1 初始化ADO环境:创建一个MFC的一个工程,导入ADO动态链接库在stdafx.h文件   :CoInitialize(NULL); //初始化COM对象   2.2 声明三个接口,初始化智能指针对象,连接对象(Connection)、命令对象(Command)和记录集对象(RecordSet), 创建Connection对象,并设置数据源,访问数据库。   2.3 通过m_pRecordset 记录集对象指针中的成员函数来读取源数据表中数据   try   {   m_pRecordset.CreateInstance(__uuidof(Recordset)); //创建记录集对象实例   m_pRecordset-Open(_bstr_t(sql),m_pConnection.GetInterfacePtr(),adOpenKeyset,adLockOptimistic,adCmdText);   }   catch (_com_error e)//捕捉错误   { AfxMessageBox(e.Description()); //弹出错误   return ; }   2.4 初始化VBA环境   ①在MFCK中:按Ctrl+W,单击Add Class…,选择From a type library…,弹出Import from Type Library对话框,找到Office安装目录,找到MSEXCEL.OLB打开,并选中_Application,Workbooks,_Workbook、_Worksheet和Worksheets等,并单击确定。   ②创建Excel文档   首先,创建三个变量,初始化所有相关对象并设置纸张横向打印,设置单元格的边框、字体、宽度及所创建工作表中列数、标题名称和列宽。   COleVariant vTrue((short)TRUE); //真   COleVariant vFalse((short)FALSE); //假   COleVariant vOpt((long)DISP_E_PARAMNOTFOUND, VT_ERROR);   _Application MyExcel; //创建一个新的Excel文档   Workbooks MyWorkBooks; //创建工作簿集合   _Workbook MyWorkBook; //创建工作簿   Worksheets MyWorkSheets; //创建工作表集合   _Worksheet MyWorkSheet; //创建工作表   Range MyRange;/

文档评论(0)

189****7685 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档