FastExcel的使用

前言

FastExcel 是一款基于 Java 的开源库,旨在提供快速、简洁且能解决大文件内存溢出问题的 Excel 处理工具。它兼容 EasyExcel,提供性能优化、bug 修复,并新增了如读取指定行数和将 Excel 转换为 PDF 的功能。

FastExcel 的主要功能

  • 高性能读写:FastExcel 专注于性能优化,能高效处理大规模 Excel 数据,显著降低内存占用。
  • 简单易用:提供简洁直观的 API,易于集成和使用。
  • 流式操作:支持流式读取,减少一次性加载大量数据的问题。
  • 读取指定行数:可以根据需求,只读取感兴趣的部分数据,提高数据处理效率。
  • Excel 转换为 PDF:支持直接将 Excel 文件转换为 PDF,满足多样化的文档输出需求。

FastExcel 的技术原理

  • 内存优化:基于流式读取技术,不需要一次性将整个 Excel 文件加载到内存中,逐行或逐块读取数据。
  • 事件驱动模型 :基于实现 ReadListener 接口处理读取操作。当读取到数据时,会触发接口中的方法,如 invoke 方法,支持开发者对每行数据进行即时处理。
  • 注解映射:用注解将 Excel 文件中的列与 Java 对象的属性进行映射。开发者能轻松地将 Excel 数据转换为 Java 对象,同时也支持反向操作,将 Java 对象写入 Excel。

代码结构如图所示

读取 Excel 文件

package cn.itcast.hotel.excel;

import cn.idev.excel.FastExcel;
import cn.idev.excel.context.AnalysisContext;
import cn.idev.excel.read.listener.ReadListener;
import cn.idev.excel.support.ExcelTypeEnum;
import com.alibaba.fastjson.JSON;

/**
 * 实现 ReadListener 接口,设置读取数据的操作
 */
public class ReadExcelDataListener implements ReadListener<DemoData> {

    @Override
    public void invoke(DemoData demoData, AnalysisContext analysisContext) {
        System.out.println("解析到一条数据" + JSON.toJSONString(demoData));
    }

    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        System.out.println("所有数据解析完成!");
    }

    public static void main(String[] args) {
        String fileName = "E:\\tools\\es\\hotel-admin\\src\\main\\resources\\excel\\demo.xlsx";
        System.out.println("File path: " + fileName);
        FastExcel.read(fileName, DemoData.class, new ReadExcelDataListener()).sheet().doRead();
    }
}

创建 /生成 Excel 文件

package cn.itcast.hotel.excel;

import cn.idev.excel.FastExcel;

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

public class WriteExcelDataListener {
    static List<DemoData> list = new ArrayList<>();

    public static List<DemoData> genData(int num) {
        for (int i = 0; i < num; i++) {
            DemoData demoData = new DemoData();
            demoData.setDate(202401 + "" + i);
            demoData.setDoubleData("日期" + i);
            demoData.setTitle("标题:" + i);
            list.add(demoData);
        }
        return list;
    }

    public static void main(String[] args) {
        List<DemoData> demoData = genData(10);
        String fileName = "E:\\tools\\es\\hotel-admin\\src\\main\\resources\\excel\\demo.xlsx";
        FastExcel.write(fileName, DemoData.class).sheet().doWrite(demoData);
    }
}

好了 至此 FastExcel的使用 点点关注不迷路 老铁们!!!!!

相关推荐
等一场春雨14 小时前
Alibaba Spring Cloud 十三 Nacos,Gateway,Nginx 部署架构与负载均衡方案
nginx·spring cloud·gateway
小白的一叶扁舟17 小时前
Nacos 2.5.0 全文详解及配置(并解决WebServerException: Unable to start mbedded Tomcat)
java·spring cloud·nacos
天使day1 天前
SpringCloud两种注册中心
java·spring·spring cloud
Mr.Demo.1 天前
[Spring] Gateway详解
java·spring·spring cloud·gateway
Cent'Anni2 天前
【Nacos】负载均衡
java·分布式·spring cloud·负载均衡
跟我很快乐2 天前
Docker搭建minio对象存储
spring cloud·docker·容器
ChinaRainbowSea2 天前
10. SpringCloud Alibaba Sentinel 规则持久化部署详细剖析
java·spring·spring cloud·sentinel·负载均衡
等一场春雨2 天前
Alibaba Spring Cloud 十七 Sentinel熔断降级
spring·spring cloud·sentinel
红衣女妖仙2 天前
分布式微服务系统简述
分布式·spring cloud·微服务·架构
等一场春雨2 天前
Alibaba Spring Cloud 六 Seata 的核心组件:RM
数据库·spring·spring cloud