背景

我们公司是内网开发,外网jar包我的权限不够,所以easyexcel jar包无法使用,参考了easyexcel的填充思想,写了一个较简单的填充方法,如果直接用easyexcel的话,可以参考这篇文章,http://njpkhuan.cn/archives/easyexcel-tian-chong-excel

思想

核心思想就是替换,在excel里面按照一定的规则定义变量,然后后台读取excel模版,替换其中的变量,或者根据变量进行自定义的处理

实现

模版

sheet1

image-1652085572745

sheet2

image-1652085673877

解决思路

  1. 读取表格加载到内存
  2. 读取sheet1
  3. 替换num变量
  4. 替换并新增列表变量
  5. 读取sheet2
  6. 替换并新增列表变量
  7. 更新打印范围

代码

image-1652086738287image-1652086142080image-1652086118582

这里只要保证sql查出来的数据和excel对应上即可自动替换,因为是oracle所以查出来的key是大写的,我excel变量是小写的,所以我方法里面做了一个转小写的操作

image-1652086243755image-1652086379856

效果

image-1652086599918

作者:|qq_小欢_1|,原文链接: http://www.imooc.com/article/325359

文章推荐

Spring IOC 常用注解与使用

处理文本数据(上):词袋

聊聊OOP中的设计原则以及访问者模式

企业应用架构研究系列二十六:信号量SemaphoreSlim与Semapho...

Java线程池ThreadPoolExecutor极简教程

前端自动脚本中常见的几个问题,你遇到了吗?

elasticsearch-spark的用法

200 行代码实现基于 Paxos 的 KV 存储

k8s docker 中部署think php 并搭建php websocket

Python技法:用argparse模块解析命令行选项

修改docker容器端口映射

MSDN系统原版镜像全系列所有历史版本下载