Java中Excel高效解析工具EasyExcel的實踐
參考資料:alibaba-easyexcel.github.io
簡介
EasyExcel是一個基于Java的簡單、省內(nèi)存的讀寫Excel的開源項目。在盡可能節(jié)約內(nèi)存的情況下支持讀寫百M的Excel。
maven 依賴如下:
<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.0.5</version> </dependency>
讀 Execl 實踐
數(shù)據(jù)讀取代碼如下:
- 先獲取文件流,比如 test-data.xls;
- SkuModel是一個解析類;
- SkuModelReadListener中進行讀取到的數(shù)據(jù)處理。
InputStream excelStream = ExcelToolMain.class.getClassLoader().getResourceAsStream("test-data.xls"); EasyExcel.read(excelStream, SkuModel.class, new SkuModelReadListener()).sheet().doRead();
寫 Execl 實踐
寫數(shù)據(jù)代碼如下:
- 首先我們需要設(shè)定寫入文件的文件名
- 然后設(shè)置寫入的數(shù)據(jù)類 SkuModel.
- data() 是用來獲取數(shù)據(jù)的,其實就是返回,構(gòu)建一個 List<SkuModel> 數(shù)據(jù)集合。
String fileName = ExcelToolMain.getPath() + "write" + System.currentTimeMillis() + ".xlsx"; EasyExcel.write(fileName, SkuModel.class).sheet().doWrite(data());
模板填充
為了解決 excel 模板樣式的支持,我們可以使用模板方式來進行數(shù)據(jù)填充:
- 模板樣式如下:
- 填充的效果如下:
- 代碼如下:
// 文件名 String fileName = ExcelToolMain.getPath() + "fillOps" + System.currentTimeMillis() + ".xlsx"; // 數(shù)據(jù)對象 FillData fillData = new FillData(); fillData.setName("張三"); fillData.setNumber(5.2); // 寫入 EasyExcel.write(fileName).withTemplate(templateFileName).sheet().doFill(fillData);
文件追加
文件追加,感覺在 EasyExcel 中其實是一個流的多寫,最后寫完后關(guān)閉。代碼如下:
ExcelWriter excelWriter = null; try { // 這里 需要指定寫用哪個class去寫 excelWriter = EasyExcel.write(fileName, SkuModel.class).build(); // 這里注意 如果同一個sheet只要創(chuàng)建一次 WriteSheet writeSheet = EasyExcel.writerSheet(sheet).build(); for (int i = 0; i < 5; i++) { // 分頁多次寫 excelWriter.write(data(), writeSheet); } } finally { // 一定要 finish,表示文件寫完畢,會關(guān)閉流 excelWriter.finish(); }
總結(jié)
EasyExcel 是基于 POI 的 excel 解析工具,給我們提供了非常多的高效 API,解決了 POI 一些常見的問題。
到此這篇關(guān)于Java中Excel高效解析工具EasyExcel的文章就介紹到這了,更多相關(guān)java解析Excel工具easyexcel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot ThreadLocal 簡單介紹及使用詳解
ThreadLocal 叫做線程變量,意思是 ThreadLocal 中填充的變量屬于當前線程,該變量對其他線程而言是隔離的,也就是說該變量是當前線程獨有的變量,這篇文章主要介紹了SpringBoot ThreadLocal 的詳解,需要的朋友可以參考下2024-01-01解決tomcat發(fā)布工程后,WEB-INF/classes下文件不編譯的問題
這篇文章主要介紹了解決tomcat發(fā)布工程后,WEB-INF/classes下文件不編譯的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12Java開發(fā)者結(jié)合Node.js編程入門教程
這篇文章主要介紹了Java開發(fā)者結(jié)合Node.js編程入門教程,我將先向您展示如何使用Java EE創(chuàng)建一個簡單的Rest服務(wù)來讀取 MongoDB數(shù)據(jù)庫。然后我會用node.js來實現(xiàn)相同的功能,需要的朋友可以參考下2014-09-09JDK-StringJoiner構(gòu)造及添加元素源碼分析
這篇文章主要為大家介紹了JDK-StringJoiner構(gòu)造及添加元素源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置詳解
Log4J2是Apache Log4j的升級版,參考了logback的一些優(yōu)秀的設(shè)計,并且修復了一些問題,因此帶來了一些重大的提升,這篇文章主要介紹了Spring?Boot?3中一套可以直接用于生產(chǎn)環(huán)境的Log4J2日志配置,需要的朋友可以參考下2023-12-12Java中對AtomicInteger和int值在多線程下遞增操作的測試
這篇文章主要介紹了Java中對AtomicInteger和int值在多線程下遞增操作的測試,本文得出AtomicInteger操作 與 int操作的效率大致相差在50-80倍上下的結(jié)論,需要的朋友可以參考下2014-09-09Java后端產(chǎn)生驗證碼后臺驗證功能的實現(xiàn)代碼
這篇文章主要介紹了Java后臺產(chǎn)生驗證碼后臺驗證功能,本文文字結(jié)合實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-06-06Spring Security LDAP實現(xiàn)身份驗證的項目實踐
在本文中,我們涵蓋了“使用 Spring Boot 的 Spring Security LDAP 身份驗證示例”的所有理論和示例部分,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-08-08