Springboot开发之 Excel 处理工具(二)-- Easyexcel
一、Easyexcel 简介
EasyExcel是一个基于Java的Excel处理工具库,它的核心设计理念是快速、简洁,并且能够有效解决处理大文件时的内存溢出问题。使用EasyExcel,开发者可以在几乎不需要考虑性能和内存消耗的情况下,轻松实现Excel文件的读写操作。
- Easyexcel 官方文档:
https://easyexcel.opensource.alibaba.com/docs/current/ - github地址:
https://github.com/alibaba/easyexcel - gitee地址:
https://gitee.com/easyexcel/easyexcel
二、为何选择 Easyexcel
1. 现有框架的问题
- Apache POI 和 jxl: 这两个Java框架用于解析和生成Excel文件,但它们的主要问题是内存消耗大。
- 内存溢出问题: 处理大型Excel文件时,这些框架可能会消耗大量内存,导致内存溢出。
2. Apache POI 的局限性
- SAX模式: Apache POI 提供了SAX模式的API来部分解决内存问题,但仍然存在不足。
- 内存消耗: 即使使用SAX模式,Apache POI 在处理Excel 2007版(.xlsx)文件时,由于解压缩和存储过程在内存中进行,内存消耗依然很大。
3. EasyExcel 的优势
- 重写解析: EasyExcel 重写了Apache POI对Excel 2007版的解析方式,显著降低了内存消耗。
- 内存优化: 一个3MB的Excel文件在使用Apache POI的SAX模式解析时可能需要约100MB内存,而EasyExcel可以将内存需求降低到几MB。
- 大文件处理: 使用EasyExcel,即使更大的Excel文件也不会导致内存溢出。
- 03版Excel处理: 对于Excel 2003版(.xls),EasyExcel依赖于Apache POI的SAX模式,并在此基础上进行了模型转换封装,使得使用更加简单和方便。
三、Springboot 项目集成 EasyExcel
1. pom 文件引入依赖:
<dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.1.0</version> <!-- 请检查并使用最新版本 -->
</dependency>
2. 实体类(例如 UserData)
import com.alibaba.excel.annotation.ExcelProperty; public class UserData { @ExcelProperty(value = "ID", index = 0) private Integer id; @ExcelProperty(value = "姓名", index = 1) private String name; @ExcelProperty(value = "年龄", index = 2) private Integer age; // 省略 getter 和 setter 方法 // ...
}
3. EasyExcel 操作帮助类
import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.excel.read.builder.ExcelReaderBuilder;
import com.alibaba.excel.read.builder.ExcelReaderSheetBuilder;
import com.alibaba.excel.write.builder.ExcelWriterBuilder;
import com.alibaba.excel.write.builder.ExcelWriterSheetBuilder;
import com.alibaba.excel.write.metadata.WriteSheet; import org.springframework.web.multipart.MultipartFile; import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; public class EasyExcelUtils { // 导出 Excel public static byte[] exportExcel(List<?> data, String sheetName, Class<?> head) { try (ByteArrayOutputStream out = new ByteArrayOutputStream()) { ExcelWriterBuilder writerBuilder = EasyExcel.write(out, head); ExcelWriterSheetBuilder sheetBuilder = writerBuilder.sheet(sheetName); WriteSheet writeSheet = sheetBuilder.build(); EasyExcel.write(out, data, writeSheet).finish(); return out.toByteArray(); } catch (IOException e) { throw new RuntimeException("导出 Excel 失败", e); } } // 导入 Excel public static <T> List<T> importExcel(MultipartFile file, Class<T> clazz) { try (InputStream inputStream = file.getInputStream()) { ExcelReaderBuilder readerBuilder = EasyExcel.read(inputStream, clazz, new AnalysisEventListener<T>() { private List<T> list = new ArrayList<>(); @Override public void invoke(T data, AnalysisContext context) { list.add(data); } @Override public void doAfterAllAnalysed(AnalysisContext context) { // 数据解析完成后,可以在这里处理解析结果 } }); ExcelReaderSheetBuilder sheetBuilder = readerBuilder.sheet(); sheetBuilder.doRead(); return list; } catch (IOException e) { throw new RuntimeException("导入 Excel 失败", e); } } // 其他可能需要的帮助方法...
}
4. 在 Controller 中使用
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile; import java.util.Arrays;
import java.util.List; @RestController
public class ExcelController { @PostMapping("/exportExcel") public ResponseEntity<byte[]> exportExcel() { List<UserData> data = Arrays.asList( new UserData(1, "Alice", 25), new UserData(2, "Bob", 30), new UserData(3, "Charlie", 35)String fileName = "users.xlsx"; byte[] excelBytes = EasyExcelUtils.exportExcel(data, fileName, UserData.class); HttpHeaders headers = new HttpHeaders(); headers.setContentDispositionFormData("attachment", fileName); headers.setContentType(MediaType.APPLICATION_OCTET_STREAM); return ResponseEntity.ok() .headers(headers) .body(excelBytes); } @PostMapping("/importExcel") public ResponseEntity<?> importExcel(@RequestParam("file") MultipartFile file) { List<UserData> userDataList = EasyExcelUtils.importExcel(file, UserData.class); // 假设你需要在这里处理导入的数据,比如保存到数据库等 // ... return ResponseEntity.ok("Excel 导入成功,共导入 " + userDataList.size() + " 条数据");
}
四、前端 vue 页面调用示例
<script>
import axios from 'axios'; export default { // ... 其他选项和数据 ... methods: { exportExcel() { // 假设你有一个要发送到服务器的对象(如果需要的话) const params = { // 例如: filter: 'someValue' }; axios({ method: 'post', url: '/api/exportExcel', // 修改为你的实际API地址 data: params, // 如果需要的话 responseType: 'blob', // 告诉axios我们期望返回一个blob }) .then((response) => { // 创建一个Blob对象来表示二进制数据 const blob = new Blob([response.data], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }); // 创建一个指向该Blob对象的URL const url = window.URL.createObjectURL(blob); // 创建一个a标签并模拟点击来下载文件 const link = document.createElement('a'); link.href = url; link.setAttribute('download', 'users.xlsx'); // 设置下载文件名 document.body.appendChild(link); link.click(); // 清理 window.URL.revokeObjectURL(url); document.body.removeChild(link); }) .catch((error) => { console.error('导出Excel失败:', error); this.message = '导出Excel失败'; }); }, // ... 其他方法 ... },
};
</script>
相关文章:
Springboot开发之 Excel 处理工具(二)-- Easyexcel
一、Easyexcel 简介 EasyExcel是一个基于Java的Excel处理工具库,它的核心设计理念是快速、简洁,并且能够有效解决处理大文件时的内存溢出问题。使用EasyExcel,开发者可以在几乎不需要考虑性能和内存消耗的情况下,轻松实现Excel文…...
6月27日云技术研讨会 | 中央集中架构新车型功能和网络测试解决方案
会议摘要 “软件定义汽车”新时代下,整车电气电气架构向中央-区域集中式发展已成为行业共识,车型架构的变革带来更复杂的整车功能定义、更多的新技术的应用(如SOA服务化、TSN等)和更短的车型研发周期,对整车和新产品研…...
微信小程序生命周期
微信小程序的生命周期包括两个主要部分:应用生命周期和页面生命周期。下面我将详细介绍它们的具体内容。 应用生命周期 onLaunch: 触发时机:小程序初始化完成时(全局只触发一次)。 用途:通常用于进行一些…...
【JS重点15】原型对象概述
目录 一:构造函数缺陷 二:原型 1 原型是是什么 2 原型对象的作用 3 原型对象this指向问题 4 利用原型对象添加方法 给JS内置构造函数Array添加最大值方法 给JS内置构造函数Array添加求和方法 三:Constructor属性 四:如何…...
Java之Hutool/Guava/Apache Commons工具包项目实践
概述 Hutool是一个Java工具包,提供了丰富的工具类和方法,目的是简化开发任务提高开发效率;适用于需要快速开发和实现多种功能的场景,适合项目需要处理字符串、日期、文件等常见任务时~ toBeBetterJavaer/docs/common-tool/StringUtils.md at master itwanger/toBeBetterJavae…...
哈喽GPT-4o——对GPT-4o 提示词的思考与看法
目录 一、提示词二、常用的提示词案例1、写作助理2、改写为小红书风格3、英语翻译和改写4、论文式回答5、主题解构6、提问助手7、Nature风格润色8、结构总结9、编程助手10、充当终端/解释器 大家好,我是哪吒。 最近,ChatGPT在网络上广受欢迎,…...
《计算机英语》 Unit 3 Software Engineering 软件工程
Section A Software Engineering Methodologies 软件工程方法论 Software development is an engineering process. 软件开发是一个工程过程。 The goal of researchers in software engineering is to find principles that guide the software development process and lea…...
2024-6-18(沉默Spring,Springboot)
1.Spring小结 我们最后再来体会一下用 Spring 创建对象的过程: 通过 ApplicationContext 这个 IoC 容器的入口,用它的两个具体的实现子类,从 class path 或者 file path 中读取数据,用 getBean() 获取具体的 bean instance。 那…...
Java热部署:让应用更新如丝般顺滑,告别繁琐重启!
目录 手动启动热部署 自动启动热部署 参与热部署监控的文件范围配置 关闭热部署 什么是热部署?简单说就是你程序改了,现在要重新启动服务器,嫌麻烦?不用重启,服务器会自己悄悄的把更新后的程序给重新加载一遍&…...
微信小程序毕业设计-小区疫情防控系统项目开发实战(附源码+论文)
大家好!我是程序猿老A,感谢您阅读本文,欢迎一键三连哦。 💞当前专栏:微信小程序毕业设计 精彩专栏推荐👇🏻👇🏻👇🏻 🎀 Python毕业设计…...
PyTorch -- RNN 快速实践
RNN Layer torch.nn.RNN(input_size,hidden_size,num_layers,batch_first) input_size: 输入的编码维度hidden_size: 隐含层的维数num_layers: 隐含层的层数batch_first: True 指定输入的参数顺序为: x:[batch, seq_len, input_size]h0:[batc…...
SpringBoot 快速入门(保姆级详细教程)
目录 一、Springboot简介 二、SpringBoot 优点: 三、快速入门 1、新建工程 方式2:使用Spring Initializr创建项目 写在前面: SpringBoot 是 Spring家族中的一个全新框架,用来简化spring程序的创建和开发过程。SpringBoot化繁…...
【第18章】Vue实战篇之登录界面
文章目录 前言一、数据绑定1. 数据绑定2. 数据清空 二、表单校验1. 代码2. 展示 三、登录1.登录按钮2.user.js3. login 四、展示总结 前言 上一章完成用户注册,这一章主要做用户登录。 一、数据绑定 登录和注册使用相同的数据绑定 1. 数据绑定 <!-- 登录表单 -…...
[C++]使用C++部署yolov10目标检测的tensorrt模型支持图片视频推理windows测试通过
【测试通过环境】 vs2019 cmake3.24.3 cuda11.7.1cudnn8.8.0 tensorrt8.6.1.6 opencv4.8.0 【部署步骤】 获取pt模型:https://github.com/THU-MIG/yolov10训练自己的模型或者直接使用yolov10官方预训练模型 下载源码:https://github.com/laugh12321/yol…...
分享uniapp + Springboot3+vue3小程序项目实战
分享uniapp Springboot3vue3小程序项目实战 经过10天敲代码,终于从零到项目测试完成,一个前后端分离的小程序实战项目学习完毕 时间从6月12日 到6月22日,具有程序开发基础,第一次写uniapp,Springboot以前用过,VUE3也…...
Ubuntu 24.04安装zabbix7.0.0图形中文乱码
当zabbix安装完成后,设置中文界面时,打开图形,中文内容会显示方框乱码,是因为服务器字体中没有相关的中文字体,需要更换。 1、找到中文字体,可以在网络上下载《得意黑》开源字体,也可以在windo…...
MybatisPlus 调用 原生SQL
方式一 DemoMapper.java Mapper public interface DemoMapper extends BaseMapper<TableConfig> {Update("${sql}")int createTable(Param("sql") String sql); }测试代码 SpringBootTest class DemoMapperTest {Resourceprivate DemoMapper demo…...
1.SG90
目录 一.实物图 二.原理图 三.简介 四.工作原理 一.实物图 二.原理图 三.简介 舵机(英文叫Servo),是伺服电机的一种,伺服电机就是带有反馈环节的电机,这种电机可以进行精确的位置控制或者输出较高的扭矩。舵机…...
【yolov8语义分割】跑通:下载yolov8+预测图片+预测视频
1、下载yolov8到autodl上 git clone https://github.com/ultralytics/ultralytics 下载到Yolov8文件夹下面 另外:现在yolov8支持像包一样导入,pip install就可以 2、yolov8 语义分割文档 看官方文档:主页 -Ultralytics YOLO 文档 还能切…...
基于STM8系列单片机驱动74HC595驱动两个3位一体的数码管
1)单片机/ARM硬件设计小知识,分享给将要学习或者正在学习单片机/ARM开发的同学。 2)内容属于原创,若转载,请说明出处。 3)提供相关问题有偿答疑和支持。 为了节省单片机MCU的IO口资源驱动6个数码管&…...
YOLOv8训练Visidron小目标检测数据集YOLO训练结果模型➕数据集可直接使用在读博士,欢迎打扰
YOLOv8训练Visidron小目标检测数据集 YOLO训练结果模型➕数据集 可直接使用 在读博士,欢迎打扰...
Qwen3.6-Plus 全面解析:性能提升、API 接入与 Claude Code 实战配置
点击下方“JavaEdge”,选择“设为星标”第一时间关注技术干货!本文已收录在Github,关注我,紧跟本系列专栏文章,咱们下篇再续!🚀 魔都架构师 | 全网30W技术追随者🔧 大厂分布式系统/数…...
nlp_structbert_sentence-similarity_chinese-large 与传统方法对比:TF-IDF、Word2Vec与深度语义模型
nlp_structbert_sentence-similarity_chinese-large 与传统方法对比:TF-IDF、Word2Vec与深度语义模型 1. 引言 在中文文本处理的世界里,判断两句话是不是一个意思,一直是个挺有意思的挑战。比如,“今天天气真好”和“今日阳光明…...
Qwen3.5-9B Visio图表描述生成:从文本到系统架构图的自动构思
Qwen3.5-9B Visio图表描述生成:从文本到系统架构图的自动构思 1. 引言:架构设计的效率革命 想象一下这样的场景:你正在会议室里和团队讨论一个新项目的系统架构。白板上画满了各种方框和连线,但总觉得不够系统化。回到工位后&am…...
OpenClaw调试技巧:Qwen3-4B任务失败排查与优化
OpenClaw调试技巧:Qwen3-4B任务失败排查与优化 1. 为什么我们需要系统化的调试方法 上周我尝试用OpenClaw对接Qwen3-4B模型来自动处理日报生成任务时,遇到了一个典型问题:模型能正常返回响应,但Agent却总是卡在"解析响应&q…...
手把手教你用PyTorch复现Qwen2.5的GQA:从MHA到GQA的代码演进与性能对比
从零实现Qwen2.5的GQA机制:PyTorch实战与性能深度剖析 当我们在讨论现代大语言模型的高效推理时,注意力机制的优化始终是核心议题。Qwen2.5采用的Grouped Query Attention(GQA)既不是对传统多头注意力(MHA)的简单改良,也不是多查询注意力(MQA…...
GitHub Desktop中文汉化工具:轻松将官方客户端变成中文界面
GitHub Desktop中文汉化工具:轻松将官方客户端变成中文界面 【免费下载链接】GitHubDesktop2Chinese GithubDesktop语言本地化(汉化)工具 【GitHub桌面客户端中文汉化】 项目地址: https://gitcode.com/gh_mirrors/gi/GitHubDesktop2Chinese 还在为GitHub De…...
Go 网关模式:让业务逻辑和外部服务“保持距离“的艺术
🎬 场景小剧场 想象一下:你的电商系统要接支付功能。如果直接在 order 包里写 stripe.Charge(),明天老板说"换支付宝",你就要满世界改代码 😫 网关模式就是给业务逻辑装个"万能插座":不…...
SEO_影响搜索引擎排名的关键SEO因素分析
SEO:影响搜索引擎排名的关键SEO因素分析 在当今信息爆炸的时代,网站的流量和曝光度直接决定了一个品牌的市场竞争力。搜索引擎优化(SEO)是提升网站在搜索结果中排名的重要手段。本文将从多个角度分析影响搜索引擎排名的关键SEO因…...
DVWA-Chinese安全实践指南:从环境搭建到漏洞攻防
DVWA-Chinese安全实践指南:从环境搭建到漏洞攻防 【免费下载链接】DVWA-Chinese DVWA全汉化版本 项目地址: https://gitcode.com/gh_mirrors/dv/DVWA-Chinese 价值定位:为什么选择DVWA-Chinese作为安全学习平台 合法可控的漏洞实验场 Web安全学…...
