基於註解的讀取excel的工具包
easyexcel-wraper
easyexcel-wraper是什麼?
一個方便讀取excel內容,且可以使用註解進行內容驗證的包裝工具
easyexcel-wraper有哪些功能?
- 在easyexcel的基礎上進行封裝,方便讀取excel內容,避免在主業務程式碼中嵌入重複繁瑣的樣本程式碼
- 支援Hibernate-validator驗證框架,可以使用諸如@NotBlank,@NotDuiplicate的註解
如何使用
- 1、新建一個JavaBean用於接收excel內容,並繼承ExcelRow基礎類,如:新建MyRow.java
import com.alibaba.excel.annotation.ExcelProperty; import com.wuyue.excel.ExcelRow; import com.wuyue.excel.validate.NotDuplicate; import lombok.Getter; import lombok.Setter; import lombok.ToString; import org.hibernate.validator.constraints.Email; import org.hibernate.validator.constraints.NotBlank; @Getter @Setter @ToString public class MyRow extends ExcelRow { @ExcelProperty(index = 0) @NotDuplicate @NotBlank(message = "名稱不能為空") private String name; @ExcelProperty(index = 1) @Email private String email; }
- 2、呼叫ExcelReader.read方法,獲取excel內容
File file = new File("D:\\1.xlsx"); FileInputStream fileInputStream = new FileInputStream(file); List<MyRow> rows = ExcelReader.builder() .inputStream(fileInputStream) .sheetNo(1) .headLineMun(1) .build() .read(MyRow.class);
- 3、主業務功能程式碼使用“行”內容的校驗結果
System.out.println(rows); rows.forEach(row -> { // 行號,如果要提示實際excel行號,應該要加上headLineMun的值 System.out.print("Row number:" + row.getRowNum()); // 校驗結果程式碼(0為正常) System.out.print(", validate code:" + row.getValidateCode()); // 校驗結果內容 System.out.println(", message:" + row.getValidateMessage()); });
當D:\1.xlsx的內容為如下時

輸出結果如下:
[MyRow(name=felix, email=5401142), MyRow(name=wuyue, [email protected]), MyRow(name=felix, email=null), MyRow(name=wuyue, email=null)] Row number:1, validate code:2, message:不是一個合法的電子郵件地址 Row number:2, validate code:0, message:null Row number:3, validate code:1, message:Duplicate field Row number:4, validate code:1, message:Duplicate field