91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

easyExcel中如何讀取Excel表頭

發布時間:2022-06-02 14:02:27 來源:億速云 閱讀:4083 作者:iii 欄目:開發技術

今天小編給大家分享一下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中如何讀取Excel表頭

如上單行表頭, 在讀取時,在EasyExcel讀取時設置headRowNumber屬性,表示Excel的表頭的行數,默認為1,設置為1時,表示第一行是表頭,從第二行是表數據

 EasyExcel.read(file.getInputStream(), EasyExcelDemo.class,
                new EasyExcelListener()).sheet().headRowNumber(1).doRead();

使用postman上傳excel查看結果:

讀取到Excel的表頭

easyExcel中如何讀取Excel表頭

讀取到Excel的表數據

easyExcel中如何讀取Excel表頭

3 多表頭Excel

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

easyExcel中如何讀取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的表頭, 讀取到第一行

easyExcel中如何讀取Excel表頭

接著讀取表頭第二行

easyExcel中如何讀取Excel表頭

讀取到Excel的表數據

easyExcel中如何讀取Excel表頭

以上就是“easyExcel中如何讀取Excel表頭”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

朝阳县| 清镇市| 射洪县| 灵寿县| 香港| 淮安市| 江源县| 左权县| 商洛市| 贵港市| 建瓯市| 久治县| 金乡县| 龙江县| 祁阳县| 左贡县| 桓仁| 绩溪县| 麻城市| 疏附县| 东乡| 原平市| 大宁县| 巍山| 台北县| 方山县| 定西市| 宜宾县| 揭东县| 陆丰市| 虎林市| 同心县| 莒南县| 阿瓦提县| 乌鲁木齐市| 凤翔县| 禄丰县| 靖江市| 遵义县| 本溪市| 鲁山县|