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

Java中Excel高效解析工具EasyExcel的實(shí)踐

 更新時(shí)間:2022年04月25日 11:27:34   作者:心城以北  
EasyExcel是阿里巴巴開(kāi)源的一個(gè)excel處理框架,已使用簡(jiǎn)單,節(jié)省內(nèi)存著稱,下面這篇文章主要給大家介紹了關(guān)于Java中Excel高效解析工具EasyExcel實(shí)踐的相關(guān)資料,需要的朋友可以參考下

參考資料:alibaba-easyexcel.github.io

簡(jiǎn)介

EasyExcel是一個(gè)基于Java的簡(jiǎn)單、省內(nèi)存的讀寫(xiě)Excel的開(kāi)源項(xiàng)目。在盡可能節(jié)約內(nèi)存的情況下支持讀寫(xiě)百M(fèi)的Excel。

maven 依賴如下:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.0.5</version>
</dependency>

讀 Execl 實(shí)踐

數(shù)據(jù)讀取代碼如下:

  • 先獲取文件流,比如 test-data.xls;
  • SkuModel是一個(gè)解析類;
  • SkuModelReadListener中進(jìn)行讀取到的數(shù)據(jù)處理。
InputStream excelStream = ExcelToolMain.class.getClassLoader().getResourceAsStream("test-data.xls");
EasyExcel.read(excelStream, SkuModel.class, new SkuModelReadListener()).sheet().doRead();

寫(xiě) Execl 實(shí)踐

寫(xiě)數(shù)據(jù)代碼如下:

  • 首先我們需要設(shè)定寫(xiě)入文件的文件名
  • 然后設(shè)置寫(xiě)入的數(shù)據(jù)類 SkuModel.
  • data() 是用來(lái)獲取數(shù)據(jù)的,其實(shí)就是返回,構(gòu)建一個(gè) List<SkuModel> 數(shù)據(jù)集合。
String fileName = ExcelToolMain.getPath() + "write" + System.currentTimeMillis() + ".xlsx";
EasyExcel.write(fileName, SkuModel.class).sheet().doWrite(data());

模板填充

為了解決 excel 模板樣式的支持,我們可以使用模板方式來(lái)進(jìn)行數(shù)據(jù)填充:

  • 模板樣式如下:

image.png

  • 填充的效果如下:

image.png

  • 代碼如下:
// 文件名
String fileName = ExcelToolMain.getPath() + "fillOps" + System.currentTimeMillis() + ".xlsx";
// 數(shù)據(jù)對(duì)象
FillData fillData = new FillData();
fillData.setName("張三");
fillData.setNumber(5.2);
// 寫(xiě)入
EasyExcel.write(fileName).withTemplate(templateFileName).sheet().doFill(fillData);

文件追加

文件追加,感覺(jué)在 EasyExcel 中其實(shí)是一個(gè)流的多寫(xiě),最后寫(xiě)完后關(guān)閉。代碼如下:

ExcelWriter excelWriter = null;
try {
    
    // 這里 需要指定寫(xiě)用哪個(gè)class去寫(xiě)
    excelWriter = EasyExcel.write(fileName, SkuModel.class).build();
    // 這里注意 如果同一個(gè)sheet只要?jiǎng)?chuàng)建一次
    WriteSheet writeSheet = EasyExcel.writerSheet(sheet).build();
    for (int i = 0; i <  5; i++) {
        // 分頁(yè)多次寫(xiě)
        excelWriter.write(data(), writeSheet);
    }
} finally {
    // 一定要 finish,表示文件寫(xiě)完畢,會(huì)關(guān)閉流
    excelWriter.finish();
}

總結(jié)

EasyExcel 是基于 POI 的 excel 解析工具,給我們提供了非常多的高效 API,解決了 POI 一些常見(jiàn)的問(wèn)題。

