Java?easyexcel使用教程之導(dǎo)出篇
EasyExcel簡介
EasyExcel是一個基于Java的簡單、省內(nèi)存的讀寫Excel的開源項目。在盡可能節(jié)約內(nèi)存的情況下支持讀寫百M(fèi)的Excel。
Excel解析流程圖:

EasyExcel讀取Excel的解析原理:

開始準(zhǔn)備工作
1、導(dǎo)入Maven依賴
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>easyexcel</artifactId>
<version>2.2.10</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.17</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.17</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>provided</scope>
<version>4.12</version>
</dependency>
2、新建Student.java類
package com.test.easyexcel.bean;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
import java.math.BigDecimal;
import java.util.Date;
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor // 一定要有無參構(gòu)造方法
public class Student {
@ExcelProperty(value = "姓名")
private String name;
@ExcelProperty(value = "性別")
private Integer sex;
@ExcelProperty(value = "生日")
private Date birthday;
@ExcelProperty(value = "體重KG")
private BigDecimal weight;
private String memo;
}
3、generateStudentUtil.java類,隨機(jī)生成Student對象
package com.test.easyexcel.util;
import com.test.easyexcel.bean.Student;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.time.ZonedDateTime;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
public class generateStudentUtil {
public static List<Student> generateStudent(int size) {
List<Student> stues = new ArrayList<>();
for (int i = 0; i < size; i++) {
stues.add(new Student("姓名" + i, (int) (Math.random() * 2), randomDate(), randomWeight(), "備注"));
}
return stues;
}
public static Date randomDate() {
LocalDateTime localDateTime = LocalDateTime.of(randomInt(1990, 2022), randomInt(1, 12), randomInt(1, 28), randomInt(0, 23), randomInt(0, 59), randomInt(0, 59), randomInt(0, 999));
ZonedDateTime zdt = localDateTime.atZone(ZoneId.systemDefault());
return Date.from(zdt.toInstant());
}
public static int randomInt(int min, int max) {
int de = max - min;
// 二進(jìn)制長度
int bitCount = Integer.toBinaryString(de).length();
int ans = 0;
do {
ans = 0;
for (int i = 0; i < bitCount; i++) {
ans += random0_1() << i;
}
} while (ans > de);
return ans + min;
}
public static int random0_1() {
return (int) (Math.random() * 2);
}
public static BigDecimal randomWeight() {
return BigDecimal.valueOf((Math.random() * 10));
}
}
4、BaseTest.java
package com.test.easyexcel;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
import java.util.function.Consumer;
// 父類
public class BaseTest {
/**
* 導(dǎo)出方法
*
* @param fileName 文件
* @param writerConsumer consumer
*/
public static void export(String fileName, Consumer<ExcelWriter> writerConsumer) {
ExcelWriter writer = EasyExcel.write(fileName)
.registerWriteHandler(new LongestMatchColumnWidthStyleStrategy())
.build();
writerConsumer.accept(writer);
writer.finish();
}
}
4、導(dǎo)出Excel報表
package com.test.easyexcel;
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.ExcelWriter;
import com.test.easyexcel.bean.Student;
import org.junit.Test;
import java.util.function.Consumer;
import static com.test.easyexcel.util.generateStudentUtil.generateStudent;
public class TestEasyExcel extends BaseTest {
@Test
public void export1() {
Consumer<ExcelWriter> consumer = writer -> {
writer.write(generateStudent(10), EasyExcel.writerSheet("學(xué)生信息")
.head(Student.class)
.build());
};
export("D:/報表.xlsx", consumer);
}
}
運(yùn)行export1結(jié)果

5、把姓名格式化:1顯示男,0顯示女
新建SexConverter.java
package com.test.easyexcel.converter;
import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.CellData;
import com.alibaba.excel.metadata.GlobalConfiguration;
import com.alibaba.excel.metadata.property.ExcelContentProperty;
public class SexConverter implements Converter<Integer> {
@Override
public Class<Integer> supportJavaTypeKey() {
return Integer.class;
}
@Override
public CellDataTypeEnum supportExcelTypeKey() {
return CellDataTypeEnum.STRING;
}
@Override
public Integer convertToJavaData(CellData cellData, ExcelContentProperty excelContentProperty, GlobalConfiguration globalConfiguration) throws Exception {
return "男".equals(cellData.getStringValue()) ? 1 : 0;
}
@Override
public CellData<String> convertToExcelData(Integer integer, ExcelContentProperty excelContentProperty, GlobalConfiguration globalConfiguration) throws Exception {
return new CellData<>(integer.equals(1) ? "男" : "女");
}
}
Student類sex屬性注入SexConverter轉(zhuǎn)換器
@ExcelProperty(value = "性別", converter = SexConverter.class) private Integer sex;
再次運(yùn)行export1()單元測試

6、把體重保留2位小數(shù)
方法1,@NumberFormat 注解。修改Student類
@ExcelProperty(value = "體重KG")
@NumberFormat("0.##") // 會以字符串形式生成單元格,要計算的列不推薦
private BigDecimal weight;
運(yùn)行export1()單元測試

方法2:@ContentStyle(dataFormat = 2) 注解 ,我們新建一個字段weight2
@ContentStyle(dataFormat = 2) private BigDecimal weight2;
運(yùn)行export1()單元測試

