FastExcel使用详解

server/2025/2/3 22:15:30/

文章目录

  • FastExcel使用详解
    • 一、引言
    • 二、环境准备与依赖引入
      • 1、Maven 依赖引入
      • 2、实体类定义
    • 三、核心操作:读写 Excel
      • 1、读取 Excel
        • 1.1 自定义监听器
        • 1.2 读取文件
      • 2、写入 Excel
        • 2.1 简单写入
        • 2.2 模板写入
    • 四、Spring Boot 集成示例
      • 1、文件上传(导入)
      • 2、文件下载(导出)
    • 五、总结

FastExcel使用详解

在这里插入图片描述

一、引言

FastExcel 是由原 EasyExcel 作者维护的高性能 Excel 处理库,专注于解决大规模数据读写时的内存溢出问题。它兼容 EasyExcel 的 API,同时新增了流式处理、读取指定行数、Excel 转 PDF 等功能,适用于企业级数据导入导出、报表生成等场景。本文将从环境配置、核心功能到实际应用示例,详细解析 FastExcel 的使用方法。


二、环境准备与依赖引入

1、Maven 依赖引入

pom.xml 中添加以下依赖:

<dependency><groupId>cn.idev.excel</groupId><artifactId>fastexcel</artifactId><version>1.1.0</version>
</dependency>

2、实体类定义

通过 @ExcelProperty 注解实现 Excel 列与 Java 对象的映射:

@Data
public class User {@ExcelProperty("编号")private Integer id;@ExcelProperty("姓名")private String name;@ExcelProperty("年龄")private Integer age;
}

说明:使用 @Data(Lombok 注解)自动生成 Getter/Setter,简化代码。


三、核心操作:读写 Excel

1、读取 Excel

FastExcel 通过 事件监听器 实现流式读取,避免内存溢出。

1.1 自定义监听器
public class UserReadListener implements ReadListener<User> {private List<User> dataList = new ArrayList<>();@Overridepublic void invoke(User user, AnalysisContext context) {dataList.add(user); // 逐行处理数据}@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {System.out.println("共读取 " + dataList.size() + " 条数据");}
}
1.2 读取文件
String fileName = "users.xlsx";
FastExcel.read(fileName, User.class, new UserReadListener()).sheet().doRead();

2、写入 Excel

2.1 简单写入
List<User> users = new ArrayList<>();
users.add(new User(1, "张三", 25));
users.add(new User(2, "李四", 30));FastExcel.write("output.xlsx").sheet("用户列表").head(User.class).doWrite(users);
2.2 模板写入

若需复杂格式,可基于模板填充数据:

try (ExcelWriter writer = FastExcel.write("output.xlsx").withTemplate("template.xlsx").build()) {FillConfig fillConfig = FillConfig.builder().forceNewRow(true).build();writer.fill(users, fillConfig, writerSheet);
}

四、Spring Boot 集成示例

1、文件上传(导入)

@PostMapping("/upload")
public ResponseEntity<String> upload(@RequestParam("file") MultipartFile file) {try {UserReadListener listener = new UserReadListener();FastExcel.read(file.getInputStream(), User.class, listener).sheet().doRead();return ResponseEntity.ok("导入成功,数据量:" + listener.getDataList().size());} catch (IOException e) {return ResponseEntity.status(500).body("导入失败");}
}

2、文件下载(导出)

@GetMapping("/download")
public void download(HttpServletResponse response) throws IOException {response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setHeader("Content-Disposition", "attachment;filename=users.xlsx");List<User> users = userService.listAll(); // 假设从数据库获取数据FastExcel.write(response.getOutputStream(), User.class).sheet("用户数据").doWrite(users);
}

五、总结

FastExcel 凭借其 高性能流式处理简洁的 API,成为处理大规模 Excel 数据的首选工具。相比传统库(如 Apache POI),其内存占用更低,特别适合百万级数据的导入导出。

适用场景

  • 企业级数据报表生成
  • 批量数据导入数据库
  • 高并发环境下的 Excel 处理

版权声明:本博客内容为原创,转载请保留原文链接及作者信息。

参考文章

  • Spring Boot3集成FastExcel实现高效Excel操作 (附源码)
  • fastexcel读写Excel - CSDN博客

http://www.ppmy.cn/server/164724.html

相关文章

深入浅出并查集(不相交集合实现思路)

引言 并查集&#xff08;Disjoint Set Union&#xff0c;简称DSU&#xff09;是一种用于处理一些不交集的合并及查询问题。它主要支持两种操作&#xff1a;查找&#xff08;Find&#xff09;和合并&#xff08;Union&#xff09;。 查找&#xff1a;确定某个元素属于哪一个子…

XML DOM 解析器

大多数浏览器都内建了供读取和操作 XML 的 XML 解析器。 解析器把 XML 转换为 JavaScript 可存取的对象&#xff08;XML DOM&#xff09;。 XML 解析器 XML DOM 包含了遍历 XML 树&#xff0c;访问、插入及删除节点的方法&#xff08;函数&#xff09;。 然而&#xff0c;在…

LeetCode题练习与总结:在系统中查找重复文件--609

一、题目描述 给你一个目录信息列表 paths &#xff0c;包括目录路径&#xff0c;以及该目录中的所有文件及其内容&#xff0c;请你按路径返回文件系统中的所有重复文件。答案可按 任意顺序 返回。 一组重复的文件至少包括 两个 具有完全相同内容的文件。 输入 列表中的单个…

20250128 大语言模型(Large Language Model, LLM)已成为自然语言处理(NLP)领域的重要突破

大语言模型分析报告 一、引言 随着人工智能技术的不断进步&#xff0c;大语言模型&#xff08;Large Language Model, LLM&#xff09;已成为自然语言处理&#xff08;NLP&#xff09;领域的重要突破。这些模型通过大规模语料数据的预训练&#xff0c;具备理解和生成人类语言…

JS面相对象小案例:自定义安全数组

在JS中&#xff0c;数组不像其他语言&#xff08;java、python&#xff09;中那样安全&#xff0c;它具有动态性和弱类型性&#xff0c;切越界访问没有具体的报错&#xff0c;而是返回空&#xff0c;为提升数组的安全性&#xff0c;我们可以自行定义一个安全数组。 一、增加报…

【Leetcode刷题记录】45. 跳跃游戏 II--贪心算法

45. 跳跃游戏 II 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向后跳转的最大长度。换句话说&#xff0c;如果你在 nums[i] 处&#xff0c;你可以跳转到任意 nums[i j] 处: 0 < j < nums[i]i j < n 返回到达 num…

Spring Boot基本项目结构

要写一个Spring Boot 项目对于新手小白来说&#xff0c;首先要了解Spring Boot 的基本架构&#xff0c;学会如何创建一个简单的spring boot项目。 springboot 基于maven做的&#xff08;前提保证maven是装好并且IDEA配置好的&#xff09;&#xff08;面向接口编程&#xff09;…

C# 操作符重载对象详解

.NET学习资料 .NET学习资料 .NET学习资料 一、操作符重载的概念 在 C# 中&#xff0c;操作符重载允许我们为自定义的类或结构体定义操作符的行为。通常&#xff0c;我们熟悉的操作符&#xff0c;如加法&#xff08;&#xff09;、减法&#xff08;-&#xff09;、乘法&#…