




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
VC中操作excel表格 摘要:使用Microsoft Office所带的控件来实现代码操作excel表格。操作系统是Microsoft XP,办公套装是Microsoft Office 2003,编程环境是Microsoft Visual Studio 6.0,一切都是Microsoft。我最近要将数据库中的内容查询出来放到excel表格以便打印,所以上网找了这方面的内容,这里主要是抛砖引玉。从思路上来看,操作excel表格就是将其打开,然后写入/读出数据,然后关闭。首先创建一个程序(我的例子是一个MFC的单文档程序),在程序的入口处和出口处先作这样两个步骤来支持COM库:在程序入口处CXXXApp: InitInstance()函数AfxEnableControlContainer();语句之后加入下面几行:if (CoInitialize(NULL) != 0)AfxMessageBox(“初始化COM支持库失败!”);exit(1);假如这个条件不通过就不能运行起程序。在程序的出口处CXXXApp: ExitInstance()函数return语句之前加入下面这句话:CoUninitialize();来释放COM支持库。这样对COM支持库的代码已经完成。下面要从Office的安装目录中找到对VC操作excel文件的动态库,在某些版本下这个文件是Excel8.olb或者Excel9.olb,在我的版本中是excel.exe这个exe也是动态库的形式,是微软公司主要的文件结果之一。选择vc的View菜单里面的ClassWizad命令,会弹出一个对话框;然后点击Add Class按钮选择From a type library,会弹出一个打开对话框,从这里打开Office安装目录下Office11EXCEL.EXE文件,从里面选择几个要用到的类:_Application, Workbooks, _Wrokbook, Worksheets, _WorkSheet, Range,点击OK按钮。会在程序中生成一个excel.h和excel.cpp文件,这些文件中包含了刚才我们选择的几个类的代码。下面介绍一下这几个类:在vc操纵excel的exe动态库里面有好多个对象模型,就是刚才在创建过程中看到的那个列表,但是经常用到的有这么几个:_Application, Workbooks, _Wrokbook, Worksheets, _WorkSheet, Range,Charts和_Chart,最后面的两个是用来操作图表的,我没有用到所以这里也就不记录了。_Application:这里的Application就是Excel本身,众所周知,一个Excel可以包含多个工作簿,每个工作簿又可以包含多个工作表,而每个工作表又可以包含多个区域或者图表,所以这里他们是树型的结构关系,而application最基本的一个功能就是找到它的子项工作簿。果然,我们在引入我们程序的Application类中看到了这样的成员函数:GetWorkbooks()。既然application就是excel,那么打开程序,退出程序,显示/隐藏程序这些基本的操作都可以在这个类的成员函数中找到,果不其然。Workbooks:这个对象是一个容器对象,它里面存放着所有打开的工作簿。因此,我们可以猜测它一定有添加,查找,打开/关闭工作簿的功能。(本程序中使用excel的一个xlt模板来生成一个xls文件就是使用了这个容器对象的添加功能。)_Workbook:这是一个工作簿,也就相当于一个xls文件。Excel可以同时打开多个工作簿,所以工作簿之间必定能够互相切换,每个工作簿可以关联工作表容器并获得工作表的索引。Worksheets:也是一个容器对象,和Workbooks类似。_Worksheet:这个就是我们看到的工作表,比如Sheet1,sheet2等等。Rang:就是我们看到的能选中的方框的大小。而我们所要作的操作基本上是以区域为单位进行的。介绍完这些,就添加一个菜单,来响应操作excel的命令。然后下面附带这个函数的内容,注释还算可以吧,并且附上网上不知道谁写的但是转载极多的一个封装类。view plaincopy to clipboardprint?1. _Application_app; 2. _Workbook_workBook; 3. _Worksheet_workSheet; 4. WorksheetsworkSheets; 5. WorkbooksworkBooks; 6. Rangerange; 7. RangecopyFrom; 8. RangecopyTo; 9. 10. if(!_app.CreateDispatch(Excel.Application,NULL) 11. 12. MessageBox(创建Excel服务失败!,信息提示,MB_OK); 13. return; 14. 15. /利用模板建立新文档 16. workBooks.AttachDispatch(_app.GetWorkbooks(); 17. _workBook.AttachDispatch(workBooks.Add(_variant_t(C:DocumentsandSettings模板.xlt);/你可以自己创建一个模板,并自由设定目录 18. /得到worksheets 19. workSheets.AttachDispatch(_workBook.GetWorksheets(); 20. /得到workSheet 21. _workSheet.AttachDispatch(workSheets.GetItem(_variant_t(sheet1); 22. /得到拷贝的母板 23. copyFrom.AttachDispatch(_workSheet.GetRange(_variant_t(A3),_variant_t(Q6); 24. copyTo.AttachDispatch(_workSheet.GetRange(_variant_t(A61),_variant_t(A61); 25. /得到全部的cells 26. range.AttachDispatch(_workSheet.GetCells(); 27. 28. / 29. /上边是头 30. 31. /* 32. 中间要做的工作有这两项:设置数据和拷贝格式 33. 设置数据就是将数据库中查询出来的数据写入表格,拷贝格式就是将表格拷贝到别的地方。 34. */35. /写入数据 36. range.SetItem(_variant_t(long)3),_variant_t(long)1),_variant_t(写入数据了); 37. range.SetItem(_variant_t(long)5),_variant_t(long)1),_variant_t(重新写入数据了); 38. /拷贝一段区域到另外的一段区域 39. copyFrom.Copy(_variant_t(copyTo); 40. range.SetItem(_variant_t(long)61),_variant_t(long)1),_variant_t(123); 41. 42. /显示excel表格 43. _app.SetVisible(TRUE); 44. /保存为文件 45. _app.SetDisplayAlerts(FALSE);/隐藏弹出的对话框 46. _workSheet.SaveAs(d:Test.xls,vtMissing,vtMissing,vtMissing,vtMissing, 47. vtMissing,vtMissing,vtMissing,vtMissing,vtMissing); 48. _app.Quit(); 49. /下边是尾 50. / 51. copyFrom.ReleaseDispatch(); 52. copyTo.ReleaseDispatch(); 53. range.Rele
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025北京首都师范大学实验小学招聘2人模拟试卷及答案详解(名师系列)
- 2025吉林吉林市桦甸市产业发展有限公司招聘13人模拟试卷及答案详解(各地真题)
- 2025河南农商银行系统社会招聘考前自测高频考点模拟试题及答案详解(夺冠)
- 2025南昌市自然资源和规划局高新分局招聘用地业务岗1人模拟试卷(含答案详解)
- 2025河南省卫生健康人才中心招聘4人考前自测高频考点模拟试题及参考答案详解
- 2025江苏无锡市锡山区卫生健康系统招聘事业编制卫生人才88人考前自测高频考点模拟试题及答案详解(考点梳理)
- 2025年4月重庆市万州区李河镇人民政府公益性岗位招聘2人考前自测高频考点模拟试题及参考答案详解1套
- 2025北京大学医学部总务处房地产管理中心宿舍管理员招聘1人模拟试卷附答案详解(模拟题)
- 2025年度中国铁路上海局集团有限公司招聘普通高校毕业生310人四(高等职业院校)考前自测高频考点模拟试题及完整答案详解1套
- 2025年绍兴市本级卫生健康单位第二次招聘硕士博士研究生、高级专家120人模拟试卷附答案详解(突破训练)
- 2025年养老护理员(中级)考试试卷:专业理论与实操考核
- 家长和孩子签订协议书
- 2025年养老护理员(中级)考试试卷:急救技能与实操训练
- 智慧水务系统的构建与实施-全面剖析
- 灸疗技术操作规范脐药灸
- (二模)新疆维吾尔自治区2025年普通高考第二次适应性检测 英语试卷(含答案详解)
- 2024-2025学年江苏省苏州市高二上册10月月考数学学情检测试题
- 《慢性肾脏病相关心肌病综合管理中国专家共识(2024版)》解读
- 牛津译林版九年级英语上学期期中热点题型专练刷题03名校选词填空20篇(原卷版+解析)
- DB11T 2032-2022 工程建设项目多测合一技术规程
- 中小学教师职称评审讲课答辩英语学科全英答辩题目汇编(附汉语翻译)
评论
0/150
提交评论