到此這篇關(guān)于Java中Excel高效解析工具EasyExcel的文章就介紹到這了,更多相關(guān)java解析Excel工具easyexcel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot ThreadLocal 簡(jiǎn)單介紹及使用詳解

    SpringBoot ThreadLocal 簡(jiǎn)單介紹及使用詳解

    ThreadLocal 叫做線程變量,意思是 ThreadLocal 中填充的變量屬于當(dāng)前線程,該變量對(duì)其他線程而言是隔離的,也就是說(shuō)該變量是當(dāng)前線程獨(dú)有的變量,這篇文章主要介紹了SpringBoot ThreadLocal 的詳解,需要的朋友可以參考下
    2024-01-01
  • 解決tomcat發(fā)布工程后,WEB-INF/classes下文件不編譯的問(wèn)題

    解決tomcat發(fā)布工程后,WEB-INF/classes下文件不編譯的問(wèn)題

    這篇文章主要介紹了解決tomcat發(fā)布工程后,WEB-INF/classes下文件不編譯的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • Java編程實(shí)現(xiàn)排他鎖代碼詳解

    Java編程實(shí)現(xiàn)排他鎖代碼詳解

    這篇文章主要介紹了Java編程實(shí)現(xiàn)排他鎖的相關(guān)內(nèi)容,敘述了實(shí)現(xiàn)此代碼鎖所需要的功能,以及作者的解決方案,然后向大家分享了設(shè)計(jì)源碼,需要的朋友可以參考下。
    2017-10-10
  • Java神操作:圖片快速轉(zhuǎn)換PDF秘籍

    Java神操作:圖片快速轉(zhuǎn)換PDF秘籍

    想掌握J(rèn)ava神操作,將圖片快速轉(zhuǎn)換成PDF嗎?這份秘籍將一步步引導(dǎo)你,輕松實(shí)現(xiàn)這一目標(biāo),別等了,跟著我們一起,解鎖這項(xiàng)超實(shí)用技能吧!
    2024-02-02
  • Java開(kāi)發(fā)者結(jié)合Node.js編程入門(mén)教程

    Java開(kāi)發(fā)者結(jié)合Node.js編程入門(mén)教程

    這篇文章主要介紹了Java開(kāi)發(fā)者結(jié)合Node.js編程入門(mén)教程,我將先向您展示如何使用Java EE創(chuàng)建一個(gè)簡(jiǎn)單的Rest服務(wù)來(lái)讀取 MongoDB數(shù)據(jù)庫(kù)。然后我會(huì)用node.js來(lái)實(shí)現(xiàn)相同的功能,需要的朋友可以參考下
    2014-09-09
  • JDK-StringJoiner構(gòu)造及添加元素源碼分析

    JDK-StringJoiner構(gòu)造及添加元素源碼分析

    這篇文章主要為大家介紹了JDK-StringJoiner構(gòu)造及添加元素源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置詳解

    Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置詳解

    Log4J2是Apache Log4j的升級(jí)版,參考了logback的一些優(yōu)秀的設(shè)計(jì),并且修復(fù)了一些問(wèn)題,因此帶來(lái)了一些重大的提升,這篇文章主要介紹了Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置,需要的朋友可以參考下
    2023-12-12
  • Java中對(duì)AtomicInteger和int值在多線程下遞增操作的測(cè)試

    Java中對(duì)AtomicInteger和int值在多線程下遞增操作的測(cè)試

    這篇文章主要介紹了Java中對(duì)AtomicInteger和int值在多線程下遞增操作的測(cè)試,本文得出AtomicInteger操作 與 int操作的效率大致相差在50-80倍上下的結(jié)論,需要的朋友可以參考下
    2014-09-09
  • Java后端產(chǎn)生驗(yàn)證碼后臺(tái)驗(yàn)證功能的實(shí)現(xiàn)代碼

    Java后端產(chǎn)生驗(yàn)證碼后臺(tái)驗(yàn)證功能的實(shí)現(xiàn)代碼

    這篇文章主要介紹了Java后臺(tái)產(chǎn)生驗(yàn)證碼后臺(tái)驗(yàn)證功能,本文文字結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • Spring Security LDAP實(shí)現(xiàn)身份驗(yàn)證的項(xiàng)目實(shí)踐

    Spring Security LDAP實(shí)現(xiàn)身份驗(yàn)證的項(xiàng)目實(shí)踐

    在本文中,我們涵蓋了“使用 Spring Boot 的 Spring Security LDAP 身份驗(yàn)證示例”的所有理論和示例部分,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08

最新評(píng)論