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=540114289@qq.com), 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