easyExcel 获取多个sheet中复杂表头的数据

news/2024/7/21 7:51:49 标签: 开发语言, excel

easyExcel 获取多个sheet中复杂表头的数据

easyExcel 解释

EasyExcel是一个强大且易于使用的Java库,用于简化Excel文件的读写操作。它是阿里巴巴开源的一个基于POI实现的Excel处理工具,并提供了一组简单的API来处理Excel文件,包括读取、写入和转换。

EasyExcel的特点包括:

易于使用:EasyExcel提供了简单而直观的API,使得读取、写入和转换Excel文件变得容易。可以通过少量的代码实现复杂的Excel文件操作。

大数据量处理:EasyExcel对大数据量的处理进行了优化,支持高效读取和写入大型Excel文件,减少内存消耗和处理时间。

支持多种数据转换:EasyExcel支持将Excel文件与Java对象之间进行相互转换,可以方便地将Excel数据映射到Java对象,也可以将Java对象转换为Excel文件。

丰富的功能:EasyExcel提供了丰富的功能,包括支持读取和写入不同格式的Excel文件(例如xls和xlsx),支持读取和写入多个sheet,支持读取和写入复杂的Excel表头,支持数据校验等。

使用EasyExcel进行Excel操作通常包括以下步骤:

读取Excel文件:使用EasyExcel提供的API读取Excel文件,并将读取的数据映射到Java对象。

写入Excel文件:使用EasyExcel提供的API将Java对象数据写入Excel文件。

数据转换:使用EasyExcel提供的转换器功能,将Excel数据和Java对象之间进行相互转换。

总之,EasyExcel是一个功能强大且易于使用的Excel处理工具,它可以帮助开发人员更轻松地处理Excel文件,减少了代码量和开发时间。无论是处理大数据量还是进行数据转换,EasyExcel都是一个很好的选择。

实体

 @Data
public class HermalPowerRnterpriseVO {
	// index为excel中指定列(从0开始)
   @ExcelProperty(value = "名称", index = 0)
    private String name;
}

