Java?easyexcel使用教程之導(dǎo)出篇
EasyExcel簡(jiǎn)介
EasyExcel是一個(gè)基于Java的簡(jiǎn)單、省內(nèi)存的讀寫Excel的開源項(xiàng)目。在盡可能節(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 // 一定要有無(wú)參構(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對(duì)象
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)制長(zhǎng)度 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報(bào)表
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:/報(bào)表.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()單元測(cè)試
6、把體重保留2位小數(shù)
方法1,@NumberFormat 注解。修改Student類
@ExcelProperty(value = "體重KG") @NumberFormat("0.##") // 會(huì)以字符串形式生成單元格,要計(jì)算的列不推薦 private BigDecimal weight;
運(yùn)行export1()單元測(cè)試
方法2:@ContentStyle(dataFormat = 2) 注解 ,我們新建一個(gè)字段weight2
@ContentStyle(dataFormat = 2) private BigDecimal weight2;
運(yùn)行export1()單元測(cè)試
方法3:利用**registerConverter(new BigDecimalConverter())**統(tǒng)一類型處理
/** * 測(cè)試統(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:/報(bào)表.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 // 一定要有無(wú)參構(gòu)造方法 @ExcelIgnoreUnannotated public class Student { ..... }
方式2:指定字段加注解
@ExcelIgnore // demo2不生成excel private String demo2;
方式3:代碼指定過濾字段, 同一個(gè)excel生成兩個(gè)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:/報(bào)表.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(); /** *第一個(gè)參數(shù):凍結(jié)的列數(shù) *第二個(gè)參數(shù):凍結(jié)的行數(shù) *第三個(gè)參數(shù):凍結(jié)后第一列的列號(hào) *第四個(gè)參數(shù):凍結(jié)后第一行的行號(hào) **/ sheet.createFreezePane(1, 0, 1, 0); } }
注冊(cè)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:/報(bào)表.xlsx", consumer); }
總結(jié)
到此這篇關(guān)于Java easyexcel使用教程之導(dǎo)出篇的文章就介紹到這了,更多相關(guān)Java easyexcel導(dǎo)出內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Java利用EasyExcel解析動(dòng)態(tài)表頭及導(dǎo)出實(shí)現(xiàn)過程
- java利用easyexcel實(shí)現(xiàn)導(dǎo)入與導(dǎo)出功能
- Java 中EasyExcel的使用方式
- Java?easyExcel的復(fù)雜表頭多級(jí)表頭導(dǎo)入
- Java使用EasyExcel進(jìn)行單元格合并的問題詳解
- Java利用EasyExcel實(shí)現(xiàn)合并單元格
- java EasyExcel面向Excel文檔讀寫邏輯示例詳解
- java EasyExcel實(shí)現(xiàn)動(dòng)態(tài)列解析和存表
相關(guān)文章
freemarker?jsp?java內(nèi)存方式實(shí)現(xiàn)分頁(yè)示例
這篇文章主要介紹了freemarker?jsp?java內(nèi)存方式實(shí)現(xiàn)分頁(yè)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06解決Mybatis中result標(biāo)簽識(shí)別不了的情況
這篇文章主要介紹了解決Mybatis中result標(biāo)簽識(shí)別不了的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。2022-01-01Java Swing中的下拉式菜單(menu)、彈出式菜單(JPopupMenu)、選項(xiàng)卡窗體(JTabbedPane)
這篇文章主要介紹了Java Swing中的下拉式菜單(menu)、彈出式菜單(JPopupMenu)、選項(xiàng)卡窗體(JTabbedPane)組件使用案例,需要的朋友可以參考下2014-10-10SpringAOP 設(shè)置注入的實(shí)現(xiàn)步驟
這篇文章主要介紹了SpringAOP 設(shè)置注入的實(shí)現(xiàn)步驟,幫助大家更好的理解和學(xué)習(xí)使用Spring框架,感興趣的朋友可以了解下2021-05-05Java手機(jī)號(hào)碼工具類示例詳解(判斷運(yùn)營(yíng)商、獲取歸屬地)
這篇文章主要介紹了Java手機(jī)號(hào)碼工具類示例詳解,通過手機(jī)號(hào)碼來判斷運(yùn)營(yíng)商獲取歸屬地,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02