posts - 36, comments - 419, trackbacks - 0, articles - 0
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

基于模板的excel导出

Posted on 2010-08-03 21:18 BearRui(AK-47) 阅读(4367) 评论(5)  编辑  收藏 所属分类: Java

    产品中有很多模块需要导出excel功能,导出excel几乎都是把页面已经显示出来的数据列表导出为excel。但后台使用poi生成excel却要1个单元格1个单元格的去编写。每个模块都需要单独写导出excel的代码,导致代码里充斥了createRow,createCell,setCellValue的代码。但这不是要命的,要命的是当前台数据列表格式变了的时候,后台生成excel代码的修改非常麻烦,特别是当产品经理要求在excel中也要保留WEB样式的时候(背景色,字体色,宽度),就只能oh shit!

HTML直接另存为excel

最开始想的解决办法是直接把数据列表的html代码另存为xls后缀的excel文件,这样是最方便,也最容易维护的方式。   可惜因为只是改了文件的后缀,所以当用excel打开的时候就会弹出"您尝试打开的文件格式与文件扩展名指定格式不一致。"的提示。最终放弃了该方法。

基于模板引擎的excel数据导出
在一次跟朋友szyicol(http://www.cnblogs.com/szyicol/)聊天中,聊起该问题,他也碰见了类似的问题,目前也是每个模块都写单独的导出excel代码。但他说想使用xls模板+xml映射文件(类似与hibernate的映射文件)来做通用导出excel。经他提醒,我最终选择使用模板引擎生成html代码,然后把html代码通过poi生成为excel。这样开发人员以后导出excel只需要编写html模板就行。

选择html的原因

   选择通过html代码(而不是xml或者其他)生成excel的原因有下:

    1、html对于开发人员来可读性最强,可以说看到这段html代码就知道生成的excel会是什么样子。
  2、因导出的就是前台的数据列表,所以html代码几乎可以直接从前台页面中copy到模板中就可以了,维护也比较方便,不需要额外比较多的工作量。

 

HTML格式       

为了易解析和增加可读性,要求生成的html代码只有table tr td标签,而且只能有1个table,类似下面的代码:

<table>
    
<tr>
        
<td colspan="7" align="center">项目名称</td>
    
</tr>
    
<tr>
        
<td colspan="7" align="center">(导出时间:2010-08-01)</td>
    
</tr>
    
<tr align="center" bgcolor="#9AB0AD">
        
<td width="150">记账人</td>
        
<td width="100">日期</td>
        
<td width="80">金额</td>
    
</tr>
    
<tr bgcolor="#ABCDC1" color="#14645E">
        
<td color="#00000">x1</td>
        
<td>2010-08-01</td>
        
<td>100</td>
    
</tr>
  
<tr bgcolor="#ABCDC1" color="#14645E">
        
<td color="#00000">x1</td>
        
<td>2010-08-01</td>
        
<td>100</td>
    
</tr>
</table>

 

模板引擎   

要根据一些数据生成上面的html代码,当然需要使用模板引擎,当然选择什么模板引擎就看自己了,我们选择了freemarker

html代码转excel
  对于html代码的解析,因为我们要求html代码只能有1个table,可以看出我们的html代码也是符合xml格式的,所以我们就使用xml库解析html代码。
通过xml解析循环所有tr,td标签,并调用对应的createRow,createCell就能生成excel了,这里不贴出所有代码,有兴趣的自己研究下,只说说poi的几个问题。

   1、合并单元格    

当html中出现colspan的时候,就需要用到合并单元格,HSSFSheet.addMergedRegion 支持合并单元格    

  2、设置颜色    

poi设置颜色比较麻烦,不能直接设置自定义的颜色值,默认只能使用内置的一些颜色。如果要使用自定义的颜色,需要先把内置的一些颜色替换成自定义颜色。建议先选出一些不常用的poi内置颜色(我们选了15个,应该够用了),当发现有自定义颜色的时候,就循环进行替换这些不常用的颜色。    

 具体可看:http://poi.apache.org/spreadsheet/quick-guide.html#CustomColors    

  3、设置宽度    

这个在poi文档中没看到很详细的介绍,因为 HSSFSheet.setColumnWidth 方法,使用的并不是像素单位,也不知道是什么单位。经过尝试发现把像素宽度*40,导出的excel列宽刚好是像素宽度。



[作者]:BearRui(AK-47)
[博客]: http://www.blogjava.net/bearrui/
[声明]:本博所有文章版权归作者所有(除特殊说明以外),转载请注明出处.
英雄,别走啊,帮哥评论下:  

精彩推荐 好文要顶 水平一般 看不懂 还需努力

评论

# re: 基于模板的excel导出  回复  更多评论   

2010-08-04 09:27 by 迟宏泽
好文章,顶一下!

# re: 基于模板的excel导出  回复  更多评论   

2010-08-04 09:29 by BearRui(AK-47)
@迟宏泽
谢谢支持!

# re: 基于模板的excel导出  回复  更多评论   

2010-08-05 09:17 by heqs
楼主的思路讲的很清晰,不过还是很想看到代码啊。呵呵

# re: 基于模板的excel导出  回复  更多评论   

2010-08-05 09:33 by BearRui(AK-47)
@heqs
谢谢支持,不过代码还是不放出来了,因为没经过公司同意,不好意思。^_^

# re: 基于模板的excel导出  回复  更多评论   

2010-08-05 12:10 by 一杯清茶
博主还需努力啊!

只有注册用户登录后才能发表评论。


网站导航: