一.背景
1.公司给一个.doc的文档.让我动态生成pdf文件.在网上试了好多方法,感觉全是坑.最终采用了用xdocreport转化成pdf.
二.实现
(一).实现步骤
1.把.doc文件字体全部改成宋体
2.把.doc文件另存为.docx文件
3.将.docx文件后缀名改为.zip
4.解压zip文件,找到word文件夹里面的document.xml文件.及_rels文件夹下的document.xml.rels文档
5.修改document.xml,以及document.xml.rels
6.代码实现转pdf
(二).修改document.xml
这是原本.doc文档目录,首选我们要遍历数据,填充目录
找到2.0草池变-缺陷报告下面的段落进行遍历,遍历方式如图所示.数据结构为.Map里面套List,List里面再套Map,如下图数据结构
/** 在ftl文件中有${textDeal}这个标签**/
Map<String,Object> dataM = new HashMap<String, Object>();
List<Map<String, Object>> mapList = new ArrayList<Map<String, Object>>();
int j = 1;
for (int i = 0; i < 10; i++) {
Map<String,Object> dataMap = new HashMap<String, Object>();
dataMap.put("id",j+"");
j++;
dataMap.put("stationName","草池变");
dataMap.put("irImgUrl","D:/10kV穿墙套管-small.jpg");
dataMap.put("viImgUrl","D:/35kV穿墙套管-small-vi.jpg");
mapList.add(dataMap);
}
dataM.put("mapList",mapList);
dataM.put("stationName", "草池变");
dataM.put("deviceVoltage", "110kv");
<w:hyperlink w:anchor 相当于一个指针 指向名称为${‘2.’+(dataMap_index+1)+’ ‘+dataMap.stationName+’-’+dataMap.deviceName+‘缺陷报告’}的段落
这里修改成如上一样(不知道这是什么)
找到该段落为3的页码数改成如下图
到这里我们目录就遍历完成下面我们遍历正文
如上图表格我们是要循环遍历的包括(2.1 草池变-3号电容器组电抗器-缺陷报告)
我们找到document.xml的所在位置进行遍历
w:id抱着不重复就行,w:name对应目录,实现点击目录就能跳转到此
document.xml图片替换
,
第一行 id,name不重复即可.重要在最后一行r:embed对应的是document.xml.rels里面的图片.
这样它就会在media目录下找到该图片
分页如下图所示
如果有数据则进行分页<#if>包着那一段
(三).代码实现(包含浏览器导出代码)