EasyExcel注解方式校验数据行

EasyExcel注解方式校验数据行

一个方便读取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的内容为如下时

[外链图片转存失败(img-k6ATmMEU-1568041808052)(https://github.com/Felix0525/assets/blob/master/20190501-0001.png?raw=true)]

输出结果如下:

    [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

完整源码

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
EasyExcel 是一个基于Java的Excel工具,提供了方便易用的导入、导出、读写Excel等功能。在使用EasyExcel导入数据时,我们通常需要进数据校验,以保证数据的准确性和完整性。下面是对EasyExcel导入数据校验的一些介绍: 1、数据校验的目的。通过对数据校验,可以检查数据的格式、类型、范围等是否符合要求,避免数据导入后出现问题,减少后续的处理工作。 2、数据校验方式EasyExcel提供了数据校验的三种方式:基于注解、基于自定义校验器和基于表头匹配。基于注解是通过在实体类属性上加注解方式校验;基于自定义校验器是用户自定义校验器类,继承EasyExcel的IExcelDataValidator接口,实现校验逻辑;基于表头匹配是通过匹配表头名称,判断导入的数据是否符合规定。 3、数据校验的具体实现。在使用EasyExcel数据导入时,我们可以在读取数据之前,加上相应的数据校验逻辑。通过校验器对数据校验,设置成功或者失败的回调函数,来处理校验结果。如对于校验失败的数据,可以进错误提示或者忽略处理。 4、数据校验的结论。通过EasyExcel数据导入时,可以进数据校验,避免了数据导入后出现各种问题。如果校验结果全部通过,那么可以放心将数据导入到业务中进处理。如果校验结果有不通过的,可以根据具体情况进处理,忽略不重要的,或者重新进数据导入操作。 总之,EasyExcel是一个非常实用的Excel工具,通过数据校验,可以大大提高数据的准确性和完整性,减少后续的处理工作,可以更好地服务于业务需求。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值