高效率导入数据到Excel.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文档。上传文档
查看更多
高效率导入数据到Excel

关于通过COM自动化调用Excel的效率问题 如果笔者告诉你,往Excel表格中写几十万条数据不会超过10秒钟,而不是通常设想的数分钟甚至数十分钟,你是否会相信,但实际情况就是这样。在Office开发中,最为常用的对象就是Range对象,而最被误用的对象也是Range对象。下面笔者举一个简单的例子说明如何有效的使用Range对象,以导出数据到Excel。 在实践中,通过COM自动化调用Excel,不管是通过VB还是通过VSTO在.net下调用Excel,最为耗时的操作就是对Range的操作,而Excel对象、WorkBook和WorkSheet对象的创建通常会在1-3秒内完成(笔者计算机上测试最多不会超过5秒)。如果我们需要向Excel中导出大量数据,一般的做法是(使用晚绑定): ? ?1Sub?test1() ?2??????Dim?objExcel?As?Object ?3??????Dim?objBook?As?Object ?4??????Dim?objSheet?As?Object ?5??????Dim?objRng?As?Object ?6??????Dim?i?As?Long,?j?As?Long ?7?????? ?8??????Set?objExcel?=?CreateObject(Excel.Application) ?9??????Set?objBook?=?objExcel.Workbooks.Add() 10??????Set?objSheet?=?objBook.Worksheets(1) 11??????Set?objRng?=?objSheet.Range(A??1??:??J??2000) 12?????? 13??????With?objRng 14????????????For?j?=?1?To?2000?Step?1 15??????????????????For?i?=?1?To?10?Step?1 16????????????????????????.Cells(j,?i).Value?=?CStr(j) 17??????????????????Next?i 18????????????Next?j 19??????End?With 20?????? 21??????objExcel.Visible?=?True 22?????? 23??????Set?objBook?=?Nothing 24??????Set?objSheet?=?Nothing 25??????Set?objExcel?=?Nothing 26End?Sub 27 28 这段程序大概需要执行2分钟左右(注意,数据一共是2000行;笔者的机器是Dell i8500笔记本,P4 2.0,512内存)甚至更长。使用早期绑定和晚期绑定对于这样的程序,差别很小。 如果测试一下,可以发现时间主要花在Range的操作上。查一下Excel的文档,可以看到,Range对象可以和数组进行很好的互操作。在笔者正在进行的《Excel与VBA程序设计》中关于效率一节(7.7)对Range对象的使用,特别是大数据量频繁引用的情况下,需要使用数组代替,但没有展开讨论。 例如将Range赋给数组:vData = ActiveSheet.Range(A1:B10).Value vData 就是一个数组。反过来,使用: ActiveSheet.Range(D1:E10).Value = vData 就可以将数组vData的值赋给Range,如果Range的范围较小,则自动截断。 下面,我们将上面的例子使用此思路修改为以下的样子(这次数据一共为20000行,是上边的10倍): ?1Sub?Test2() ?2???? ?3????Dim?objExcel?As?Object ?4????Dim?objBook?As?Object ?5????Dim?objSheet?As?Object ?6????Dim?objRng?As?Object ?7????Dim?i?As?Long,?j?As?Long ?8 ?9????Set?objExcel?=?CreateObject(Excel.Application) 10????Set?objBook?=?objExcel.Workbooks.Add() 11????Set?objSheet?=?objBook.Worksheets(1) 12????Set?objRng?=?objSheet.Range(A??1??:??J??20000) 13???????? 14????Dim?a(1?to?20000,?1?to?10)?As?Variant 15???? 16????For?j?=?1?To

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档