Springboot开发之 Excel 处理工具(二)-- Easyexcel

2024-06-21 22:44

本文主要是介绍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 {  @GetMapping("/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() + " 条数据");  
}

这篇关于Springboot开发之 Excel 处理工具(二)-- Easyexcel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082552

相关文章

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Springboot项目构建时各种依赖详细介绍与依赖关系说明详解

《Springboot项目构建时各种依赖详细介绍与依赖关系说明详解》SpringBoot通过spring-boot-dependencies统一依赖版本管理,spring-boot-starter-w... 目录一、spring-boot-dependencies1.简介2. 内容概览3.核心内容结构4.

Spring Boot 整合 SSE(Server-Sent Events)实战案例(全网最全)

《SpringBoot整合SSE(Server-SentEvents)实战案例(全网最全)》本文通过实战案例讲解SpringBoot整合SSE技术,涵盖实现原理、代码配置、异常处理及前端交互,... 目录Spring Boot 整合 SSE(Server-Sent Events)1、简述SSE与其他技术的对

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

MyBatis-Plus 与 Spring Boot 集成原理实战示例

《MyBatis-Plus与SpringBoot集成原理实战示例》MyBatis-Plus通过自动配置与核心组件集成SpringBoot实现零配置,提供分页、逻辑删除等插件化功能,增强MyBa... 目录 一、MyBATis-Plus 简介 二、集成方式(Spring Boot)1. 引入依赖 三、核心机制

Java高效实现Word转PDF的完整指南

《Java高效实现Word转PDF的完整指南》这篇文章主要为大家详细介绍了如何用Spire.DocforJava库实现Word到PDF文档的快速转换,并解析其转换选项的灵活配置技巧,希望对大家有所帮助... 目录方法一:三步实现核心功能方法二:高级选项配置性能优化建议方法补充ASPose 实现方案Libre

springboot整合mqtt的步骤示例详解

《springboot整合mqtt的步骤示例详解》MQTT(MessageQueuingTelemetryTransport)是一种轻量级的消息传输协议,适用于物联网设备之间的通信,本文介绍Sprin... 目录1、引入依赖包2、yml配置3、创建配置4、自定义注解6、使用示例使用场景:mqtt可用于消息发