一、将word模板另存为xml格式,将须要替换的地方使用标签和指令替换,具体参照Freemarker开发手册java
(1)普通字符串替换为${stringdemo}app
(2)表格替换编辑器
<#list rows as row>
......
<#list row as item>
....${item}..
</#list>
......
</#list>测试
二、将修改后的xml模板文件后缀名改成.ftl编码
三、实例程序spa
import java.io.BufferedWriter; import java.io.File; import java.io.FileOutputStream; import java.io.OutputStreamWriter; import java.io.Writer; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import freemarker.template.Configuration; import freemarker.template.DefaultObjectWrapper; import freemarker.template.Template; public class DemoFreemarker { public static void main(String[] args) { creatWord(); } @SuppressWarnings("unchecked") public static void creatWord() { try { //建立配置实例 Configuration cfg = new Configuration(); cfg.setDefaultEncoding("utf-8"); cfg.setDirectoryForTemplateLoading(new File("C://wtt")); cfg.setObjectWrapper(new DefaultObjectWrapper()); //获取模板 Template temp = cfg.getTemplate("demo.ftl"); temp.setEncoding("utf-8"); //建立数据模型 Map root = new HashMap(); root.put("stringdemo", "字符串测试"); List rows = new ArrayList(); for (int j=1; j<5; j++) { List row = new ArrayList(); for (int i=1; i<16; i++) { row.add(j+""+i); } rows.add(row); } root.put("rows", rows); //将模板和数据模型合并生成文件 File docFile = new File("C://wtt/demo.doc"); Writer docout = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(docFile))); temp.process(root, docout); } catch (Exception e) { e.printStackTrace(); } } }
注:
一、支持word版本为2003及更高版本.net
二、此种方法优势是跨平台,而且不依赖MS office wordcode
三、若是生成的文件不能打开,用文本编辑器打开生成的wordorm
(1)若是开始为 ?<?xml version="1.0" ,即开头多出个问号,由于ftl模板文件格式有问题,须要将格式设置为“UTF-8无BOM”格式,可以使用Notepad++文本编辑器设置xml
(2)若是生成的word格式为ANSI,则将ftl模板第一行声明编码改成gbk,如:<?xml version="1.0" encoding="gbk" standalone="yes"?>