码迷,mamicode.com
首页 > 其他好文 > 详细

freeMarker生成word,excel文档

时间:2016-09-12 07:35:55      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:freemarker

    以前导出文档一直使用poi技术,这个项目使用freemarker技术,然后看了一下,发现比poi简单多了。于是发表一下。

        FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页、电子邮件配置文件源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。

        首,把你要导出的word文档另存为xml格式,然后使用记事本将它打开,将动态生成的代码用el表达式(jstl标签)替换。

示例如下:

word文档

姓名:aaa

性别:bbb

另存为xml后打开,修改如下

<w:t>姓名:${name}</w:t></w:r></w:p><w:p><w:pPr><w:jc w:val="left"/><w:rPr><w:rFonts w:ascii="微软雅黑" w:h-ansi="微软雅黑" w:fareast="微软雅黑" w:cs="微软雅黑" w:hint="fareast"/><w:sz w:val="24"/><w:sz-cs w:val="24"/><w:lang w:val="EN-US" w:fareast="ZH-CN"/></w:rPr></w:pPr><w:r><w:rPr><w:rFonts w:ascii="微软雅黑" w:h-ansi="微软雅黑" w:fareast="微软雅黑" w:cs="微软雅黑" w:hint="fareast"/><w:sz w:val="24"/><w:sz-cs w:val="24"/><w:lang w:val="EN-US" w:fareast="ZH-CN"/></w:rPr><w:t>性别:${sex}</w:t>



用${name}和${sex}代替aaa和bbb。然后在后台编写java代码。

package com.freemarkes.word;
import java.io.IOException;
import java.io.Writer;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;
public class WordHandler {
      private Configuration configuration = null;
      Log logger = LogFactory.getLog(WordHandler.class);
  
      public WordHandler() {
          configuration = new Configuration();
          configuration.setDefaultEncoding("UTF-8");
      }
     /*
      * configuration跟文件路径有关系,是相对的。
      */
     private Template getTemplate(String templatePath, String templateName) throws IOException {
         configuration.setClassForTemplateLoading(this.getClass(), templatePath);
         /***
         * public void setClassForTemplateLoading(Class clazz, String pathPrefix);
 * public void setDirectoryForTemplateLoading(File dir) throws IOException;
 * public void setServletContextForTemplateLoading(Object servletContext, String path);
  *看名字也就知道了,分别基于类路径、文件系统以及Servlet Context。
          ***/
         Template t = null;
         t = configuration.getTemplate(templateName);
         t.setEncoding("UTF-8");
         return t;
     }
 
     
     public void write(String templatePath, String templateName, Map dataMap, Writer out) throwsException {
         try {
             Template t = getTemplate(templatePath, templateName);
             t.process(dataMap, out);
         } catch (Exception e) {
             logger.error(e);
         } finally{
         out.close();
         }
     }
public static void main(String[] args) throws Exception {
  Map map=getMap();
  WordHandler handler = new WordHandler();
  Writer out = new OutputStreamWriter(new FileOutputStream("D:\\chaoslee.doc"), "UTF-8");
  handler.write("", "chaoslee.xml", map, out);
}
public static Map getMap(){
Map map = new HashMap();
map.put("name", "chaoslee");
map.put("sex", "男");
return map;
}
 }


运行main方法就可以导出word文档了。代码见附件

我的xml文档是复制的片段,所以可能不能使用,如果有使用的人,还是自己另存为一下。

这个博客不能复制图片让我很是为难啊,还是 我不会复制。复制的都是空白的。

Excel方法也差不多。

本文出自 “行走太行览燕赵” 博客,请务必保留此出处http://chaoslee.blog.51cto.com/10643967/1851642

freeMarker生成word,excel文档

标签:freemarker

原文地址:http://chaoslee.blog.51cto.com/10643967/1851642

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!