首页 > 开发 > 综合 > 正文

分享:处理Excel方法小结

2024-07-21 02:24:01
字体:
来源:转载
供稿:网友

常常看到如何处理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
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表