需求:
需要大批量的给接口生成审批word文件,每个文件中时间与标题各自独立
这里只针对word生成,Excel后面工作用到的再更新
poi-tl(poi template language)是Word模板引擎,使用Word模板和数据创建很棒的Word文档。官网
Maven
<dependency>
<groupId>com.deepoove</groupId>
<artifactId>poi-tl</artifactId>
<version>1.10.0</version>
</dependency>
这里的需求只需要基于一个模板即可生成所有的文件,所以只需要在模板中先准备好所有固定的东西,再补充上标签即可进行填充。
生成代码:
package xyz.diuut;
import com.deepoove.poi.XWPFTemplate;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.file.Files;
import java.util.*;
/**
* @Author Diuut
* @Date 2021/10/21 16:18
*/
public class poi_tl {
public static void main(String[] args) throws Exception {
List<String> apiList = getList("C:\\Users\\xxxx\\Desktop\\xxxx.txt");
for (int i = 0; i < apiList.size(); i++) {
Map<String, Object> data = new HashMap<>();
data.put("apiName", apiList.get(i));
data.put("time", "2021年6月28日");
XWPFTemplate template = XWPFTemplate.compile("C:\\Users\\xxxx\\Desktop\\template.docx")
.render(data);
FileOutputStream out;
out = new FileOutputStream("C:\\Users\\xxxx\\Desktop\\xxxx"+i+".docx");
template.write(out);
System.out.println("已生成:"+apiList.get(i));
out.flush();
out.close();
template.close();
}
}
/**
* 根据路径文件生成列表
*
* @param path 地址
* @return
*/
public static List<String> getList(String path) {
File listFile = new File(path);
List<String> urlList = new ArrayList<String>();
if (listFile.exists()) {
try {
urlList = Files.readAllLines(listFile.toPath());
} catch (IOException ex) {
ex.printStackTrace();
}
if (urlList.isEmpty()) {
System.out.println("路径文件生成为空");
return null;
}
}
return urlList;
}
}
文件名可自定义生成,此处准备好的列表文件是txt格式,每一行各自独立,可以用uedit工具进行格式化生成获取,方便后续处理。