SpringBoot整合EasyExcel進(jìn)行大數(shù)據(jù)處理的方法詳解
EasyExcel
我用過Poi和EasyPoi這些工具總體來說:
- POI 優(yōu)點(diǎn)我覺得自由,但是迎來的就是復(fù)雜度,和大數(shù)據(jù)量時(shí)候性能的缺點(diǎn)
- EasyPoi基于POI 的二次封裝,解決了大部分的常用場景,簡化了代碼,但是特別復(fù)雜表格處理還是不行,而且性能的話和poi差不多,簡單來說就是簡化了Poi的操作,少些點(diǎn)代碼
下面來說說今天的主角EasyExcel,這個(gè)項(xiàng)目是阿里巴巴開發(fā)的開源的,專門針對大數(shù)據(jù)批量處理,比如100萬+的Excel數(shù)據(jù)這種,會(huì)比以上幾款要快很多并且性能上也不會(huì)太占用系統(tǒng)的資源,但是不好的地方就是,處理不了復(fù)雜的表單 ,不能像poi那么自由,所以有得有失,基本日常所需都能辦到,特殊場景在可以使用模板的方式,或者使用poi也行
主流操作的excel格式

下面這種分組的也能讀取,但是需要跳過前兩行的標(biāo)題

下面演示,基礎(chǔ)的入門讀和寫案例, 需要對數(shù)據(jù)進(jìn)行特殊處理,多Sheet,或者同步等需要參考文檔,基礎(chǔ)會(huì)了看文檔就簡單了
需要的Maven
<dependencies>
<!-- 開發(fā)web 項(xiàng)目和啟動(dòng)Springboot必須添加的-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.4.1</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>2.0.3.graal</version>
<scope>compile</scope>
</dependency>
</dependencies>
基礎(chǔ)讀案例
操作的excel

實(shí)體類
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class EmployeesEntity {
@ExcelProperty(index = 0)
private Integer no; //工號
@ExcelProperty(index = 1)
private String name;
@ExcelProperty(index = 2)
private Double fund;
@ExcelProperty(index = 3)
private Double postSalary;
@ExcelProperty(index = 4)
private Double performanceOf;
@ExcelProperty(index = 5)
private Double allWork;
@ExcelProperty(index = 6)
private Double violations;
@ExcelProperty(index = 7)
private Double traffic;
@ExcelProperty(index = 8)
private Double communication;
}
讀取監(jiān)聽器
一般是異步讀取,可以指定同步讀取數(shù)據(jù)(看文檔)
public class EmployeesListener extends AnalysisEventListener<EmployeesEntity> {
/**
* 這個(gè)每一條數(shù)據(jù)解析都會(huì)來調(diào)用
*
* @param data
* one row value. Is is same as {@link AnalysisContext#readRowHolder()}
* @param context
*/
@Override
public void invoke(EmployeesEntity data, AnalysisContext context) {
System.out.println("解析到一條數(shù)據(jù):"+JSON.toJSONString(data));
}
/**
* 所有數(shù)據(jù)解析完成了 都會(huì)來調(diào)用
*
* @param context
*/
@Override
public void doAfterAllAnalysed(AnalysisContext context) {
}
}
測試
@Test
public void get(){
File file = new File("./src/main/resources/大客戶部-薪酬表.xlsx");
String absolutePath = file.getAbsolutePath();
// // 這里 需要指定讀用哪個(gè)class去讀,然后讀取第一個(gè)sheet 文件流會(huì)自動(dòng)關(guān)閉
EasyExcel.read(absolutePath, EmployeesEntity.class, new EmployeesListener()).sheet().doRead();
}

基礎(chǔ)寫案例
寫可以指定Sheet進(jìn)行寫,還可以指定列進(jìn)行寫,還可以寫入圖片,簡單的合并單元格…下面教程默認(rèn)寫入第一個(gè)Sheet中
實(shí)體類
@ExcelProperty("字符串標(biāo)題") 列的標(biāo)題
@Data
public class DemoData {
@ExcelProperty("字符串標(biāo)題")
private String string;
@ExcelProperty("日期標(biāo)題")
private Date date;
@ExcelProperty("數(shù)字標(biāo)題")
private Double doubleData;
/**
* 忽略這個(gè)字段
*/
@ExcelIgnore
private String ignore;
}
測試
//生成模擬數(shù)據(jù)
private List<DemoData> data() {
List<DemoData> list = new ArrayList<DemoData>();
for (int i = 0; i < 10; i++) {
DemoData data = new DemoData();
data.setString("字符串" + i);
data.setDate(new Date());
data.setDoubleData(0.56);
list.add(data);
}
return list;
}
/**
* 最簡單的寫
* <p>1. 創(chuàng)建excel對應(yīng)的實(shí)體對象 參照{(diào)@link DemoData}
* <p>2. 直接寫即可
*/
@Test
public void simpleWrite() {
// 寫
File file = new File("./src/main/resources/DemoData.xlsx");
// 這里 需要指定寫用哪個(gè)class去寫,然后寫到第一個(gè)sheet,名字為模板 然后文件流會(huì)自動(dòng)關(guān)閉
// 如果這里想使用03 則 傳入excelType參數(shù)即可
EasyExcel.write(file.getAbsolutePath(), DemoData.class).sheet("DemoData").doWrite(data());
}

