JAVA:探索 EasyExcel 的技术指南

news2024/12/27 0:42:20

1、简述

在 Java 开发中,Excel 文件的读写操作是一项常见的需求。阿里巴巴开源的 EasyExcel 提供了一种高效、简洁的解决方案,特别是在处理大规模数据时表现尤为突出。本文将详细介绍 EasyExcel 的优缺点、应用场景,并通过实例展示其基本用法。

EasyExcel 官方文档
GitHub - EasyExcel

官网已停止维护

在这里插入图片描述

2、需求

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模式,在上层做了模型转换的封装,让使用者更加简单方便。

在这里插入图片描述

3、应用

EasyExcel 是一个用于读写 Excel 文件的开源 Java 库。与传统的 Apache POI 相比,EasyExcel 通过减少内存消耗、简化代码结构,使得处理 Excel 文件变得更加轻松,特别是在处理大文件时优势明显。

3.1 Maven 依赖

首先,在项目的 pom.xml 中添加 EasyExcel 的 Maven 依赖:

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>4.0.2</version>
</dependency>
3.2 写入 Excel 文件

以下代码展示了如何使用 EasyExcel 将数据写入到一个 Excel 文件中:

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.annotation.ExcelProperty;

import java.util.ArrayList;
import java.util.List;

public class EasyExcelWriteExample {
    public static void main(String[] args) {
        String fileName = "simpleWrite.xlsx";

        // 数据准备
        List<UserData> data = new ArrayList<>();
        data.add(new UserData(1, "Alice", "alice@example.com"));
        data.add(new UserData(2, "Bob", "bob@example.com"));

        // 写入数据到 Excel 文件
        EasyExcel.write(fileName, UserData.class).sheet("用户信息").doWrite(data);
    }
}

// 定义数据类
class UserData {
    @ExcelProperty("用户ID")
    private Integer id;

    @ExcelProperty("用户名")
    private String name;

    @ExcelProperty("邮箱")
    private String email;

    public UserData(Integer id, String name, String email) {
        this.id = id;
        this.name = name;
        this.email = email;
    }

    // Getters and Setters
}

代码解释:

  • UserData 类通过注解 @ExcelProperty 指定了 Excel 列名和属性的映射关系。
  • 使用 EasyExcel.write() 方法指定写入的文件名和数据类,然后通过 sheet() 方法指定工作表名称,最后调用 doWrite() 将数据写入 Excel 文件。
3.3 读取 Excel 文件

下面的代码展示了如何使用 EasyExcel 从 Excel 文件中读取数据:

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;

import java.util.ArrayList;
import java.util.List;

public class EasyExcelReadExample {
    public static void main(String[] args) {
        String fileName = "simpleWrite.xlsx";

        // 读取数据
        EasyExcel.read(fileName, UserData.class, new UserDataListener()).sheet().doRead();
    }
}

// 定义数据类(与写入时相同)
class UserData {
    @ExcelProperty("用户ID")
    private Integer id;

    @ExcelProperty("用户名")
    private String name;

    @ExcelProperty("邮箱")
    private String email;

    // Getters and Setters
}

// 定义读取时的监听器
class UserDataListener extends AnalysisEventListener<UserData> {
    private List<UserData> list = new ArrayList<>();

    @Override
    public void invoke(UserData data, AnalysisContext context) {
        System.out.println("读取到数据: " + data);
        list.add(data);
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        System.out.println("所有数据读取完成!");
    }
}

代码解释:

  • 读取操作使用 EasyExcel.read() 方法,指定要读取的文件名、数据类以及处理读取数据的监听器。
  • AnalysisEventListener 用于处理每一行读取到的数据,通过 invoke() 方法逐行处理数据,doAfterAllAnalysed() 方法在所有数据读取完成后执行。

4、场景

4.1 优点
  • 内存消耗低: EasyExcel 使用流式写入和 SAX 方式解析 Excel 文件,极大减少了内存使用,适合处理大数据量的 Excel 文件。
  • 代码简洁: EasyExcel 提供了简洁的 API,可以在几行代码内完成复杂的 Excel 操作,降低了开发和维护的成本。
  • 支持多种 Excel 格式: 支持 .xls 和 .xlsx 格式的读写操作。
  • 支持复杂的 Excel 模板: 可以处理带有图片、表格、合并单元格等复杂模板的 Excel 文件。
  • 社区活跃: 作为阿里巴巴的开源项目,EasyExcel 有着良好的社区支持和持续更新。
4.2 缺点
  • 功能覆盖面有限: 相比于 Apache POI,EasyExcel 主要聚焦于数据读写,缺乏对 Excel 文件内部结构的全面操作支持。
  • 较少的定制化支持: 在某些高级功能上,EasyExcel 的定制化能力较弱,例如复杂样式的设置。
  • 学习曲线: 对于熟悉 Apache POI 的开发者来说,EasyExcel 的 API 可能需要一定的适应时间。
