栏目导航
热点推荐
- 三十条有用的 Java 编程规则
- Java制作水印图片源码
- Java常见异常及可能的导致原因
- Java中的修饰词使用方法总结
- J2EE系统异常的处理准则
- Java中的异常、断言、日志解析(
- Java面试技巧:Java面试题集锦(
- 面向Java开发人员的Scala指南:
- Java程序员:一刻钟精通正则表达
- 网友经验分享:学好java开发的关
- 专家解答:创建表格与数据库进行
- Java远程访问Domino数据库
阅览排行
Java中根据模板导出数据到word的解决方案
www.jz123.cn 2010-03-01 来源: 中国建站 责任编辑(袁袁) 我要投递新闻
网上找了很久,发现主要两种开源包:POI和Jacob,Jacob首先被否决掉了,因为他最后必须运行在windows平台上。Excel导入导出我就是用的POI,但是POI中的word操作实在不行,读取还可以,写入数据远不能满足项目的需要。后面尝试诸如生成PDF然后转Word,生成XML转Word,生成Html转word,生成rtf转word。这些都是可行的办法,但是网上开源包的功能有限,iText对PDF操作是很强,但是对PDF内容的解析不行。
最后这个事情拖了四天,我看文档的时候想到mht文件,于是我把Word模板导出成mht文件,然后查看其源码,其实就是html代码,我想这样可以用velocity填写数据,然后直接导出成doc格式的文档,后来这样基本满足我们项目的需要。
#foreach($bean in $beanList) <tr style=3D'mso-yfti-irow:1;mso-yfti-lastrow:yes;page-break-inside:avoid; height:22.7pt'> <td width=3D"6%" style=3D'width:6.52%;border:solid windowtext 1.0pt;borde= r-top: none;mso-border-top-alt:solid windowtext .5pt;mso-border-alt:solid window= text .5pt; padding:0cm 5.4pt 0cm 5.4pt;height:22.7pt'> <p class=3DMsoNormal align=3Dcenter style=3D'text-align:center'><span style=3D'mso-bidi-font-size:10.5pt;font-family:SimSun'>${bean.seqNo}<o:p></o:p></span= ></p> </td> <td width=3D"10%" style=3D'width:10.12%;border-top:none;border-left:none; border-bottom:solid windowtext 1.0pt;border-right:solid windowtext 1.0pt; mso-border-top-alt:solid windowtext .5pt;mso-border-left-alt:solid window= text .5pt; mso-border-alt:solid windowtext .5pt;padding:0cm 5.4pt 0cm 5.4pt;height:2= 2.7pt'> <p class=3DMsoNormal align=3Dcenter style=3D'text-align:center'><span style=3D'mso-bidi-font-size:10.5pt;font-family:SimSun'>${bean.name}<span lang=3DEN-US><o:p></o:p></span></span></p> </td> </tr> #end |
上面是用mht源码改写成vm文件的部分代码,就和生成一般的文本文件一摸一样。这儿如果直接把汉字、特殊字符什么的传给模板(当然英文不会),会出现乱码,导致根据模板导出的word文件这个都是乱码,关于乱码的详细解释可以参考:http://blog.csdn.net/myyate/archive/2008/04/08/2260234.aspx ; 也就是说导出时需要把带汉字的字符串都进行转码,这儿给出一些方法:
/** * 把给定的str转换为10进制表示的unicode,格式为:姨 * 目前只是用于mht模板的转码 * @param str * @return */ public static String encode2HtmlUnicode(String str) { if(str == null) return ""; StringBuilder sb = new StringBuilder(str.length() * 2); for (int i = 0; i < str.length(); i++) { sb.append(encode2HtmlUnicode(str.charAt(i))); } return sb.toString(); } public static String encode2HtmlUnicode(char character) { if (character > 255) { return "&#" + (character & 0xffff) + ";"; } else { return String.valueOf(character); } } public static String encode2HtmlUnicode(Character character) { if(character == null) return null; return encode2HtmlUnicode(character.charValue()); } public static void encode2HtmlUnicode(String[] value) { if(value == null || value.length < 1) return; for(int i = 0; i < value.length; i ++) { value[i] = encode2HtmlUnicode(value[i]); } } |
上面的这些方法在项目中可以通过递归来对bean进行转码,当然我在项目中只是针对String和Character两种数据类型进行转码。
上一篇:Hibernate批量更新与删除实例浅析 下一篇:Hibernate一对多关系的处理