Spring Boot整合Easy Excel

Spring Boot整合Easy Excel

什么是Easy Excel?

EasyExcel是一个基于Java的、快速、简洁、解决大文件内存溢出的Excel处理工具。

他能让你在不用考虑性能、内存的等因素的情况下,快速完成Excel的读、写等功能。

Spring Boot 整合 Easy Excel

添加依赖

xml 复制代码
<dependency>
	<!-- 根据最新版本进行修改 -->
    <dependency>
    	<groupId>com.alibaba</groupId>
	    <artifactId>easyexcel</artifactId>
        <version>3.3.2</version>
    </dependency>
        <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>easyexcel-core</artifactId>
        <version>3.3.2</version>
    </dependency>
</dependency>

读取excel

java 复制代码
public static List<ExcelData> readExcel(String url, int sheetNo) {
        List<ExcelData> dataList = new ArrayList<>(); // 存储读取的Excel数据列表

        // Excel 文件路径
        String excelFilePath = url;

        // 使用 EasyExcel 读取 Excel 文件,并指定要读取的 sheet
        EasyExcel.read(excelFilePath, ExcelData.class, new ExcelDataListener(dataList))
                .excelType(ExcelTypeEnum.XLSX)
                .sheet(sheetNo - 1) // sheet 索引从0开始,所以需要减1
                .doRead();

        return dataList;
    }

写入excel

java 复制代码
public static void writeToExcel(List<?> dataList, String filePath, String sheetName, Class<?> clazz) {
        ExcelWriter excelWriter = null;
        try {
            // 创建 ExcelWriter 对象,并指定 Excel 文件路径
            excelWriter = EasyExcel.write(filePath, clazz).build();

            // 创建 WriteSheet 对象,并指定 Excel 工作表名称
            WriteSheet writeSheet = EasyExcel.writerSheet(sheetName).build();

            // 将数据写入 Excel 文件
            excelWriter.write(dataList, writeSheet);
        } finally {
            // 关闭 ExcelWriter 对象,释放资源
            if (excelWriter != null) {
                excelWriter.finish();
            }
        }
    }

参考文献

官方文档

相关推荐
大阿明7 小时前
Spring Boot(快速上手)
java·spring boot·后端
哆啦A梦15888 小时前
Springboot整合MyBatis实现数据库操作
数据库·spring boot·mybatis
墨香幽梦客8 小时前
API集成技术规范:RESTful与GraphQL在企业系统对接中的应用对比
后端·restful·graphql
星轨zb9 小时前
通过实际demo掌握SpringSecurity+MP中的基本框架搭建
数据库·spring boot·spring security·mp
刀法如飞10 小时前
AI编程时代,为什么35岁以上程序员会更吃香?
人工智能·后端·ai编程
小码哥_常10 小时前
Spring Boot 遇上 HMAC-SHA256,API 安全大升级!
后端
小码哥_常10 小时前
10分钟极速掌握!SpringBoot+Vue3整合SSE实现实时消息推送
后端
大黄说说11 小时前
深入 Go 语言 GMP 调度模型:高并发的秘密武器
后端
云原生指北12 小时前
Omnipub E2E 测试文章 - 自动化验证
后端
IT_陈寒12 小时前
SpringBoot自动配置揭秘:5个让开发效率翻倍的隐藏技巧
前端·人工智能·后端