Java中Excel高效解析工具EasyExcel的實(shí)踐
參考資料: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 依賴(lài)如下:
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.0.5</version>
</dependency>讀 Execl 實(shí)踐
數(shù)據(jù)讀取代碼如下:
- 先獲取文件流,比如 test-data.xls;
- SkuModel是一個(gè)解析類(lèi);
- 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ù)類(lèi) 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ù)填充:
- 模板樣式如下:
- 填充的效果如下:
- 代碼如下:
// 文件名
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)文章
解決idea2024版本創(chuàng)建項(xiàng)目時(shí)沒(méi)有java?8的版本選擇
這篇文章主要介紹了在使用IntelliJ?IDEA創(chuàng)建Spring?Boot項(xiàng)目時(shí)遇到的問(wèn)題,包括Java版本選擇受限和項(xiàng)目結(jié)構(gòu)不完整,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2025-03-03
Java操作Mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)的增刪查改功能示例
這篇文章主要介紹了Java操作Mongodb數(shù)據(jù)庫(kù)實(shí)現(xiàn)數(shù)據(jù)的增刪查改功能,結(jié)合完整實(shí)例形式分析了java針對(duì)MongoDB數(shù)據(jù)庫(kù)的連接、增刪改查等相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
Java Set簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
Set最大的特性就是不允許在其中存放的元素是重復(fù)的。接下來(lái)通過(guò)本文給大家分享java set常用方法和原理分析,需要的的朋友參考下吧2017-05-05
Java實(shí)現(xiàn)文件上傳至服務(wù)器的方法
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)文件上傳至服務(wù)器的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
springboot開(kāi)啟mybatis二級(jí)緩存的步驟詳解
這篇文章給大家介紹了springboot開(kāi)啟mybatis二級(jí)緩存的詳細(xì)步驟,文中通過(guò)代碼示例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-02-02
springboot+mybatis-plus實(shí)現(xiàn)自動(dòng)建表的示例
本文主要介紹了springboot+mybatis-plus實(shí)現(xiàn)自動(dòng)建表的示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06
java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例
今天小編就為大家分享一篇java調(diào)用shell命令并獲取執(zhí)行結(jié)果的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
SpringMVC整合SpringSession 實(shí)現(xiàn)sessiong
這篇文章主要介紹了SpringMVC整合SpringSession 實(shí)現(xiàn)session的實(shí)例代碼,本文通過(guò)實(shí)例相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友參考下吧2018-04-04
idea中maven使用tomcat7插件運(yùn)行run報(bào)錯(cuò)Could not start T
這篇文章主要介紹了idea中maven使用tomcat7插件運(yùn)行run報(bào)錯(cuò)Could not start Tomcat問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-09-09

