easyexcel 导出 代码翻译converter_【starter推荐】简单高效Excel 导出工具

EasyExcel

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

95c07667fcaa0403e24a38445465ddfe.png

spring boot starter依赖

  • 方便在 web 环境下使用 easyexcel ,已上传至 maven 仓库
<dependency>
<groupId>com.pig4cloud.excelgroupId>
<artifactId>excel-spring-boot-starterartifactId>
<version>0.0.1version>
dependency>

使用方法

只需要在 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 Liste1() {
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;
}
bd5782f71ba2db800d32121e79b8a8e1.png
  • 自定义字段属性
@Data
public class DemoData {
@ColumnWidth(50) // 定义宽度
@ExcelProperty("用户名") // 定义列名称
private String username;
@ExcelProperty("密码")
private String password;
}
3ad987cb97bba1d5e3e94a86be9e7f7c.png
  • 忽略部分字段
@Data
public class DemoData {
@ColumnWidth(50) // 定义宽度
@ExcelProperty("用户名") // 定义列名称
@ContentStyle(fillPatternType = FillPatternType.SOLID_FOREGROUND, fillForegroundColor = 40)
private String username;
@ExcelProperty("密码")
private String password;
}
bb5f7b0a98b6bb0707017468fc8bb106.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;
}
6a9b045226d2d0704c980f59fd0237c1.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;
}
6ce927e0d769e5eddf0384e392f50863.png

高级用法模板导出

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

其他用法

  • 理论上支持 alibaba/easyexcel[1] v2.1.6 版本的大部分配置
  • 支持 alibaba/easyexcel[2] 原生的配置注解
  • github stater 地址,可fork 魔改[3]

Reference

[1]

alibaba/easyexcel: https://github.com/alibaba/easyexcel

[2]

alibaba/easyexcel: https://www.yuque.com/easyexcel/doc/write

[3]

github stater 地址,可fork 魔改: https://github.com/pigxcloud/excel-spring-boot-starter

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值