easyPOI初级使用

环境 idea

核心依赖

   <dependency>
            <groupId>cn.afterturn</groupId>
            <artifactId>easypoi-spring-boot-starter</artifactId>
            <version>4.0.0</version>
        </dependency>

在这里插入图片描述

excl导入导出

通过实体+注解的方式导出模板(结果)
在这里插入图片描述

@GetMapping("/down")
public void down(HttpServletResponse httpServletResponse) {
    String fileName = "导出模板.xls";
    Class clazz = AnnotationUtils.changeAnnotation(Person.class, new ArrayList<>());
    ExcelUtiles.exportExcel(new ArrayList<>(), "标题", "sheetName", clazz, LocalDateTime.now() + fileName, httpServletResponse);
}

修改注解

public static <T> Class changeAnnotation(Class<T> clazz, List<String> hideList) {
    Field[] fields = clazz.getDeclaredFields();
    if (fields == null || fields.length < 1) {
        return clazz;
    }
    for (Field field : fields) {
        Excel excel = field.getAnnotation(Excel.class);
            InvocationHandler invocationHandler = Proxy.getInvocationHandler(excel);
            Field declaredField = null;
            try {
                declaredField = invocationHandler.getClass().getDeclaredField("memberValues");
            } catch (NoSuchFieldException e) {
                e.printStackTrace();
            }
            // 因为这个字段事 private final 修饰,所以要打开权限
            declaredField.setAccessible(true);
            // 获取 memberValues
            Map memberValues = null;
            try {
                memberValues = (Map) declaredField.get(invocationHandler);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            }
        if (hideList.indexOf(excel.name()) != -1) {
            // 修改 value 属性值
            memberValues.put("isColumnHidden", true);
            System.out.println(excel.isColumnHidden());
        }else {
            memberValues.put("isColumnHidden", false);
        }
    }
    return clazz;
}

通过修改注解属性选怎动态导入导出行

导入

/**
 * easypoi 导入
 *
 * @param multipartFile
 * @return
 */
@PostMapping("/imp")
public String import1(@RequestBody MultipartFile multipartFile) {
    List<Person> people = ExcelUtiles.importExcel(multipartFile, 1, 1, Person.class);
    System.out.println(people.size());
    return people.toString();
}

word模板导出

在这里插入图片描述

插入链接与图片

链接: git地址 demo
链接: git地址 test

图片: Alt

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小吴小吴bug全无

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值