方法3:利用**registerConverter(new BigDecimalConverter())**統(tǒng)一類型處理
/**
* 測試統(tǒng)一類型轉(zhuǎn)換
*/
@Test
public void export2() {
Consumer<ExcelWriter> consumer = writer -> {
writer.write(generateStudent(10), EasyExcel.writerSheet("學(xué)生信息")
.registerConverter(new BigDecimalConverter())
.head(Student.class)
.build());
};
export("D:/報表.xlsx", consumer);
}
BigDecimalConverter.java
package com.test.easyexcel.converter;
import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.enums.CellDataTypeEnum;
import com.alibaba.excel.metadata.CellData;
import com.alibaba.excel.metadata.GlobalConfiguration;
import com.alibaba.excel.metadata.property.ExcelContentProperty;
import java.math.BigDecimal;
import java.math.RoundingMode;
public class BigDecimalConverter implements Converter<BigDecimal> {
@Override
public Class supportJavaTypeKey() {
return BigDecimal.class;
}
@Override
public CellDataTypeEnum supportExcelTypeKey() {
return CellDataTypeEnum.NUMBER;
}
@Override
public BigDecimal convertToJavaData(CellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
return cellData.getNumberValue();
}
@Override
public CellData convertToExcelData(BigDecimal value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception {
return new CellData(value.setScale(2, RoundingMode.DOWN));
}
}
7、過濾字段不生成excel
方式1:類上加注解 @ExcelIgnoreUnannotated,過濾屬性沒有@ExcelProperty注解的字段
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor // 一定要有無參構(gòu)造方法
@ExcelIgnoreUnannotated
public class Student {
.....
}
方式2:指定字段加注解
@ExcelIgnore // demo2不生成excel private String demo2;
方式3:代碼指定過濾字段, 同一個excel生成兩個sheet分別過濾不同字段
/**
* 過濾字段
*/
@Test
public void exportExcludeColumn() {
Consumer<ExcelWriter> consumer = writer ->
writer.write(generateStudent(10), EasyExcel.writerSheet(1, "學(xué)生信息")
.excludeColumnFiledNames(Arrays.asList("name", "sex")) // sheet1過濾姓名、性別
.head(Student.class)
.build());
consumer = consumer.andThen(writer ->
writer.write(generateStudent(10), EasyExcel.writerSheet(2, "學(xué)生信息2")
.excludeColumnFiledNames(Arrays.asList("birthday", "weight")) // sheet2過濾生日和體重
.head(Student.class)
.build()));
export("D:/報表.xlsx", consumer);
}

8、凍結(jié)列, 凍結(jié)姓名列
凍結(jié)列handler,FreezeNameHandler.java
package com.learning.easyexcel.converter;
import com.alibaba.excel.write.handler.SheetWriteHandler;
import com.alibaba.excel.write.metadata.holder.WriteSheetHolder;
import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder;
import org.apache.poi.ss.usermodel.Sheet;
/**
* 凍結(jié)姓名列
*/
public class FreezeNameHandler implements SheetWriteHandler {
@Override
public void beforeSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
}
@Override
public void afterSheetCreate(WriteWorkbookHolder writeWorkbookHolder, WriteSheetHolder writeSheetHolder) {
// 獲取到當(dāng)前的sheet
Sheet sheet = writeSheetHolder.getSheet();
/**
*第一個參數(shù):凍結(jié)的列數(shù)
*第二個參數(shù):凍結(jié)的行數(shù)
*第三個參數(shù):凍結(jié)后第一列的列號
*第四個參數(shù):凍結(jié)后第一行的行號
**/
sheet.createFreezePane(1, 0, 1, 0);
}
}
注冊handler
/**
* 凍結(jié)姓名列
*/
@Test
public void exportFreezeColumn() {
Consumer<ExcelWriter> consumer = writer -> {
writer.write(generateStudent(10), EasyExcel.writerSheet("學(xué)生信息")
.registerWriteHandler(new FreezeNameHandler()) // 凍結(jié)姓名列
.head(Student.class)
.build());
};
export("D:/報表.xlsx", consumer);
}
總結(jié)
到此這篇關(guān)于Java easyexcel使用教程之導(dǎo)出篇的文章就介紹到這了,更多相關(guān)Java easyexcel導(dǎo)出內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
jenkins如何部署應(yīng)用到多個環(huán)境
本文介紹了如何基于流水線的方式將應(yīng)用程序部署到多個環(huán)境,包括測試環(huán)境和生產(chǎn)環(huán)境,通過創(chuàng)建項目、設(shè)置參數(shù)、配置流水線、設(shè)置環(huán)境變量、配置Maven工具、構(gòu)建階段、部署測試環(huán)境和生產(chǎn)環(huán)境、以及清理階段,實(shí)現(xiàn)了自動化部署流程2024-11-11
String與XML互轉(zhuǎn)以及從XML取節(jié)點(diǎn)值并修改的方法
今天小編就為大家分享一篇String與XML互轉(zhuǎn)以及從XML取節(jié)點(diǎn)值并修改的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
Java設(shè)計模式之策略模式的使用(Strategy?Pattern)
策略模式是一種行為型設(shè)計模式,用于定義一系列算法并將每個算法封裝起來,使它們可以互相替換,從而實(shí)現(xiàn)代碼的可維護(hù)性和靈活性,策略模式包含策略接口、具體策略類和上下文類,并通過將算法的選擇與使用分離,使得算法可以獨(dú)立變化2025-03-03

