分享:处理Excel方法小结

常常看到如何处理Excel文件的提问,这里小结一下,欢迎大家补充。

▲1、通过Excel的接口操作
★限制:需要安装Excel
▲1.1、采用interop方式。参考:《Creating an Excel Spreadsheet and Adding Data to It Programmatically》http://www.csharphelp.com/archives/archive241.html
▲1.2、使用反射的技术。参考:《Calling a COM Component From C# (Late Binding)》http://www.c-sharpcorner.com/1/call_com.asp

▲2、输出Excel程序可以兼容的csv格式的文件(注1)作为Excel文件。
★限制:
 A、只能用于输出,
 B、csv只支持单页(worksheet),也就是只能产生单页的Excel文件。(注2)
 C、不能控制格式(Format),象Cell的合并等都做不到。

▲3、使用office 2003支持的xml导入功能,产生Excel可以导入的xml文件。
★限制:
 A、只能用于输出,
 B、不支持低版本。

▲4、根据excel的文件格式(注3),用写二进制文件的方法产生。
▲4.1、使用第三方控件,如Aspose,网站http://www.aspose.com
  ★限制:要花钱。
▲4.2、自己写,参考http://www.cnblogs.com/unruledboy/archive/2004/07/07/22093.html,不错的中文介绍,只是没有介绍他的资料来源,以及,也只实现了单Sheet的模式。打算走这条路可以去http://www.sourceforge.net搜索opensource关于Microsoft Office的文件格式的资料。事实上4.1提到的Aspose就是用的这些资料,只不过它用混淆器包装了一把,就开始卖钱了。
  ★限制:工作量大。

孟子提醒,补充一种

▲5、使用ActiveX控件,使得用户远程操作Excel文件。参考:《如何在Web页面上直接打开、编辑、创建Office文档 》http://blog.joycode.com/kaneboy/archive/2004/11/03/37889.aspx
 限制:
 A、客户端直接在Browser上操作Server上的文件,Server端需要配置相应权限
 B、客户端需要安装office xp sp3以上或者自行注册office的activex控件"owssupp.dll"
 C、客户端直接在Browser上操作Server上的文件,Server端对文件内容及变更不知情,不能控制。

注1:即逗号分隔列,回车分隔行的文本格式
注2:常见“DataGrid输出到Excel”都是这种方法,例如孟宪会主页上的例子,他是重定向DataGrid的Render,但是那只是个示意,不能什么情况下都照抄,比如如果Grid里有CheckBox等太复杂的东西就不行了,最好还是自己写循环从DataTable直接生成。
注3:即Biff(Binary Interchange File Format)格式,参考《FILE: How to Create a BIFF5 File》http://support.microsoft.com/default.aspx?scid=kb;en-us;150447

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值