Springboot+Easyexcel将数据写入模板文件并导出Excel的操作代码
一、导入依赖
<!--操作excel工具包--> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.0.5</version> </dependency>
话费电费燃气费94折充值,加v: sz08111,长期有效
二、根据excel表头创建对应的实体类Pojo
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表示列名的索引值。
三、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<ExcelTitle> 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<ExcelTitle> getOutputData() { List<ExcelTitle> 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里的内容。
需要注意
- 需要加上response的响应类型和响应头来使得返回请求返回excel文件
- 写到Web流时,这里的ContentType和CharacterEncoding不要乱码,否则很容易乱码或者文件损坏
- 使用EasyExcel.withTemplate引入模板的输入流
到此这篇关于Springboot+Easyexcel将数据写入模板文件并导出Excel的文章就介绍到这了,更多相关Springboot Easyexcel 导出Excel内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- SpringBoot种如何使用 EasyExcel 实现自定义表头导出并实现数据格式化转换
- SpringBoot中使用EasyExcel并行导出多个excel文件并压缩zip后下载的代码详解
- Springboot整合EasyExcel实现Excel文件上传方式
- SpringBoot 整合 EasyExcel 实现自由导入导出功能
- SpringBoot整合EasyExcel实现批量导入导出
- SpringBoot整合EasyExcel实现复杂Excel表格的导入导出
- SpringBoot整合EasyExcel实现导入导出功能
- 使用SpringBoot+EasyExcel+Vue实现excel表格的导入和导出详解
相关文章
关于spring boot使用 jdbc+mysql 连接的问题
这篇文章主要介绍了spring boot使用 jdbc+mysql 连接,在这里mysql 8.x版本驱动包,要使用 com.mysql.cj.jdbc.Driver作为驱动类,文中给大家详细介绍,需要的朋友可以参考下2022-03-03
最新评论