标签:code 读取 excel 工具包 MyRow import message validate
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
标签:code,读取,excel,工具包,MyRow,import,message,validate 来源: https://www.cnblogs.com/felixwu0525/p/10808130.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。