4.3 应用场景
  • 大规模数据导出: 由于其低内存消耗的特点,EasyExcel 特别适合用于导出包含大量数据的 Excel 文件,如报表生成、数据备份等。
  • 轻量级 Excel 操作: 对于简单的数据导入导出任务,EasyExcel 提供了极简的 API,使得开发者可以快速实现功能。
  • 实时数据导出: 在需要实时生成并导出 Excel 的场景下,EasyExcel 可以在占用最小内存的情况下,高效完成任务。

5、 总结

EasyExcel 作为一种高效的 Excel 读写工具,在处理大规模数据时表现突出。其低内存消耗和简洁的 API 设计,使得开发者能够快速实现 Excel 文件的读写操作。然而,EasyExcel 也存在一些功能上的局限性,尤其是在需要复杂 Excel 操作时。因此,开发者应根据具体需求选择合适的工具。

通过这篇博客,希望你对 EasyExcel 的使用有了更清晰的理解,并能够在实际项目中有效应用。如果你有任何疑问或建议,欢迎在评论区交流讨论。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python自动化小技巧24——实现自动化输出模板表格报告

背景 很多人拿到数据excel文件&#xff0c;然后要写报告&#xff0c;做表格&#xff0c;要各种计算&#xff0c;各种排序&#xff0c;分组聚合&#xff0c;数据透视&#xff0c;然后合并单元格&#xff0c;添加边框&#xff0c;加粗&#xff0c;添加显示规则&#xff0c;添加数…

C# 通俗易懂的介绍基础知识(七)——栈Stack(从日常生活开始讲解)

目录 一、前言 二、栈是排列方式 三、栈的单词 四、程序中的栈 五、栈的方法 1.声明并初始化栈 2.往栈里放东西&#xff08;学名&#xff1a;入栈&#xff09; 3.从栈往外拿东西 &#xff08;学名&#xff1a;出栈&#xff09; 4.清空栈 5.遍历 Stack 6.获取Stack的长…

Vue全栈开发旅游网项目(10)-用户管理后端接口开发

1.异步用户登录\登出接口开发 1.设计公共响应数据类型 文件地址&#xff1a;utils/response404.py from django.http import JsonResponseclass BadRequestJsonResponse(JsonResponse):status_code 400def __init__(self, err_list, *args, **kwargs):data {"error_c…

PostgreSQL中如果有Left Join的时候索引怎么加

在PostgreSQL中&#xff0c;当你的查询包含多个LEFT JOIN和WHERE条件时&#xff0c;合理地添加索引可以显著提高查询性能。以下是一些具体的优化步骤和建议&#xff1a; 1. 分析查询 使用 EXPLAIN ANALYZE 命令分析你的查询&#xff0c;了解查询的执行计划&#xff0c;识别出连…

A027-基于Spring Boot的农事管理系统

&#x1f64a;作者简介&#xff1a;在校研究生&#xff0c;拥有计算机专业的研究生开发团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339; 赠送计算机毕业设计600…

Vue的基础使用

一、为什么要学习Vue 1.前端必备技能 2.岗位多&#xff0c;绝大互联网公司都在使用Vue 3.提高开发效率 4.高薪必备技能&#xff08;Vue2Vue3&#xff09; 二、什么是Vue 概念&#xff1a;Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套 构建用户界面 的 渐进式 框架…

Innovus Flexible H-tree and Multi-tap Clock Flow Lab实操系列教程(Day1)

我们都知道时钟树综合在数字IC后端实现中的重要性。做clock tree主要有传统clock tree做法&#xff0c;H tree&#xff0c;Flexible H-tree&#xff0c;fishbone等做法。接下去小编将拿cadence官方的这份Innovus Flexible H-tree and Multi-Tap Clock Flow和对应的lab data来做…

【MySQL】MySQL数据库安装以及报错处理技巧

前言&#xff1a; 本节内容讲述在Ubuntu环境下怎么进行MySQL的安装。 以及一些安装过程中遇到的报错如何处理的问题。 ps:注意&#xff0c; 本篇文章不是图形化界面的MySQL安装教程哦。想要安装图形化界面的MySQL的友友们可以另寻资源了。 目录 更新软件包列表 安装M…

ISP——你可以从这里起步(二)

接上一篇&#xff0c;上一篇是原理篇&#xff0c;这一篇是实战篇&#xff0c;为了实现下面框图中的不完美ISP。 第一章 做一张RAW图自己用 不是所有的人都能获得raw图&#xff0c;即使获得了raw图也需要对应的sensor参数才能把它用起来&#xff0c;所以我找了一条野路子可以把…

