easyExcel不同版本按照模板导出

        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版本


        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>2.1.6</version>
        </dependency>

 2.excel模板:

 3.导出方法

@Log("导出财务数据")@ApiOperation("导出财务数据")@GetMapping(value = "/download")public void download(HttpServletResponse response) throws IOException {Demo2 otherInfo = new Demo2();otherInfo.setDate(new Date());//蔬菜信息List<Demo1> 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

一、导入依赖

<!--lombok-->
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId>
</dependency><!--操作excel工具包-->
<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.0.5</version>
</dependency>

二、根据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<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里的内容。

需要注意

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

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

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

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/8450.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ChatGPT 从入门到精通,联动Excel 的八种方法

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了人工智能中文站https://ai.weoknow.com 每天给大家更新可用的国内可用chatGPT资源 近期 AI 工具大爆发&#xff0c; 一天之内&#xff0c;AI 绘图两大神器之一的 Midjourney 中文版可申请试用了&#xff0c;ChatG…

网赚小项目,聊天挣钱,打字聊天就能挣钱的方法

大家好&#xff0c;我是蝶衣王的小编 你是不是也想利用你的空余时间赚点零花钱&#xff0c;但是又找不到很好的方法&#xff0c;网上这些小兼职呢&#xff0c;又容易被割了韭菜&#xff0c;今天我就教你们一个比较靠谱的网赚小方法&#xff0c;只需一部手机聊聊天就可以赚取佣…

够快,首个“开源ChatGPT项目“来了!网友吐槽:这谁能跑

文&#xff5c;明敏 源&#xff5c;量子位 就说程序员的手速有多快吧&#xff0c;首个开源ChatGPT项目已经出现了&#xff01; 基于谷歌语言大模型PaLM架构&#xff0c;以及使用从人类反馈中强化学习的方法&#xff08;RLHF&#xff09;&#xff0c;华人小哥Phillip Wang复刻了…

3 个令人眼前一亮的 ChatGPT 项目,开源了!

公众号关注 “GitHubDaily” 设为 “星标”&#xff0c;每天带你逛 GitHub&#xff01; 前不久&#xff0c;红杉资本提出了一个概念&#xff0c;叫 Developer Tool 2.0&#xff0c;很多传统的开发者工具&#xff0c;都值得基于 AI Copilot 能力&#xff0c;重新构建一遍。 目前…

五年时间,Transformer宇宙发展成了这样,ChatGPT 只是其中之一

源 | 机器之心 大家好&#xff0c;这里是 NewBeeNLP。关于 Transformer &#xff0c;这是一篇很好的学习指南&#xff0c;可以帮助你熟悉最流行的 Transformer 模型。 自 2017 年提出至今&#xff0c;Transformer 模型已经在自然语言处理、计算机视觉等其他领域展现了前所未有的…

GPT专业应用:英语作文修改与解释

正文共 868 字&#xff0c;阅读大约需要 3 分钟 英语学习者/老师必备技巧&#xff0c;您将在3分钟后获得以下超能力&#xff1a; 快速修改英语作文 Beezy评级 &#xff1a;B级 *经过简单的寻找&#xff0c; 大部分人能立刻掌握。主要节省时间。 推荐人 | Kim 编辑者 | Linda …

最新SpringBoot 整合 ChatGPT API 项目实战!!!

体验到了ChatGPT的强大之后&#xff0c;那么我们会想&#xff0c;如果我们想基于ChatGPT开发一个自己的聊天机器人&#xff0c;这个能搞定吗&#xff1f; ChatGPT平台已经为技术提供了一个入口了&#xff0c;很简单的就是实现了。 一、准备工作 &#xff08;1&#xff09;已…

使用宝塔面板的Docker安装ChatGPT-pandora项目

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了人工智能中文站https://ai.weoknow.com 每天给大家更新可用的国内可用chatGPT资源 本机以腾讯云 轻量云服务器为例。 首先在轻量云服务器后台的防火墙放行端口3002。 然后登陆宝塔&#xff0c;点击Docker&#xf…

SpringBoot 整合 ChatGPT API 项目实战,十分钟快速搞定!

往期热门文章&#xff1a; 1、10款低代码平台YYDS&#xff01; 2、使用 Autowired 为什么会被 IDEA 警告&#xff0c;应该怎么修改最佳&#xff1f; 3、每天 100 万次登陆请求&#xff0c;8G 内存该如何设置 JVM 参数&#xff1f; 4、12种接口优化的通用方案&#xff0c;我又偷…

chatgpt赋能python:Python的调试方法:如何看每一步的执行情况

Python的调试方法&#xff1a;如何看每一步的执行情况 Python是一门强大的编程语言&#xff0c;它易于学习&#xff0c;同时也被广泛应用于各种领域。当你在编写Python代码时&#xff0c;难免会遇到一些错误和问题。本文将介绍一些方法来调试Python代码&#xff0c;以帮助您更…

如何辨别ChatGPT是不是真的

随着ChatGPT爆红&#xff0c;国内陆续出现了几个所谓的“ChatGPT 反向代理站点”&#xff0c;乍一试回答似乎还挺靠谱&#xff0c;但它们真的是ChatGPT吗&#xff1f;本文以其中一个站点为例&#xff0c;对其真伪进行辨别。 其实最多只需要问两个问题&#xff0c;基本上就可以…

Excel到PPT动嘴就能做!ChatGPT4接入Office全家桶

微软把AI神器GPT-4全面接入Office&#xff0c;这下ChatPPT、ChatWord、ChatExcel一家整整齐齐。 CEO纳德拉在发布会上直接放话&#xff1a;今天&#xff0c;进入人机交互的新时代&#xff0c;重新发明生产力。 新功能名叫Microsoft 365 Copilot&#xff08;副驾驶&#xff09;&…

QQ 接入GPT,让聊天更自然

目录 0、文末点击公众号联系 1、先看效果 1.1 私聊&#xff1a; 1.2 群聊 2、下载文件 3、获取Api Key 4、Windows 封装版 4.1、进入py 文件夹。 4.2、打开 QBot 文件夹 5、代码版 5.1 进入 py 文件夹 5.1.1 安装依赖 5.1.2 启动 4.2、打开 QBot 文件夹 6、到此就…

我把ai聊天和绘画接入到了微信群

经过两天的努力&#xff0c;总算通过这种形式把ai聊天机器人接入到群聊中。挺有趣的&#xff0c;有没有测试下效果的。还可以画画哦。

在飞书上轻松集成ChatGPT,3步搞定!

在飞书上使用 ChatGPT&#xff0c;3步搞定 为了让用户更便捷地使用 ChatGPT&#xff0c;我们将 ChatGPT 集成到飞书&#xff0c;设置只需要几分钟。 步骤一&#xff1a;获取飞书 Webhook URL 在应用商店或点击飞书官网下载飞书。下载安装后进入飞书界面&#xff0c;点击上方➕…

ChatGPT 和知识策略,构建低成本的认知助手

ChatGPT 风靡全球!它无处不在。我的朋友不断向我发送 ChatGPT 所做的奇妙和意想不到的事情的例子。ChatGPT 在短短五天内就吸引了超过 100 万用户。 我对 ChatGPT 变得如此出色并不感到惊讶。但令我惊讶的是,在过去两个月中,人们对这些工具的认识有了惊人的增长。这鼓励我帮…

LangChain 基于 ChatGPT 构建本地知识库问答应用

一、使用本地知识库构建问答应用 上篇文章基于 LangChain 的Prompts 提示管理构建特定领域模型&#xff0c;如果看过应该可以感觉出来 ChatGPT 还是非常强大的&#xff0c;但是对于一些特有领域的内容让 GPT 回答的话还是有些吃力的&#xff0c;比如让 ChatGPT 介绍下什么是 L…

你想知道ChatGPT针对JAVA技术趋势等问题的答案不?

今天终于试了一下最近非常火的ChatGPT,针对JAVA技术趋势等问题与ChatGPT进行了沟通,感觉还挺好玩的,如同和一个人正常交流一样,问题的答案虽然不是很精准,但还算是正确的。 让人吃惊的是:ChatGPT 竟然都知道@EnumValue怎么使用 使用界面 问题及回复 问题: JAVA技术趋势…

吴恩达ChatGPT《Prompt Engineering》笔记

1. 课程介绍 1.1 ChatGPT 相关术语 LLM&#xff1a;Large Language Model&#xff0c;大语言模型 Instruction Tuned LLM&#xff1a;经过指令微调的大语言模型 Prompt&#xff1a;提示词 RLHF&#xff1a;Reinforcement Learning from Human Feedback&#xff0c;人类反馈…

ChatGPT 最佳实践指南之:使用外部工具

Use external tools 使用外部工具 Compensate for the weaknesses of GPTs by feeding them the outputs of other tools. For example, a text retrieval system can tell GPTs about relevant documents. A code execution engine can help GPTs do math and run code. If a …