欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于easyExcel中讀取Excel表頭的實例說明

 更新時間:2022年06月02日 11:13:15   作者:七國的天下,我要九十九  
EasyExcel是阿里巴巴開源的一個excel處理框架,以使用簡單、節(jié)省內存著稱,下面這篇文章主要給大家介紹了關于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的表頭只有一行.

image-20220412223234618

如上單行表頭, 在讀取時,在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的表頭有多行.

image-20220412224038861

如上單行表頭, 在讀取時,在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詳解

    這篇文章主要介紹了Java的動態(tài)代理和靜態(tài)代理及反射常用API詳解,動態(tài)代理是一種在運行時動態(tài)生成代理對象的技術,它是一種設計模式,用于在不修改原始對象的情況下,通過代理對象來間接訪問原始對象,并在訪問前后執(zhí)行額外的操作,需要的朋友可以參考下
    2024-01-01
  • Spring類型轉換 ConversionSerivce Convertor解析

    Spring類型轉換 ConversionSerivce Convertor解析

    這篇文章主要介紹了Spring類型轉換 ConversionSerivce Convertor的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11
  • java排序算法之冒泡排序

    java排序算法之冒泡排序

    這篇文章主要為大家詳細介紹了java排序算法之冒泡排序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • SpringBoot項目鑒權的4種方式小結

    SpringBoot項目鑒權的4種方式小結

    本文主要介紹了SpringBoot項目鑒權的4種方式小結,包括傳統(tǒng)AOP、攔截器、參數解析器和過濾器,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • Mybatis中Collection集合標簽的使用詳解

    Mybatis中Collection集合標簽的使用詳解

    這篇文章主要介紹了Mybatis中Collection集合標簽的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • Spring集成Redis詳解代碼示例

    Spring集成Redis詳解代碼示例

    這篇文章主要介紹了Spring集成Redis詳解代碼示例,介紹了Eclipse工程結構,POM依賴,Spring配置,Redis配置信息以及Java代碼等相關內容,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • Java解析xml的四種方法匯總

    Java解析xml的四種方法匯總

    XML在不同的語言里解析方式都是一樣的,只不過實現的語法不同而已。java中基本的解析方式有四種,DOM解析、sax解析、JDOM解析和DOM4J解析,下面我們就來詳細探討下這四種方式
    2016-05-05
  • 關于Spring MVC在Controller層中注入request的坑詳解

    關于Spring MVC在Controller層中注入request的坑詳解

    這篇文章主要給大家介紹了關于Spring MVC在Controller層中注入request的坑的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。
    2018-04-04
  • 基于Java編寫第一個區(qū)塊鏈項目

    基于Java編寫第一個區(qū)塊鏈項目

    區(qū)塊鏈是分布式數據存儲、點對點傳輸、共識機制、加密算法等計算機技術的新型應用模式,下面這篇文章主要給大家介紹了基于Java實現區(qū)塊鏈的相關資料,需要的朋友可以參考下
    2021-08-08
  • 如何實現Java線程安全問題

    如何實現Java線程安全問題

    這篇文章主要介紹了如何實現Java線程安全問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12

最新評論