使用POI向Excel模板动态添加内容

一、功能的需求以及实现的效果

下载链接: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
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值