關于easyExcel中讀取Excel表頭的實例說明
前言
在使用easyExcel讀取文件時,對于Excel的表頭,在解析讀取時分成不同的狀態(tài),需要加以區(qū)分.
1 環(huán)境準備
準備一個可以正常訪問的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(); // 從監(jiān)聽中獲取結果集 Resp resp = EasyExcelListener.RESP.get(); List<EasyExcelDemo> importList = resp.getImportList(); log.info("導入集合 list = {}", importList); // 清除數據 EasyExcelListener.RESP.remove(); } }
4 準備一個監(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("解析到的一條數據: excelRow = {}", data); importList.add(data); } @Override public void doAfterAllAnalysed(AnalysisContext context) { // 解析完所有excel行, 保存到數據庫或進行業(yè)務處理 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的表格讀取,使用起來比較方便,但是對于多表頭和單表頭的讀取,需要注意,是按照一層層的解析的.即再一些特殊的場景,需要校驗表格的表頭是否正確等, 要注意多表頭的讀取按照行數順序讀取數據.
到此這篇關于easyExcel中讀取Excel表頭的文章就介紹到這了,更多相關easyExcel讀取Excel表頭內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解
這篇文章主要介紹了Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解,動態(tài)代理是一種在運行時動態(tài)生成代理對象的技術,它是一種設計模式,用于在不修改原始對象的情況下,通過代理對象來間接訪問原始對象,并在訪問前后執(zhí)行額外的操作,需要的朋友可以參考下2024-01-01Spring類型轉換 ConversionSerivce Convertor解析
這篇文章主要介紹了Spring類型轉換 ConversionSerivce Convertor的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-11-11關于Spring MVC在Controller層中注入request的坑詳解
這篇文章主要給大家介紹了關于Spring MVC在Controller層中注入request的坑的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-04-04