关于easyExcel中读取Excel表头的实例说明
作者:七国的天下,我要九十九 发布时间:2023-10-11 17:48:43
标签:easyexcel,表头,excel
前言
在使用easyExcel读取文件时,对于Excel的表头,在解析读取时分成不同的状态,需要加以区分.
1 环境准备
准备一个可以正常访问的SpringBoot项目.
1 添加pom
<!-- https://mvnrepository.com/artifact/com.alibaba/easyexcel -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.0.5</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
2 添加dto对象
// 表格对应实体类
@Data
public class EasyExcelDemo {
@ExcelProperty("标题")
private String string;
@ExcelProperty("日期")
private Date date;
@ExcelProperty("金额")
private Double money;
/**
* 忽略这个字段
*/
@ExcelIgnore
private String name;
}
// 返回对象
@Data
public class Resp {
private List<EasyExcelDemo> importList;
}
3 准备一个控制器
@RestController
@RequestMapping("/easyExcel")
@Slf4j
public class EasyExcelController {
@PostMapping("/upload")
public void upload(@RequestParam("file") MultipartFile file) throws IOException {
// 读取Excel
EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
new EasyExcelListener()).sheet().headRowNumber(1).doRead();
// 从监听中获取结果集
Resp resp = EasyExcelListener.RESP.get();
List<EasyExcelDemo> importList = resp.getImportList();
log.info("导入集合 list = {}", importList);
// 清除数据
EasyExcelListener.RESP.remove();
}
}
4 准备一个监听类
@Slf4j
public class EasyExcelListener extends AnalysisEventListener<EasyExcelDemo> {
public static List<EasyExcelDemo> importList = new ArrayList<>();
public static final ThreadLocal<Resp> RESP = new ThreadLocal<>();
@Override
public void invoke(EasyExcelDemo data, AnalysisContext context) {
log.info("解析到的一条数据: excelRow = {}", data);
importList.add(data);
}
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
// 解析完所有excel行, 保存到数据库或进行业务处理
log.info("解析的所有数据 list = {}", importList);
Resp resp = new Resp();
resp.setImportList(importList);
RESP.set(resp);
}
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
log.info("表头数据 excelHead= {}", headMap);
}
}
2 单表头Excel
单表头Excel, 即Excel的表头只有一行.
如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,默认为1,设置为1时,表示第一行是表头,从第二行是表数据
EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
new EasyExcelListener()).sheet().headRowNumber(1).doRead();
使用postman上传excel查看结果:
读取到Excel的表头
读取到Excel的表数据
3 多表头Excel
多表头Excel, 即Excel的表头有多行.
如上单行表头, 在读取时,在EasyExcel读取时设置headRowNumber属性,表示Excel的表头的行数,设置为2时,表示第二和之前行都是表头.
EasyExcel.read(file.getInputStream(), EasyExcelDemo.class, new EasyExcelListener()).sheet().headRowNumber(2).doRead(); EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
new EasyExcelListener()).sheet().headRowNumber(2).doRead();
使用postman上传excel查看结果:
读取到Excel的表头, 读取到第一行
接着读取表头第二行
读取到Excel的表数据
4 总结
关于EasyExcel的表格读取,使用起来比较方便,但是对于多表头和单表头的读取,需要注意,是按照一层层的解析的.即再一些特殊的场景,需要校验表格的表头是否正确等, 要注意多表头的读取按照行数顺序读取数据.
来源:https://blog.csdn.net/ABestRookie/article/details/124136841


猜你喜欢
- 前言本文主要给大家介绍了关于Android如何实现移动小球和CircularReveal页面切换动画的相关内容,分享出来供大家参考学习,下面
- 在使用JDBC的时候,数据库据连接是非常宝贵的资源。为了复用这些资源,可以将连接保存在一个队列中。当需要的时候可以从队列中取出未使用的连接。
- 单例模式,属于创建类型的一种常用的软件设计模式。通过单例模式的方法创建的类在当前进程中只有一个实例(根据需要,也有可能一个线程中属于单例,如
- 本文实例讲述了java针对电话号码正则匹配的方法。分享给大家供大家参考。具体如下:public interface RegExpConst
- 本文实例讲述了Java递归基础与递归的宏观语意。分享给大家供大家参考,具体如下:1.什么是递归本质上,将原来的问题,转化为更小的同一问题2.
- 本文实例为大家分享了Unity通过代码修改按钮点击效果的具体代码,供大家参考,具体内容如下效果:创建一个脚本,挂载到按钮上,主要是实现鼠标移
- 一、实验目的1. 掌握各种高级UI控件的基本使用;2. 能够实现Tab切换效果。二、实验任务1. 根据原型图设计界面;2. 实现Tab切换;
- 一、系统介绍 1.系统功能登录系统查询信息新增信息修改信息删除信息2.环境配置JDK版本:1.8Mysql:8.0.133.数据库
- 实践仿照@EnableEurekaServer实现自动装配如果你使用过Eureka作为微服务的注册中心,那么对@EnableWebConfi
- 一、闭包的定义。有很多不同的人都对闭包过进行了定义,这里收集了一些。# 是引用了自由变量的函数。这个函数通常被定义在另一个外部函数中,并且引
- java.nio.file.Files.walkFileTree是JDK7新增的静态工具方法。1.Files.walkFileTree的原理
- 年前无意看到一个用Python写的小桌面程序,可以自动玩扫雷的游戏,觉得挺有意思,决定用C#也做一个。【真实情况
- 绝对路径:不可改变的路径本地绝对路径:增加盘符的路径(e:/test/test.html)网络绝对路径:增加协议,IP地址,端口号的路径(h
- 这篇文章将向大家展示Java编程利用socket多线程访问服务器文件代码示例,如果您想先了解Java多线程socket编程的基础知识,可以看
- 什么是 Nacos Config在分布式系统中,由于服务数量巨多,为了方便服务 配置文件统一管理,实时更新,所以需要分布式配置中心组件。Sp
- 日志是非常重要的,虽然他不会以需求功能提来,但也不会体现在产品方案中。但是,它在系统项目中却占有巨大的地位。为了保证服务的高可用,发现问题一
- 文中涉及到文件名称排序,固定根目录以及返回上一层在上面,方便选择等。根据文件后缀,筛选文件还没做。先看效果。1、效果图2、核心代码如下是通过
- 序本文主要研究一下java String的internString.intern()java.base/java/lang/String.j
- 本文实例讲述了C#使用xsd文件验证XML格式是否正确的实现方法。分享给大家供大家参考,具体如下://创建xmlDocumentXmlDoc
- 偶然在项目中用到播放视频时,需要横屏将视频全屏播放,所以需要监听屏幕的横竖屏切换事件。横竖屏切换监听效果: ConfigChang