CTF攻防世界小白刷题自学笔记14

fileclude&#xff0c;难度&#xff1a;1&#xff0c;方向&#xff1a;Web 题目来源:CTF 题目描述:好多file呀&#xff01; 给一下题目链接&#xff1a;攻防世界Web方向新手模式第17题。 打开一看&#xff0c;这熟悉的味道&#xff0c;跟上一篇文章基本一摸一样的&#xff…

CTFHub每日练习

文章目录 技能树CTF Web信息泄露目录遍历PHPINFO备份文件下载网站源码bak文件vim缓存.DS_Store Git泄露Logstash index方法一方法二 密码口令弱口令 技能树 CTF Web 信息泄露 目录遍历 PHPINFO 备份文件下载 网站源码 当开发人员在线上环境中对源代码进行了备份操作&#x…

使用CNN进行验证码识别:深度学习与图像预处理教程

验证码&#xff08;CAPTCHA&#xff09;广泛用于区分人类和自动化程序&#xff08;如机器人&#xff09;&#xff0c;通常由扭曲的字母、数字或符号组成。为了实现验证码的自动识别&#xff0c;深度学习尤其是卷积神经网络&#xff08;CNN&#xff09;非常有效。本文将带你一起…

Springboot采用jasypt加密配置

目录 前言 一、Jasypt简介 二、运用场景 三、整合Jasypt 2.1.环境配置 2.2.添加依赖 2.3.添加Jasypt配置 2.4.编写加/解密工具类 2.5.自定义加密属性前缀和后缀 2.6.防止密码泄露措施 2.61.自定义加密器 2.6.2通过环境变量指定加密盐值 总结 前言 在以往的多数项目中&#xff0…

讯飞、阿里云、腾讯云:Android 语音合成服务对比选择

在 移动端 接入语音合成方面&#xff0c;讯飞和腾讯云等都是优秀的选择&#xff0c;但各有其特点和优势。咱们的需求是需要支持普通话/英语/法语三种语言&#xff0c;以下是对各个平台的详细比较&#xff1a; 一、讯飞语音合成介绍 与语音听写相反&#xff0c;语音合成是将一段…

python爬虫获得店铺的所有商品

在编写Python爬虫以获取店铺的所有商品信息时&#xff0c;通常涉及到发送HTTP请求、解析响应内容以及处理API返回的数据。以下是一个详细的Python爬虫示例&#xff0c;用于获取店铺的商品信息。这个示例假设API返回的是JSON格式的数据&#xff0c;并且需要API密钥进行认证。 步…

java程序打包及执行 jar命令及运行jar文件

java程序打包及执行 jar命令及运行jar文件 打包命令&#xff1a; 安装完成jdk之后采用 jar命令进行打包 jar -cvfe ddd.jar -C bin/ddd.java 打包 ddd.java 文件 jar -cvfe dddd.jar -C . 注意 -C 后面的点. 表示当前目录下所有 如图&#xff1a; 运行jar 文件 java -class…

计算机视觉空域处理完整版——超详细图文解

空域处理 图像空域处理 a.线性滤波b.非线性滤波c.二值图像处理方法 数学形态学连通成分标记 “点运算”是在不改变图像大小、几何形状以及局部结构的情况下&#xff0c;对像素值进行修改&#xff0c;新图像的像素值只与 原图像同一位置的像素值有关。 灰度级变换(线性变换,非…

【HarmonyOS】Hdc server port XXXX has been used.Configure environment variable

【HarmonyOS】Hdc server port XXXX has been used.Configure environment variable 一、 问题背景&#xff1a; 无法调试debug应用&#xff0c;IDE右下角显示该弹窗&#xff1a; Hdc server port XXXX has been used.Configure environment variable ‘OHOS_HDC_SERVER_POR…

立体工业相机提升工业自动化中的立体深度感知

深度感知对仓库机器人应用至关重要&#xff0c;尤其是在自主导航、物品拾取与放置、库存管理等方面。 通过将深度感知与各种类型的3D数据&#xff08;如体积数据、点云、纹理等&#xff09;相结合&#xff0c;仓库机器人可以在错综复杂环境中实现自主导航&#xff0c;物品检测…

深度解析:Android APP集成与拉起微信小程序开发全攻略

目录 一、背景以及功能介绍 二、Android开发示例 2.1 下载 SDK 2.2 调用接口 2.3 获取小程序原始Id 2.4 报错提示&#xff1a;bad_param 2.4.1 错误日志 2.4.2 解决方案 相关推荐 一、背景以及功能介绍 需求&#xff1a;产品经理需要APP跳转到公司的小程序(最好指定页…