1. pom依赖
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j-core</artifactId>
<version>8.3.9</version>
</dependency>
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j-export-fo</artifactId>
<version>8.3.9</version>
</dependency>
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j-JAXB-ReferenceImpl</artifactId>
<version>8.3.9</version>
</dependency>
注意:
docx4j-core 8.3.9 jdk1.8
docx4j-core 11.4.9 jdk11
低版本 docx4j
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j</artifactId>
<version>6.1.2</version>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
<exclusion>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j-JAXB-ReferenceImpl</artifactId>
<version>8.1.6</version>
</dependency>
<dependency>
<groupId>org.docx4j</groupId>
<artifactId>docx4j-ImportXHTML</artifactId>
<version>8.2.1</version>
<exclusions>
<exclusion>
<artifactId>logback-classic</artifactId>
<groupId>ch.qos.logback</groupId>
</exclusion>
</exclusions>
</dependency>
2. 工具类
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.time.DateFormatUtils;
import org.docx4j.Docx4J;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;
import org.docx4j.openpackaging.parts.WordprocessingML.MainDocumentPart;
import java.io.File;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
@Slf4j
public class WordUtil {
/**
* 加载模板并替换数据
*
* @param templateFilePath
* @param data
* @param outFilePath
* @throws Exception
*/
public static void replaceData(String templateFilePath, Map<String, String> data, String outFilePath) throws Exception {
//加载模板文件并创建WordprocessingMLPackage对象
WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.load(new File(templateFilePath));
MainDocumentPart documentPart = wordMLPackage.getMainDocumentPart();
// 8.3.9 版本 有这行会导致 标题变成正文
// VariablePrepare.prepare(wordMLPackage);
documentPart.variableReplace(data);
Docx4J.save(wordMLPackage, new File(outFilePath));
}
}
登记表.docx模板
3. 测试
String zipFilePath = "C:\\Users\\bestm\\Desktop\\登记表.docx";
String zipFilePath2 = "C:\\Users\\bestm\\Desktop\\登记表2.docx";
Map<String, String> map = new HashMap<>();
map.put("date", DateFormatUtils.format(new Date(), "yyyy-MM-dd"));
map.put("addr", "银行");
map.put("visitor", "张三");
map.put("visitorPosition", "主管");
map.put("visitee", "李四");
map.put("visiteePosition", "Java开发");
map.put("detail", "用这些语言编写的程序和上面我们讲的命令行客户端和图像化管理工具一样,都属于mysql的客户端,通过客户端是可以操作mysql服务端");
map.put("remark", "本文主要通过对mysql-connector-java源码的分析来了解client与mysql-server创建连接握手的基本过程");
replaceData(zipFilePath, map , zipFilePath2);