關(guān)于easyExcel中讀取Excel表頭的實(shí)例說明
前言
在使用easyExcel讀取文件時(shí),對(duì)于Excel的表頭,在解析讀取時(shí)分成不同的狀態(tài),需要加以區(qū)分.
1 環(huán)境準(zhǔn)備
準(zhǔn)備一個(gè)可以正常訪問的SpringBoot項(xiàng)目.
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對(duì)象
// 表格對(duì)應(yīng)實(shí)體類
@Data
public class EasyExcelDemo {
@ExcelProperty("標(biāo)題")
private String string;
@ExcelProperty("日期")
private Date date;
@ExcelProperty("金額")
private Double money;
/**
* 忽略這個(gè)字段
*/
@ExcelIgnore
private String name;
}
// 返回對(duì)象
@Data
public class Resp {
private List<EasyExcelDemo> importList;
}
3 準(zhǔn)備一個(gè)控制器
@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();
// 從監(jiān)聽中獲取結(jié)果集
Resp resp = EasyExcelListener.RESP.get();
List<EasyExcelDemo> importList = resp.getImportList();
log.info("導(dǎo)入集合 list = {}", importList);
// 清除數(shù)據(jù)
EasyExcelListener.RESP.remove();
}
}
4 準(zhǔn)備一個(gè)監(jiān)聽類
@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("解析到的一條數(shù)據(jù): excelRow = {}", data);
importList.add(data);
}
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
// 解析完所有excel行, 保存到數(shù)據(jù)庫或進(jìn)行業(yè)務(wù)處理
log.info("解析的所有數(shù)據(jù) list = {}", importList);
Resp resp = new Resp();
resp.setImportList(importList);
RESP.set(resp);
}
@Override
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
log.info("表頭數(shù)據(jù) excelHead= {}", headMap);
}
}
2 單表頭Excel
單表頭Excel, 即Excel的表頭只有一行.

如上單行表頭, 在讀取時(shí),在EasyExcel讀取時(shí)設(shè)置headRowNumber屬性,表示Excel的表頭的行數(shù),默認(rèn)為1,設(shè)置為1時(shí),表示第一行是表頭,從第二行是表數(shù)據(jù)
EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
new EasyExcelListener()).sheet().headRowNumber(1).doRead();
使用postman上傳excel查看結(jié)果:
讀取到Excel的表頭

讀取到Excel的表數(shù)據(jù)

3 多表頭Excel
多表頭Excel, 即Excel的表頭有多行.

如上單行表頭, 在讀取時(shí),在EasyExcel讀取時(shí)設(shè)置headRowNumber屬性,表示Excel的表頭的行數(shù),設(shè)置為2時(shí),表示第二和之前行都是表頭.
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查看結(jié)果:
讀取到Excel的表頭, 讀取到第一行

接著讀取表頭第二行

讀取到Excel的表數(shù)據(jù)

4 總結(jié)
關(guān)于EasyExcel的表格讀取,使用起來比較方便,但是對(duì)于多表頭和單表頭的讀取,需要注意,是按照一層層的解析的.即再一些特殊的場(chǎng)景,需要校驗(yàn)表格的表頭是否正確等, 要注意多表頭的讀取按照行數(shù)順序讀取數(shù)據(jù).
到此這篇關(guān)于easyExcel中讀取Excel表頭的文章就介紹到這了,更多相關(guān)easyExcel讀取Excel表頭內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法
這篇文章主要介紹了淺談MyBatis-Plus學(xué)習(xí)之Oracle的主鍵Sequence設(shè)置的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
深入理解spring boot異步調(diào)用方式@Async
Spring為任務(wù)調(diào)度與異步方法執(zhí)行提供了注解支持。通過在方法上設(shè)置@Async注解,可使得方法被異步調(diào)用。下面這篇文章主要給大家介紹了關(guān)于spring boot異步調(diào)用方式@Async的相關(guān)資料,需要的朋友可以參考下。2017-07-07
Spring?Cloud?Gateway集成Sentinel流控詳情
這篇文章主要介紹了Spring?Cloud?Gateway集成Sentinel流控詳情,Sentinel支持對(duì)Spring?Cloud?Gateway、Zuul等主流的API?Gateway進(jìn)行限流,需要的朋友可以參考一下2022-09-09
Java與Spring?boot后端項(xiàng)目Bug超全總結(jié)
Spring Boot是一個(gè)開源的 Java 開發(fā)框架,它的目的是簡(jiǎn)化Spring應(yīng)用程序的開發(fā)和部署,下面這篇文章主要給大家介紹了關(guān)于Java與Spring?boot后端項(xiàng)目Bug的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
Java異步線程中的CompletableFuture與@Async詳解
這篇文章主要介紹了Java異步線程中的CompletableFuture與@Async詳解,CompletableFuture是java中提供的一個(gè)異步執(zhí)行類,@Async是Spring提供的異步執(zhí)行方法,當(dāng)調(diào)用方法單獨(dú)開啟一個(gè)線程進(jìn)行調(diào)用,需要的朋友可以參考下2024-01-01

