easyexcel 导出 代码翻译converter_真没想到!Java 导出 Excel 表格会变得如此简单优雅

作者:冷冷gg 链接:https://juejin.im/post/5e83f12ce51d4546c82d8b0f

EasyExcel

EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。 64M内存1分钟内读取75M(46W行25列)的Excel,当然还有急速模式能更快,但是内存占用会在100M多一点

9b62fd9217c75d61ef143500fb9c3f74.png

spring boot stater依赖

  • 方便在 web 环境下使用 easyexcel ,已上传至 maven 仓库
com.pig4cloud.excel    excel-spring-boot-starter    0.0.2

使用方法

只需要在 Controller 层返回 List 并增加 @ResponseExcel注解即可

@Documented@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public @interface ResponseExcel {String name() default "";ExcelTypeEnum suffix() default ExcelTypeEnum.XLSX;String password() default "";String[] sheet() default {};boolean inMemory() default false;String template() default "";String[] include() default {};String[] exclude() default {};Class extends WriteHandler>[] writeHandler() default {};Class extends Converter>[] converter() default {};}

基础用法

  • 返回单 sheet, 全部字段导出
@ResponseExcel(name = "lengleng", sheet = "demoList")@GetMapping("/e1")public List e1() {    List dataList = new ArrayList<>();    for (int i = 0; i < 100; i++) {        DemoData data = new DemoData();        data.setUsername("tr1" + i);        data.setPassword("tr2" + i);        dataList.add(data);    }    return dataList;}// 实体对象@Datapublic class DemoData {private String username;private String password;}
95f232efda9315f7ee8117d30add51b4.png
  • 自定义字段属性
@Datapublic class DemoData {    @ColumnWidth(50)  // 定义宽度@ExcelProperty("用户名") // 定义列名称    @ContentStyle(fillPatternType = FillPatternType.SOLID_FOREGROUND, fillForegroundColor = 40)private String username;@ExcelProperty("密码")private String password;}
7e7b7dfadd78f47547b56de0d2d0e60c.png
  • 忽略部分字段
@Datapublic class DemoData {    @ColumnWidth(50)  // 定义宽度@ExcelProperty("用户名") // 定义列名称    @ContentStyle(fillPatternType = FillPatternType.SOLID_FOREGROUND, fillForegroundColor = 40)private String username;@ExcelProperty("密码")private String password;
3fc330290f05effcf1cb4ec9d40cb7bb.png

导出多sheet

@ResponseExcel(name = "lengleng", sheet = {"第一个sheet","第二个sheet"})@GetMapping("/e1")public List> e1() {    List> lists = new ArrayList<>();    lists.add(list());    lists.add(list());    return lists;}
80f93b7a7034a2d2103615a7571ce81a.png

设置导出加密码

@ResponseExcel(name = "lengleng", sheet = "sheetName",password = "lengleng")@GetMapping("/e1")public List> e1() {List> lists = new ArrayList<>();lists.add(list());lists.add(list());return lists;}
24cfb40dbce1ef19339fff7e6244f506.png

高级用法模板导出

@ResponseExcel(name = "模板测试excel", sheet = "sheetName",template = "example.xlsx")@GetMapping("/e1")public List e1() {    return list();}

感悟

从正式成为一名程序员的那天起,注定要进行没有止境的学习,想要进阶高级或者专家,就要坚持每天都高效的学习,不要给自己的懒惰找借口,“什么我也想学习可是又没有资源”,这次我给你整理好了,我看你还有啥理由!私信或者回复【666】就给你

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值