- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++读取Excel的XLS文件的方法有很多,但是也许就是因为方法太多,大家在选择的时候会很疑惑。
由于前两天要做导表工具,比较了常用的方法,总结一下写个短文,
OLE的方式
这个大约是最常用的方式,这个方式其实启动了一个EXCEL的进程在背后读写EXCEL文件,这个方式的最大好处是什么事情都能做。包括设置EXCEL的格式,增加删除Sheet,读写单元格,等等。功能几乎是最全的,而且使用起来也不是特别的难。
其基本方法都是使用导出的.h文件进行OLE操作,但是由于OLE的接口说明文档不多,想非常完美的使用她们也不是太容易,好在例子也很多。
网上普遍认为OLE速度慢,EXCEL的OLE读写方式也基本一样。但是读取速度可以改进,如果在读取的加载整个Sheet的Range的全部数据,而不是一个个单元格读取,那么速度还是相对不错。想想原理也很简单,整体读取减少了OLE的交互次数。OLE的写入方式一般只能几个进行比较方便,所以速度可能要快很多。
我自己的亲身体会是,一个EXCEL文件,100多列的字段,如果采用一个个单元格的读取方式,1s大约3条左右的记录,如果整体读取,速度可以提高几十倍。
OLE读写EXCEL方式功能很强大,读取速度还可以,但写入速度不高,当然这个方式不可能移植的,而且你必须安装了EXCEL。
2.Basic EXCEL 方式
这是CodeProject上的一个推荐开源工程了,
/KB/office/BasicExcel.aspx
作者是基于EXCEL的文件格式进行的处理。但是为什么叫Basic EXCEL呢。他不支持很多东西,公式,文件格式,表格合并等(有人说中文支持也不好),所以可以认为他只支持最基本的EXCEL表格,我自己的尝试是如果这个EXCEL文件有其他元素(公式,格式等),使用Basic EXCEL读取会失败。
OLE读写EXCEL方式功能比较弱,由于是直接根据文件格式操作,读写速度都不错,你也不需要按照EXCEL,另外这个方式是可以移植的,但是有一些成本,其代码比较晦涩难懂,而且没有注释,另外即使在Windows平台上,告警也很多。
3.Sourceforge 上的几个EXCEL库。
Sourceforge 上有几个开源的的EXCEL库,但是完善的不多,有的是为了PHP读写EXCEL准备的,包括libXLS,XLSlib,SmartEXCEL等。我下载了几个实验了一下,在Widonws都没有编译成功。也罢了。
4.ODBC的方式
这个亲身没有尝试过,但是按照原理,应该只能读写。速度吗,ODBC的速度本来就是出名的慢了。
/document/viewdoc/?id=421
附录:A1
值得一提的是Basic EXCEL的作者原来在CodeProject上有一个给予ODBC方式的封装CSpreadSheet 。如果有兴趣,大家可以去看看。其实内心还是很佩服这个作者的。
/KB/database/cspreadsheet.aspx
5.ADO的方式
ADO的方式听说应该就是使用OLEDB的方式。和OLE的方式应该没有本质区别。我看了看例子也和OLE很像
6.LibXL
LibXL 是一个收费的EXCEL的库。
/
按照他的说明,他可以不依赖EXCEL读取XLS文件。包括设置格式等。看例子操作应该很简单。但是是否可以移植到Linux平台,我估计难度也不小。呵呵。
由于要收费,没有法子测试了。
7.网上一些号称不用OLE读取EXCEL例子
初步看了一下,这个应该是网上探索EXCEL格式文档的例子。可以实际操作的方式不强。
本文来自CSDN博客,转载请标明出处:
/fullsail/archive/2009/04/12/4067416.aspx
直接通过ODBC读、写Excel表格文件????想要通过ODBC直接读、写Excel表格文件,首先,应确保ODBC中已安装有Excel表格文件的驱动MICROSOFT?EXCEL?DRIVER?(*.XLS)。然后,可根据下面步骤进行:1.????在StdAfx.h文件中加入:#include?afxdb.h?#include?odbcinst.h2.????通过ODBC直接创建Excel文件(暂定文件名:Demo.xls)//创建并写入Excel文件void?CRWExcel::WriteToExcel(){??CDatabase?database;??CString?sDriver?=?MICROSOFT?EXCEL?DRIVER?(*.XLS);?//?Excel安装驱动??CString?sExcelFile?=?c:\\demo.xls;????????????????????????//?要建立的Excel文件??CString?s
您可能关注的文档
- Excel2003的使用方法与技巧.ppt
- excel办公软件经典教程——文创公.doc
- Excel2003基础操作之输入技巧.doc
- Excel2003使用技巧.ppt
- Excel-6(Excel复习).doc
- Excel表格导入Coreldraw的方法和处理技巧-2(实用完美.doc
- Excel不能将对象移到工作表外-解决方法.doc
- Excel常用必备秘技.doc
- Excel 2000基本功.doc
- EXCEL常用技巧培训.ppt
- 2025年兰州现代职业学院单招职业倾向性测试题库审定版.docx
- 2025年兰州外语职业学院单招职业适应性考试题库及参考答案1套.docx
- 2025年兰州外语职业学院单招职业倾向性考试题库审定版.docx
- 2025年兰州外语职业学院单招职业适应性考试题库及参考答案1套.docx
- 2025年兰州外语职业学院单招职业适应性测试题库往年题考.docx
- 2025年六盘水职业技术学院单招职业倾向性测试题库及答案一套.docx
- 2025年六盘水幼儿师范高等专科学校单招职业技能考试题库精选.docx
- 2025年六盘水幼儿师范高等专科学校单招职业技能考试题库及答案1套.docx
- 2025年六盘水幼儿师范高等专科学校单招职业技能测试题库带答案.docx
- 2025年六安职业技术学院单招职业适应性测试题库a4版.docx
文档评论(0)