Excel模板方式
一般特別復(fù)雜的excel,比如發(fā)票,等, 一般就需要使用模板的方式,如果使用代碼的話太復(fù)雜了
準(zhǔn)備模塊

實(shí)體類
@Data
public class FillData {
private String name;
private double number;
}
測試
@Test
public void simpleFill() {
// 模板注意 用{} 來表示你要用的變量 如果本來就有"{","}" 特殊字符 用"\{","\}"代替
File templateFileName = new File("./src/main/resources/模板.xlsx");
File fill = new File("./src/main/resources/fillData.xlsx");
// 這里 會(huì)填充到第一個(gè)sheet, 然后文件流會(huì)自動(dòng)關(guān)閉
FillData fillData = new FillData();
fillData.setName("張三");
fillData.setNumber(5.2);
EasyExcel.write(fill.getAbsolutePath()).withTemplate(templateFileName.getAbsolutePath()).sheet().doFill(fillData);
}
如果是統(tǒng)計(jì)表,而且標(biāo)題是非常復(fù)雜的情況下,那么我們使用列表填充會(huì)很容易解決(自行看文檔)
到此這篇關(guān)于SpringBoot整合EasyExcel進(jìn)行大數(shù)據(jù)處理的方法詳解的文章就介紹到這了,更多相關(guān)SpringBoot EasyExcel大數(shù)據(jù)處理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot整合EasyExcel實(shí)現(xiàn)大規(guī)模數(shù)據(jù)的并行導(dǎo)出與壓縮下載
- SpringBoot利用EasyExcel實(shí)現(xiàn)導(dǎo)出數(shù)據(jù)
- 使用VUE+SpringBoot+EasyExcel?整合導(dǎo)入導(dǎo)出數(shù)據(jù)的教程詳解
- SpringBoot整合EasyExcel實(shí)現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)
- SpringBoot種如何使用?EasyExcel?實(shí)現(xiàn)自定義表頭導(dǎo)出并實(shí)現(xiàn)數(shù)據(jù)格式化轉(zhuǎn)換
相關(guān)文章
Spring Boot + Vue 基于 RSA 的用戶身份
RSA是一種非對稱加密算法,適用于用戶身份認(rèn)證加密,本文介紹了基于RSA的用戶身份認(rèn)證加密機(jī)制的實(shí)現(xiàn),包括前端Vue.js使用jsencrypt庫對用戶名密碼進(jìn)行加密,后端使用RSA私鑰解密驗(yàn)證用戶憑據(jù),感興趣的朋友跟隨小編一起看看吧2024-11-11
Java使用Ajax實(shí)現(xiàn)跨域上傳圖片功能
這篇文章主要介紹了Java使用Ajax實(shí)現(xiàn)跨域上傳圖片功能,需要的朋友可以參考下2017-09-09
Java實(shí)現(xiàn)復(fù)制文件并命名的超簡潔寫法
這篇文章主要介紹了Java實(shí)現(xiàn)復(fù)制文件并命名的超簡潔寫法,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
SpringBoot整合HTTPS的項(xiàng)目實(shí)踐
HTTPS的主要作用是通過SSL證書保護(hù)用戶數(shù)據(jù)的安全與隱私,增加網(wǎng)站信任度,防止數(shù)據(jù)被竊取和篡改,保護(hù)網(wǎng)站免受釣魚攻擊,本文就來介紹一下,感興趣的可以了解一下2024-10-10
JDK8配置環(huán)境變量的bat文件的詳細(xì)教程
這篇文章主要介紹了JDK8配置環(huán)境變量的bat文件,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
SpringBoot基于Mybatis-Plus自動(dòng)代碼生成
這篇文章主要介紹了SpringBoot基于Mybatis-Plus自動(dòng)代碼生成,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

