今天小编给大家分享一下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的表数据

以上就是“easyExcel中如何读取Excel表头”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注天达云行业资讯频道。