一、功能的需求以及实现的效果
下载链接:https://download.csdn.net/download/weixin_38500202/12275618
1、首先先交代一下需求,需根据Excel模板中特定的值,动态的添加内容。图片如下:
2、如上图,${cls.f10} 标识表示需获取对象中的字段,${cls.templateData.outSth()} 需获取对象中的方法(此处使用Java的反射原理)。
3、 改模板还支持列表型标识,如${cls.templatedata[#].type},模板如下
4、列表型标识生成的结果如下
二、源码实现
1、引入poi(可以maven也可以直接下jar包)
--引入poi的版本如下
<!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.0.1</version>
</dependency>
2、实现思路,主要分以下三步
- 循环整个Excel,试着去寻找标识。如为非列表标识,则直接置换;如为列表标识,则记录至listRecord
- 循环listRecord,并保持单元格的样式
- 动态插入数据即可
3、源码实现(主要代码如下)
package com.ssm.POITemplate;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
imp