锁定老帖子 主题:web导出excel文件的几种方法
精华帖 (0) :: 良好帖 (15) :: 新手帖 (2) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-09-04
最后修改:2009-09-04
经常有人问怎么导出数据到excel文件。
web导出excel文件的几种方法
KimmKing kimmking@163.com 2009年9月4日10:19:09
总的来说,两种方法:服务器端生成和浏览器端生成。
服务器端生成就是:根据用户请求,获取相应的数据,使用poi/jxl, jacob/jawin+excel,或是用数据拼html的table或是cvs纯文本的数据格式等。然后按.xls或是.cvs格式的文件的形式返回给用户,指定Content-Type:application/vnd.ms-excel ,浏览器就会提示要下载的文件是excel文件。 poi/jxl, jacob/jawin生成的是excel的biff格式。html/csv的是文本格式,不另存为excel文件,很多excel功能是用不了的。jacob/jawin需要服务器端是windows系统,且安装了excel2000以上版本。poi/jxl和html/csv方式的话,服务器端可以跨平台。
浏览器端生成excel文件还没有特别完善的方案,这是因为js无法处理二进制。大概有以下几个方案,各有利弊。 1. activex方式:使用js/vbs调用excel对象,http://setting.iteye.com/blog/219302,有个extjs的gridpanel导出为excel的例子。 (ie+excel) 2. ie命令方式:将html或是csv输出到open的window,然后使用execCommand的saveas命令,存为csv或xls。 (ie6 only) 3. 服务器端中转方式:将html的table或是拼接的csv传到服务器端,服务器端再按照Content-Type:application/vnd.ms-excel返回,浏览器就会按excel方式处理。与服务器端拼接相比,少了一次取数操作。 (all) 4. data协议方式:对于支持data协议的浏览器,可以将html或是csv先用js base64处理,然后前缀data:application/vnd.ms-excel;base64,,即可使浏览器将其中的数据当做excel来处理,浏览器将提示下载或打开excel文件,可惜的是ie不支持。extjs的官网有一个grid的plugin,实现导出xhtml格式的伪excel文件,就是这么做的。 (except IE)
浏览器端只有第一种方案导出的是真正的biff格式的excel文件,其他方式都是文本格式。activex方式只能在windows平台的ie浏览器使用,而且需要降低ie的安全性,所以应用比较有限。复杂的excel文件,还是在服务器端用poi/jxl生成excel比较好。如果浏览器固定位ie6,浏览器端方式2是最好的方案。如果要降低服务器端cpu的计算压力,客户端方案3可行,而且跨平台(比poi/jxl方式少了取数和生成二进制文件)。如果是非ie浏览器,方案4也不失为一种好方法。
ps: 还有一个方案,就是让安装了ie和excel的用户在网页上右键,点击“导出到 Microsoft Excel”,然后可以选择要导出的table区域,点“导入”按钮,完成导入。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-09-04
不错,就是格式难看了点.
|
|
返回顶楼 | |
发表时间:2009-09-04
比较完善的总结,每种方法给个小例子就更好咯
|
|
返回顶楼 | |
发表时间:2009-09-04
我都第三种:
1.import jxl.Workbook; 2.直接jsp的header定义为Content-Type:application/vnd.ms-excel, 然后页面就是<table></table> (这种没1的好看) |
|
返回顶楼 | |
发表时间:2009-09-04
楼上的方式比较实用,复杂格式和数比较多的报表的话后台拿jxl定时生成比较好些
|
|
返回顶楼 | |
发表时间:2009-09-04
lz总结的很好,要是有例子的话就更好了啊 支持支持
|
|
返回顶楼 | |
发表时间:2009-09-05
十分感谢kimmking的分享 ,问个问题:用POI处理后,导出的Excel单元格格式能否设置成文本类型的?代码中我设置格式为HSSFCell.CELL_TYPE_STRING,导出后单元格格式为常规类型的,这样我一输入2009-09-05常规类型就会自动转换成日期类型!
|
|
返回顶楼 | |
发表时间:2009-09-07
貌似jasper report也支持excel导出,不过实际效果不好
|
|
返回顶楼 | |
发表时间:2009-09-07
viMory 写道 十分感谢kimmking的分享 ,问个问题:用POI处理后,导出的Excel单元格格式能否设置成文本类型的?代码中我设置格式为HSSFCell.CELL_TYPE_STRING,导出后单元格格式为常规类型的,这样我一输入2009-09-05常规类型就会自动转换成日期类型!
excel是输入后判断的,你说的这个跟poi没关系。 试试将一个单元格格式设置为文本,键入2009-09-05,还是会成为日期2009-9-5 解决办法是输入'2009-09-05,前缀一个单引号,就会保留格式 |
|
返回顶楼 | |
发表时间:2009-09-07
最后修改:2009-09-07
力挺jasper 除网页差点 pdf excel都不错。
对于列数太多的报表,大家是这么处理的? 我是一行数据中再分行来做,但不美观也不直观 field1 field2 name field3 field4 field5 field6 ———————————— male 22 joe cn 175 66 cole ————————————— male 27 terry cn 180 78 John |
|
返回顶楼 | |