java使用@interface和反射来动态生成excel

1、对象类上搞注解
public class ReportExecuteDetailDto {

    // 项目信息
    private String regionCode;         // 大区编号
    @ExcelColumn(order = 0, title = "大区")
    private String regionName;         // 大区名称
    
    @ExcelColumn(order = 14, title = "行申请金额", dataType = ExcelColumn.FieldType.Number)
    private BigDecimal detailApplyAmount;    // 行申请金额
}
2、创建注解类
package cn.com.ibm.portal.subject.annotation;

import java.lang.annotation.*;

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@Documented
public @interface ExcelColumn {
    /**
     * 标注该属性的顺序
     * @return 该属性的顺序
     */
    int order();

    /**
     * execl标题
     * @return
     */
    String title();

    /**
     * 日期数据的格式化格式
     * @return
     */
    String format() default "";

    /**
     * 单元格宽度
     * @return
     */
    int width() default 30;

    /**
     *  是否设置默认值:字符串默认为""
     *  Number:0.00
     *  Date: now
     *  Percent: 0.00%
     */
    boolean hasDefault() default false;

    /**
     * 数据类型
     * @return
     */
    FieldType dataType() default FieldType.String;

    public static enum FieldType {
        /*
            字符串
         */
        String,

        /*
            数值
         */
        Number,

        /*
            日期
         */
        Date,

        /*
            百分比
         */
        Percent;
    }
}
3、获取属性
private static List<Field> getExcelColumnAnnotation(Class clazz) {
        // 用来存放所有的属性域
        List<Field> fieldList = Lists.newArrayList();
        // 过滤带有注解的Field
        for (Field f : clazz.getDeclaredFields()) {
            if (f.getAnnotation(ExcelColumn.class) != null) {
                fieldList.add(f);
            }
        }
        // 这个比较排序的语法依赖于java 1.8
        fieldList.sort(Comparator.comparingInt(
                m -> m.getAnnotation(ExcelColumn.class).order()
        ));
        return fieldList;
    }
4、使用
private static List<PoiCellVo> genExecuteReportTitleData(ReportExecuteDto dto, int startRow, int startCol) {
        List<PoiCellVo> result = Lists.newArrayList();
        //添加固定标题
        int fixStartRow = startRow;
        int fixStartCol = startCol;

        // 根据注解获取标题
        List<Field> annotationList = getExcelColumnAnnotation(ReportExecuteDetailDto.class);

        PoiCellVo fixVo = null;
        ExcelColumn annotation = null;
        for (Field field : annotationList) {
            annotation = field.getAnnotation(ExcelColumn.class);
            if (annotation == null) {
                continue;
            }
            fixVo = new PoiCellVo(annotation.title(), fixStartRow, fixStartCol, 1, 1, headerColor, (short) annotation.width(), (short) 0);
            result.add(fixVo);
            fixStartCol++;
        }

        return result;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值