当前位置: 主页 > JAVA语言

java导出word文档实例-Java中使用freemarker导出word文档(自己真实项目案例)

发布时间:2023-07-02 10:16   浏览次数:次   作者:佚名

Java中使用freemarker导出word文档(自己真实项目案例)

最近做了一个项目,有一个需求是要将职员的一些数据按照指定的样式导出成一个word文档出来,由于自己是一个Java小白,不懂,于是便在网上找方法,网上介绍的有很多,因为原来用poi导出过ppt,于是便想用poi来做,但是由于时间不够,最终选择了用freemarker来做,在做的过程中遇到了一些问题,但最终还是完成了。于是把自己完成这个功能所做的一切从头到尾的记录一编,希望能对其他人有帮助。

1.项目需要导出图片和表格

可以看出在这个样式中,需要导出图片和循环表格。

2.开始制作模板

在制作模板时,用office word 2003或以上的版本来制作,不要用wps做。在画模板遇到一些问题,我的解决如下:

1.关于图片,我画了一个文本框来放图片,然后随便放了一个图片进去(一定要插入一张图片,方便后面找到图片的位置好 进行替换)。

2.一些需要动态生成的数据写如个人信息用personInfo来代替,注意,单词要先用一个文本框写好,再复制黏贴过来java导出word文档实例,不要再word上手动敲,不然再转成xml时单词会被拆散。也不要直接黏贴过来一个${personInfo},我发现还是会被拆散,最好直接黏贴一个单词过来,在xml中再找到这个单词再添加${}。

3.表格只需要画一行,循环在xml中配置。

java导出word文档实例_excel表格中嵌入文档_word文档表格中挑√

模板画好之后,直接将word另存为xml格式,保存完后将word关掉。

java导出word文档实例_excel表格中嵌入文档_word文档表格中挑√

用notepad++打开你保存的xml格式的文档找到你写的单词如stdName

java导出word文档实例_excel表格中嵌入文档_word文档表格中挑√

在单词前后加上${},所有你写的单词都加上。

java导出word文档实例_word文档表格中挑√_excel表格中嵌入文档

搜索w:tr找到表格

java导出word文档实例_excel表格中嵌入文档_word文档表格中挑√

在表格标签的首尾分别加上 和 标签,并且标签里的单词要改成${exp.time}这种形式。解释一下:list标签可以使标签内的表格自动循环生成相应的行数,expList是自己命名的,是表格的数据来源,是一个list集合。exp是别名。

word文档表格中挑√_excel表格中嵌入文档_java导出word文档实例

搜索

,你会发现这个标签里的内容特别多,这就是你画模板时插入的图片的BASE64字符串。

excel表格中嵌入文档_java导出word文档实例_word文档表格中挑√

标签里的内容删完,替换为${images},这样就可以在代码中设置,然后导出自己获取的图片了,当然名字自己取,叫img也可以,只要在代码中和这对应就好了。

excel表格中嵌入文档_word文档表格中挑√_java导出word文档实例

3.完成模板

将上面修改好的xml文档保存好,点击重命名将其类型修改为ftl。我的是将template.xml改为template.ftl。

好了,至此,模板就制作好了,在后面代码中你要用的模板就是template.ftl。我是直接将template.ftl文档复制到我的项目中,当然,你放本地也可以,只是引用时方法和路径不一样而已。

excel表格中嵌入文档_java导出word文档实例_word文档表格中挑√

4.Java代码

创建项目之类的就不说了,然后给你的项目到导freemarker的包。freemarker.jar包下载:

下面便是核心代码了:

private void exportWord(String ssdw, String image64Str, String stdName, String personInfo, List familyInfos,

Map maps) {

Map dataMap = new HashMap();

//ssdw 是我前面获取的职员信息

dataMap.put("orgName", ssdw);

//image64Str 是职员的照片转换后的BASE64字符串

dataMap.put("images", image64Str);

//stdName 是我前面获取的职员信息

dataMap.put("stdName", stdName);

//personInfo 是我前面获取的职员信息

dataMap.put("personInfo", personInfo);

//familyList 是职员的家庭信息的集合,对应模板中的表格

List> familyList = new ArrayList>();

for (int i = 0; i < familyInfos.size(); i++) {

Map map = new HashMap();

map.put("gx", familyInfos.get(i).getYbrgx());

map.put("xm", familyInfos.get(i).getCyxm());

map.put("dwjzw", familyInfos.get(i).getDwjzw());

familyList.add(map);

}

dataMap.put("familyList", familyList);

//expList 是职员的工作经历信息的集合,对应模板中的表格

List> expList = new ArrayList>();

Iterator> it = maps.entrySet().iterator();

while (it.hasNext()) {

Map map = new HashMap();

Map.Entry entity = (Entry) it.next();

map.put("time", entity.getKey());

map.put("experience", entity.getValue());

expList.add(map);

}

dataMap.put("expList", expList);

@SuppressWarnings("deprecation")

Configuration configuration = new Configuration();

configuration.setDefaultEncoding("utf-8");

//有两种方式获取你的模板,模板在项目中时用第一个,模板在本地时用第二个。

//注意:两种方式的路径都只需要写到模板的上一级目录

configuration.setClassForTemplateLoading(this.getClass(), "/tem");

// configuration.setDirectoryForTemplateLoading(new File("C:/"));

File outFile = new File("D:/outFilessa"+Math.random()*10000+".doc");//输出路径

Template t=null;

Writer out = null;

try {

t = configuration.getTemplate("template.ftl", "utf-8"); //文件名java导出word文档实例,获取模板

out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8"));

t.process(dataMap, out);

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

out.close();

} catch (IOException e1) {

e.printStackTrace();

}

}

}

将获取的图片转换为BASE64字符串

word文档表格中挑√_excel表格中嵌入文档_java导出word文档实例

要使用BASE64Encoder还得有如下操作:

点击你的项目名右键,选择Properties,进去后选择Java Build Path,然后如图:

excel表格中嵌入文档_java导出word文档实例_word文档表格中挑√

java导出word文档实例_word文档表格中挑√_excel表格中嵌入文档

word文档表格中挑√_java导出word文档实例_excel表格中嵌入文档

操作完成,应用并OK。

Over 使用freemarker导出word完成