EasyExcel自定义非空注解,类似@NotBlank注解。

写在前面

今天开发excel导入数据的功能,一切都很顺利。但是当看到需求文档,其中有几个列的数据是必输的。于是我想到了,在实体类属性上加@NotBlank注解不就可以了嘛!但是我写接口入参是一个文件,所以解析实体后这个注解根本不起作用。于是想到自己创建自定义注解,校验非空的列。

正题

1.创建注解类

写过注解的同学应该都比较熟悉了,直接上代码。

字符串非空校验

/**
 * Excel导入必填校验注解
 *
 */
@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelValid {
    String message() default "非空字段必填";
}

字符串长度校验注解

@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelStrLengthValid {
    int length() default 0;
    String message() default "字段超长";
}

int长度校验

@Target(ElementType.FIELD)
@Retention(RetentionPolicy.RUNTIME)
public @interface ExcelIntValid {
    int min();
    int max();
    String message() default "整数超过长度范围";
}

还可以写其他类型的校验注解,这里就不展示了。

2.导入字段检验逻辑

public class ExcelInValid {

    /**
     * Excel导入字段校验
     *
     * @param object 校验的JavaBean 其属性须有自定义注解
     * @author linmaosheng
     */
    public static void valid(Object object) {
        Field[] fields = object.getClass().getDeclaredFields();
        for (Field field : fields) {
            field.setAccessible(true);
            //属性的值
            Object fieldValue = null;
            try {
                fieldValue = field.get(object);
            } catch (IllegalAccessException e) {
                //B
您可以使用EasyExcel库中的@ExcelProperty注解来实现自定义转换器。@ExcelProperty注解用于将Java对象的属性与Excel表格的列进行映射。 首先,您需要创建一个实现了Converter接口的自定义转换器类。Converter接口有两个方法需要实现:convertToExcelData和convertToJavaData。convertToExcelData方法将Java对象属性转换为Excel表格中要写入的数据,而convertToJavaData方法将Excel表格中读取的数据转换为Java对象属性。 以下是一个示例的自定义转换器类: ```java import com.alibaba.excel.converters.Converter; import com.alibaba.excel.metadata.CellData; import com.alibaba.excel.metadata.GlobalConfiguration; import com.alibaba.excel.metadata.property.ExcelContentProperty; public class CustomConverter implements Converter<Object> { @Override public Class<?> supportJavaTypeKey() { return null; // 返回支持的Java类型 } @Override public CellData<Object> convertToExcelData(Object value, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception { // 将Java对象属性转换为Excel表格中要写入的数据,返回CellData对象 // 实现转换逻辑 return new CellData<>(value); } @Override public Object convertToJavaData(CellData cellData, ExcelContentProperty contentProperty, GlobalConfiguration globalConfiguration) throws Exception { // 将Excel表格中读取的数据转换为Java对象属性,返回对应类型的值 // 实现转换逻辑 return cellData.getData(); } } ``` 然后,在您的Java对象的属性上使用@ExcelProperty注解,并指定自定义转换器类: ```java public class YourObject { @ExcelProperty(converter = CustomConverter.class) private Object yourProperty; // 其他属性和方法 } ``` 这样,在使用EasyExcel库读取或写入Excel表格时,会自动应用您定义的转换器来实现自定义的转换逻辑。 希望对您有帮助!如有问题,请随时提问。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值