easyExcel不同版本按照模板导出
创始人
2024-01-30 09:59:41
0

        Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,一个3M的excel用POI sax解析依然需要100M左右内存,改用easyexcel可以降低到几M,并且再大的excel也不会出现内存溢出;03版依赖POI的sax模式,在上层做了模型转换的封装,让使用者更加简单方便。

1.引入pom依赖  

   2.1.6版本


       
            com.alibaba
            easyexcel
            2.1.6
       

 2.excel模板:

 3.导出方法

@Log("导出财务数据")@ApiOperation("导出财务数据")@GetMapping(value = "/download")public void download(HttpServletResponse response) throws IOException {Demo2 otherInfo = new Demo2();otherInfo.setDate(new Date());//蔬菜信息List demo1s = new ArrayList<>();Demo1 demo1 = new Demo1();demo1.setName("胡萝北");demo1.setNumber(10);demo1s.add(demo1);Demo1 demo11 = new Demo1();demo11.setName("西红柿");demo11.setNumber(30);demo1s.add(demo11);response.setContentType("application/octet-stream");response.setHeader("content-type", "application/octet-stream");response.setCharacterEncoding("utf-8");String fileName = null;// 这里URLEncoder.encode可以防止中文乱码try {fileName = URLEncoder.encode("测试的.xlsx", "UTF-8").replaceAll("\\+", "%20");} catch (UnsupportedEncodingException e) {e.printStackTrace();}response.setHeader("Content-disposition", "attachment;filename=" + fileName);
//获取response//获取模板ClassPathResource classPathResource = new ClassPathResource("static/temp.xlsx");try (InputStream inputStream = classPathResource.getInputStream();ServletOutputStream outputStream = response.getOutputStream()) {//设置输出流和模板信息ExcelWriter excelWriter = EasyExcel.write(outputStream).withTemplate(inputStream).build();WriteSheet writeSheet = EasyExcel.writerSheet().build();//开启自动换行,自动换行表示每次写入一条list数据是都会重新生成一行空行,此选项默认是关闭的,需要提前设置为trueFillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();excelWriter.fill(demo1s, fillConfig, writeSheet);excelWriter.fill(otherInfo, writeSheet);excelWriter.finish();} catch (Exception e) {e.printStackTrace();}}

实体类代表

import com.alibaba.excel.annotation.ExcelProperty;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;@Getter
@Setter
@EqualsAndHashCode
public class Demo1 {@ExcelProperty("姓名")private String name;@ExcelProperty("数字")private Integer number;
}

   3.0.5版本

需求背景:

针对用户选择的数据,利用现有的excel模板,实现批量导出的功能。比如CSDN也有类似的批量导出数据功能,这里需要导出时,按照模板文件的字段导出。

现有模板字段:

实现方式:springboot+easyexcel

一、导入依赖


org.projectlomboklombok

com.alibabaeasyexcel3.0.5

二、根据excel表头创建对应的实体类Pojo

ExcelTitile实体类

import com.alibaba.excel.annotation.ExcelProperty;
import lombok.Data;@Data
public class ExcelTitle {@ExcelProperty(value="事件名称", index=0)private String eventName;@ExcelProperty(value="需求负责人", index=1)private String prdManager;@ExcelProperty(value="技术负责人", index=2)private String techManager;@ExcelProperty(value="文档链接", index=3)private String prdDocs;@ExcelProperty(value="数据链接", index=4)private String statsDocs;@ExcelProperty(value="统计口径", index=5)private String reportCaliber;

这里采用了@ExcelProperty的注解,其中value表示列名,index表示列名的索引值。@Data 注解的主要作用是提高代码的简洁,使用这个注解可以省去代码中大量的get()、 set()、 toString()等方法;

三、Controller类接收请求

@RequestMapping(value = "/bulkOutput", method = RequestMethod.GET)public ResultBean bulkOutput(HttpServletResponse response) {// 重要! 设置返回格式是excel形式response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");// 设置编码格式response.setCharacterEncoding("utf-8");// 设置URLEncoder.encode 防止中文乱码String fileName = null;try {fileName = URLEncoder.encode("数据批量导出", "UTF-8").replaceAll("\\+", "%20");// 设置响应头response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");List bulkOutputData = wildEventService.getBulkOutputData();// 模板文件保存在springboot项目的resources/static下Resource resource = new ClassPathResource("static/数据批量导出模板.xlsx");ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream()).withTemplate(resource.getInputStream()) // 利用模板的输出流.build();// 写入模板文件的第一个sheet 索引0    WriteSheet writeSheet = EasyExcel.writerSheet(0).build();// 将数据写入到模板文件的对应sheet中excelWriter.write(bulkOutputData, writeSheet);excelWriter.finish();} catch (UnsupportedEncodingException e) {return ResultBean.errorService(e.getMessage());} catch (IOException e) {return ResultBean.errorService(e.getMessage());}return ResultBean.success("数据导出成功!");}

上述代码中,首先对response进行了设置,设置了返回类型,响应头,以及导出下载时的文件名称。接下来,利用Resource resource = new ClassPathResource("static/数据批量导出模板.xlsx"); 读取项目下的模板文件,并调用easyexcel的写入方法。这里write(response.getOutputStream())表示写入response的输出流,即将文件返回给客户端进行下载withTemplate(resource.getInputStream())表示读取模板文件进行写入。最后调用 WriteSheet writeSheet = EasyExcel.writerSheet(0).build();将苏剧写入模板文件的第一个sheet中(索引从0开始)。

四、Service层获取待写入数据

这里为了简易期间,构造一些数据如下

import com.example.demo.Pojo.ExcelTitle;
import org.springframework.stereotype.Service;import java.util.ArrayList;
import java.util.List;@Service
public class BulkOutputService {public List getOutputData(){List resultList = new ArrayList<>();// 第一行数据ExcelTitle t1 = new ExcelTitle();t1.setEventName("测试数据1");t1.setTechManager("张三");t1.setPrdManager("张三");t1.setPrdDocs("http://prdDocs.com");t1.setStatsDocs("http://statsDocs.com");t1.setReportCaliber("reportCaliber");// 第二行数据ExcelTitle t2 = new ExcelTitle();t2.setEventName("测试数据2");t2.setTechManager("李四");t2.setPrdManager("李四");t2.setPrdDocs("http://prdDocs.com");t2.setStatsDocs("http://statsDocs.com");t2.setReportCaliber("reportCaliber");resultList.add(t1);resultList.add(t2);return resultList;}}

这里构造了两行简易数据,实际场景中只需要根据自己的数据做替换就可以了。

有了上述步骤,就可以接下来执行代码查看导出效果了。

效果展示

启动springboot程序,在浏览器中输入请求: http://localhost:8080/bulkOutput, 可以发现返回的excel文件被浏览器下载,打开后内容如下:

可以看到,数据根据模板格式写入了文件,并以excel的形式导出。初步完成了我们预定的场景。

总结

本次实现的功能是利用现有模板,将数据批量导出成excel,借助于easyexcel来实现操作excel的功能。最重要的功能模块是Controller里的内容。

需要注意

  1. 需要加上response的响应类型和响应头来使得返回请求返回excel文件

  2. 写到Web流时,这里的ContentType和CharacterEncoding不要乱码,否则很容易乱码或者文件损坏

  3. 使用EasyExcel.withTemplate引入模板的输入流

 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...