当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 分享:处理Excel方法小结

ASP.NET
从ASP.NET的PHP执行速度比较谈起
基于ASP.NET2.0的非HttpModule山寨版MVC框架的实现
ASP.NET 中公有的六种验证控件
无废话C#设计模式之八:Facade
C# 中的 @ 符号的使用及注意事项
保护你的.Net代码:谁动了我的组件?
VS2008与.NET 3.5的JS智能感知和调试
关于 .Net 开发下的分布式缓存设计
在C#3.0中使用扩展方法来扩展接口
C#实现Windows 服务的制作安装和删除
C#3.0中实现隐式类型变量、匿名类型的方法
C#代码与javaScript函数的相互调用
构建 ASP.NET AJAX 开发环境
Windows 窗体的.Net 框架绘图技术
.NET 开发中的一些小技巧集锦
ASP.NET 2.0 创建母版页引来的麻烦
.NET Compact Framework 概述
.NET Compact Framework 2.0 SP1新增功能
专家访谈:从Web 2.0到Web 3.0
.Net里漂浮窗口拖动的实现方法

ASP.NET 中的 分享:处理Excel方法小结


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 149 ::
收藏到网摘: n/a


常常看到如何处理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就是用的这些资料,只不过它用混淆器包装了一把,就开始卖钱了。  ★限制:工作量大。

注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