EasyExcel 动态导出指定列
EasyExcel使用
EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。在尽可能节约内存的情况下支持读写百M的Excel。
官方文档写的非常详细:EasyExcel · 语雀
GitHub:https://github.com/alibaba/easyexcel
指定列动态导出
在导出的基础上,添加导出字段,可实现动态导出数据
根据官方文档,有两种导出方式,一种需要手动关闭文件流,一种自动关闭文件流,在此我选择自动关闭文件流的方式。
ExcelWriterBuilder excelBuilder = EasyExcel.write(response.getOutputStream(), ExcelUserDTO.class);
excelBuilder = includeColumnFiledName(includeColumnFiledNames, excelBuilder);
excelBuilder.sheet("sheet").doWrite(data());
指定列动态导出关键代码:
private ExcelWriterBuilder includeColumnFiledName(Set<String> includeColumnFiledNames, ExcelWriterBuilder excelBuilder) {
excelBuilder = excelBuilder.registerWriteHandler(new LongestMatchColumnWidthStyleStrategy());
if (includeColumnFiledNames.size() > 0) {
excelBuilder = excelBuilder.includeColumnFiledNames(includeColumnFiledNames);
}
excelBuilder = excelBuilder.registerWriteHandler(new LongestMatchColumnWidthStyleStrategy());
return excelBuilder;
}
复杂表头制作
EasyExcel复杂表制作也非常简单,使用@ExcelProperty注解