在实际工作中用到的再慢慢补充
public class Demo{
//字段不能为空
@NotBlank(message = "ID不能为空")
private String Id;
//cellType 定义导出数据类型(如0数字 1字符串)
@Excel(name = "上级ID", cellType = Excel.ColumnType.NUMERIC)
private String parentId;
//type 定义字段类型
@Excel(name = "帐号状态", type = Type.EXPORT)
private String status;
//name 导出模板列名
@Excel(name = "用户名")
private String userName;
//readConverterExp 读取内容转表达式
@Excel(name = "安全等级", readConverterExp = "1=一级,2=二级,3=三级")
private String loginLevel;
//min max 获取字段时校验字段长度
@Size(min = 0, max = 100, message = "用户名长度不能超过100个字符")
public String getUserName()
{
return userName;
}
}
excel类:
package gov.chinatax.tpass.acl.util.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
* 自定义导出Excel数据注解
*
* @author ruoyi
*/
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Excel
{
/**
* 导出到Excel中的名字.
*/
public String name() default "";
/**
* 日期格式, 如: yyyy-MM-dd
*/
public String dateFormat() default "";
/**
* 读取内容转表达式 (如: 0=男,1=女,2=未知)
*/
public String readConverterExp() default "";
/**
* 导出类型(0数字 1字符串)
*/
public ColumnType cellType() default ColumnType.STRING;
/**
* 导出时在excel中每个列的高度 单位为字符
*/
public double height() default 14;
/**
* 导出时在excel中每个列的宽 单位为字符
*/
public double width() default 16;
/**
* 文字后缀,如% 90 变成90%
*/
public String suffix() default "";
/**
* 当值为空时,字段的默认值
*/
public String defaultValue() default "";
/**
* 提示信息
*/
public String prompt() default "";
/**
* 设置只能选择不能输入的列内容.
*/
public String[] combo() default {};
/**
* 是否导出数据,应对需求:有时我们需要导出一份模板,这是标题需要但内容需要用户手工填写.
*/
public boolean isExport() default true;
/**
* 另一个类中的属性名称,支持多级获取,以小数点隔开
*/
public String targetAttr() default "";
/**
* 字段类型(0:导出导入;1:仅导出;2:仅导入)
*/
Type type() default Type.ALL;
/**
* 导出类型(ALL:导出导入;EXPORT:仅导出;IMPORT:仅导入)
*/
public enum Type
{
ALL(0), EXPORT(1), IMPORT(2);
private final int value;
Type(int value)
{
this.value = value;
}
public int value()
{
return this.value;
}
}
/**
* 字段类型(NUMERIC:数字;STRING:字符串)
*/
public enum ColumnType
{
NUMERIC(0), STRING(1);
private final int value;
ColumnType(int value)
{
this.value = value;
}
public int value()
{
return this.value;
}
}
}