• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

[原创]C#通过引用Office Excel (2007) 组件实现对Excel文件的操作

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

对用应用软件来说,将报表转出为Excel文件,进行二次加工,或者根据Excel模版填充数据,是非常常用的。实现对Excel文件的操作,如将报表转出为Excel或根据已有的Excel模版进行填充,有很多方法,比如使用第三方组件,根据Open XML的标准,将WEB页面中的控件直接输出等等,还有一种方式就是引用Office Excel组件,直接由.NET程序调用。即在项目的“引用(References)”处直接引用Office的Excel组件,这时,系统自动会生成一个Microsoft.Office.Interop.Excel.dll的文件,此文件相当于.NET 托管代码与Office COM组件的一个接口(Interop)。

这样做有其优缺点,

优点:

1. 生成的Excel文件,完全(100%)符合Excel规范,即与用Excel编辑的文件完全一致

2. C#代码可以控制Excel内部的sheet,可以指定其立即刷新,如刷新Pivot Table

缺点:

1. 采用B/S架构时,服务器端必须与开发环境安装有同一个版本的Excel;采用C/S结构时,使用转出(生成)Excel文件的客户端必须与开发环境安装有同一个版本的Excel。

2. 使用Excel组件时,必须注意释放资源、关闭Excel进程、优化填充Excel的方法

下面,将结合本人的一些项目经验,谈谈如何在ASP.NET下,使用Office Excel (2007) 组件,将已经定义好的Excel模版填充数据,然后返回客户端。 (http://skywind.cnblogs.com

1.添加Excel组件的引用:

2.打开需要填充的Excel模版,(我的项目中的做法是在这之前,先根据模版复制一份为需要填充的Excel模版)

3.填充Excel

这里面有两个提高填充效率和俗得的小的技巧

l 对于一个Range型的区域的数据,可以通过object[,]作为一个中介,整理好后一次性的插入Excel文件中;

l 操作时,对其Value2属性进行操作,Value2忽略单元格的格式,也可提高效率

4.刷新Pivot table等内容

5.保存Excel文件

6.关闭Excel进程,释放资源

7。下载生成的Excel文件

很遗憾,Office2007不完全遵从与OpenXML规范,据说要到Office2009才支持,到时候,对Excel操作就容易了!仅供参考,如果看官有更好的操作Excel的第三方组件或者源码推荐,欢迎交流。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap