功能描述
实现批量生成标识签,及生成多页的文档(图中二维码也属于数据一部分),如下图:
环境说明
Java
office 2016专业版
FreeMarker
步骤
第一步 制作xml
新建word,制作带有数据的模板(如果有图片随便插入一个图片占位)。然后将word文件保存为xml文件。
第二步 制作模板
修改循环的图片:找到循环的图片,然后用FreeMarker语法替换图片字符串
源文件xml是:
模板文件如下:
图片在文档里的位置修改
第三步 写Java工具类
创建:ImageUtil,java
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Base64;
import java.util.Base64.Encoder;
import org.springframework.util.StringUtils;
public class ImageUtil {
/**
* 将图片内容转换成Base64编码的字符串
* @param imageFile 图片文件的全路径名称
* @return 转换成Base64编码的图片内容字符串
*/
public static String getImageBase64String(String imageFile) {
if (StringUtils.isEmpty(imageFile)) {
return "";
}
File file = new File(imageFile);
if (!file.exists()) {
return "";
}
InputStream is = null;
byte[] data = null;
try {
is = new FileInputStream(file);
data = new byte[is.available()];
is.read(data);
is.close();
} catch (IOException e) {
e.printStackTrace();
}
Encoder encoder = Base64.getEncoder();
String result = data != null ?encoder.encodeToString(data):"";
return result;
}
/**
* 将图片流转换成Base64编码的字符串
* @param is 图片流
* @return
*/
public static String getImageBase64String(InputStream is) {
byte[] data = null;
try {
data = new byte[is.available()];
is.read(data);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Encoder encoder = Base64.getEncoder();
String result = data != null ?encoder.encodeToString(data):"";
return result;
}
public static void main(String[] args) {
BufferedImage qr_image;
try {
InputStream is = new FileInputStream(new File("F:\\test\\shh.png"));
System.out.println(getImageBase64String(is));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
创建:ExportWordByFtl.java
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.InputStream;
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.Template;
public class ExportWordByFtl {
public static void generateDocWord(Map<String, Object> dataMap ) throws Exception {
// 设置FreeMarker的版本和编码格式
Configuration configuration = new Configuration(Configuration.VERSION_2_3_27);
configuration.setDefaultEncoding("UTF-8");
// 输出文档路径及名称
File outFile = new File("G:\\test\\test1.doc");
// 设置FreeMarker生成Word文档所需要的模板的路径
configuration.setDirectoryForTemplateLoading(new File("G:/test/"));
Template t = configuration.getTemplate("demo.xml", "UTF-8");
// 创建一个Word文档的输出流
Writer out = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(outFile), "utf-8"), 10240);
//FreeMarker使用Word模板和数据生成Word文档
t.process(dataMap, out);
out.flush();
out.close();
}
public static void main(String[] args) {
Map<String, Object> dataMap =new HashMap<>();
List<Map<String, String>> list=new ArrayList<>();
for (int i = 0; i < 4; i++) {
Map<String, String> map=new HashMap<>();
map.put("rkh", "入库号"+i);
map.put("cjh", "采集号"+i);
map.put("zm", "种名"+i);
map.put("cjr", "采集人"+i);
map.put("zjrq", "采集日期"+i);
map.put("cid", "采集地"+i);
map.put("imgid", String.valueOf(20+i));
try {
InputStream is= new FileInputStream(new File("G:\\test\\img"+i+".jpg"));
map.put("imgStr", ImageUtil.getImageBase64String(is));
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
list.add(map);
}
dataMap.put("data", list);
try {
generateDocWord(dataMap);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
## 结果
![在这里插入图片描述](https://img-blog.csdnimg.cn/20191224183646700.png)
![在这里插入图片描述](https://img-blog.csdnimg.cn/20191224183748575.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzMzMzM0NDEx,size_16,color_FFFFFF,t_70)