业务代码

    @Override
    public void importData(MultipartFile file) {
        //初始化实体
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();
        Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);
        //声明并初始化inputStream
        try (InputStream inputStream = file.getInputStream()) {
            // 读取excel
            List<ReadSheet> readSheetList = EasyExcel.read(inputStream).build().excelExecutor().sheetList();

            for (ReadSheet readSheet : readSheetList) {
                //读取特定Excel表格
                try (InputStream sheetInputStream = file.getInputStream()) {
                    AbstractMap.SimpleEntry<Integer, Class<?>> sheetInfo = sheetMap.get(readSheet.getSheetName());
                    if (sheetInfo != null) {
                        readSheet(sheetInputStream, sheetInfo.getKey(), sheetInfo.getValue(), entityMap.get(sheetInfo.getValue()));
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            // 输出读到的内容
            for (Map.Entry<Class<?>, List<Object>> entry : entityMap.entrySet()) {
                log.info(entry.getKey().getSimpleName() + ": " + JSON.toJSONString(entry.getValue()));
            }

        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    /**
     * 初始化sheet内容
     * XXX 为sheet的名称,0,1,2,3为指定的sheet下表
     */
    private Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> initializeSheetMap() {
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = new HashMap<>(16);
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(0, LoadVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(1, HermalPowerRnterpriseVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(2, HydropowerEnterpriseVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(3, CentralizedSceneryVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(4, NewEnergyStorageVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(5, PowerAggregatorVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(6, LoadAggregatorVO.class));
        sheetMap.put("XXX", new AbstractMap.SimpleEntry<>(7, AggregateBodyVO.class));
        return sheetMap;
    }

    /**
     * 初始化entity内容
     */
    private Map<Class<?>, List<Object>> initializeEntityMap(Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap) {
        Map<Class<?>, List<Object>> entityMap = new HashMap<>(16);
        for (Class<?> clazz : sheetMap.values().stream().map(AbstractMap.SimpleEntry::getValue).distinct().toArray(Class<?>[]::new)) {
            entityMap.put(clazz, new ArrayList<>());
        }
        return entityMap;
    }

    /**
     * 获取sheet数据
     */
    private void readSheet(InputStream inputStream, Integer sheetNum, Class<?> clazz, List<?> dataList) {
        EasyExcel.read(inputStream, clazz, new EasyExcelVOListener(dataList))
				//sheetNum为获取第几个sheet的数据
                .sheet(sheetNum)
                // 跳过表头
                .headRowNumber(2)
                .doRead();
    }
    

优化2.0

问题:版本1.0会生成临时文件(这是因为EasyExcel的底层,它使用了ZipFile来处理Excel文件,而未正确关闭ZipFile可能会导致资源泄漏),程序会走垃圾清除:Cleaning up unclosed ZipFile for archive
解决:使用 EasyExcel.read()方法的另一个重载,以关闭自动生成的临时文件。使用 ExcelReader 对象来替代
EasyExcel.read().build().excelExecutor().sheetList(),然后在 finally 块中调用 excelReader.finish() 来关闭和删除临时文件。

临时文件问题代码

 List<ReadSheet> readSheetList = EasyExcel.read(inputStream).build().excelExecutor().sheetList();
    @Override
    public void importData(MultipartFile file) {
        //初始化excel实体
        Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();
        Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);
        ExcelReader excelReader = null;
        //声明并初始化inputStream
        try (InputStream inputStream = file.getInputStream()) {
            excelReader = EasyExcel.read(inputStream).build();
            // 读取excel
            List<ReadSheet> readSheetList = excelReader.excelExecutor().sheetList();

            for (ReadSheet readSheet : readSheetList) {
                //读取特定Excel表格
                try (InputStream sheetInputStream = file.getInputStream()) {
                    AbstractMap.SimpleEntry<Integer, Class<?>> sheetInfo = sheetMap.get(readSheet.getSheetName());
                    if (sheetInfo != null) {
                        readSheet(sheetInputStream, sheetInfo.getKey(), sheetInfo.getValue(), entityMap.get(sheetInfo.getValue()));
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }

            // 输出读到的内容
            for (Map.Entry<Class<?>, List<Object>> entry : entityMap.entrySet()) {
                log.info(entry.getKey().getSimpleName() + ": " + JSON.toJSONString(entry.getValue()));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            if (excelReader != null) {
                excelReader.finish();
            }
        }
    }

http://www.niftyadmin.cn/n/5314833.html

相关文章

大创项目推荐 深度学习实现语义分割算法系统 - 机器视觉

文章目录 1 前言2 概念介绍2.1 什么是图像语义分割 3 条件随机场的深度学习模型3\. 1 多尺度特征融合 4 语义分割开发过程4.1 建立4.2 下载CamVid数据集4.3 加载CamVid图像4.4 加载CamVid像素标签图像 5 PyTorch 实现语义分割5.1 数据集准备5.2 训练基准模型5.3 损失函数5.4 归…

[力扣 Hot100]Day1 两数之和

考完研了秽土转生&#xff0c;开始刷一下LeetCode准备一下复试&#xff0c;我尽量每个工作日一更 题目描述 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设…

Redis 配置(二)

目录 redis 配置 Redis 主从复制 主从复制的作用 主从复制流程 搭建Redis 主从复制 Redis 哨兵模式 哨兵模式的作用 哨兵结构 故障转移机制 主节点的选举 搭建Redis 哨兵模式 Redis 群集模式 集群的作用 Redis集群的数据分片 Redis集群的主从复制模型 搭建R…

#Uniapp:uni-app中vue2生命周期--11个

uni-app中vue2生命周期 生命周期钩子描述H5App端小程序说明beforeCreate在实例初始化之后被调用 详情√√√created在实例创建完成后被立即调用 详情√√√beforeMount在挂载开始之前被调用 详情√√√mounted挂载到实例上去之后调用 详情 注意&#xff1a;此处并不能确定子组…

防火墙管理入门:Firewalld 与 UFW

防火墙在保护计算机安全方面扮演着至关重要的角色。在Linux系统中&#xff0c;Firewalld和UFW&#xff08;Uncomplicated Firewall&#xff09;是两个常见的防火墙管理工具。本文将介绍如何查看系统版本、了解防火墙状态以及如何关闭、开启防火墙。 一、Firewalld 与 UFW 的区…

蓝牙信标定位原理

定位原理&#xff1a;蓝牙信标的定位原理是基于RSSI蓝牙信号强度来做定位的。 根据应用场景不同&#xff0c;通过RSSI定位原理可分为两种定位方式 一、存在性定位 这种方式通常要求所需定位的区域安装一个蓝牙信标即可&#xff0c;手持终端扫描蓝牙信标信号&#xff0c;扫描…

C++ 获取每一行的数据 FetchRow() 用vector()实现

1、在LXData里面定义结构体 struct LXAPI LXData{const char* data 0;int size 0;}; 2、在LXMysql.h和LXMysql.cpp分别定义和编写代码 //获取一行数据std::vector<LXData>FetchRow(); std::vector<LXData> LXMysql::FetchRow(){std::vector<LXData>re;i…

java字符串常用方法day02

StringBuilder类 由于String是不变对象,每次修改内容都要创建新对象,因此String不适合做频繁修改操作.为了解决这个问题,java提供了StringBuilder类. package string;/*** 频繁修改字符串带来的性能损耗.*/ public class StringDemo2 {public static void main(String[] args…