地质所 沉降监测网建设项目
zmk
2024-05-16 6cc8b13ee47303a907f8e57b018406c46d8928e4
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package com.javaweb.common.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;
 
    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;
        }
    }
 
    public enum ColumnType
    {
        NUMERIC(0), STRING(1);
        private final int value;
 
        ColumnType(int value)
        {
            this.value = value;
        }
 
        public int value()
        {
            return this.value;
        }
    }
}