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

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;
}

业务代码

    @Overridepublic void importData(MultipartFile file) {//初始化实体Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);//声明并初始化inputStreamtry (InputStream inputStream = file.getInputStream()) {// 读取excelList<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();
    @Overridepublic void importData(MultipartFile file) {//初始化excel实体Map<String, AbstractMap.SimpleEntry<Integer, Class<?>>> sheetMap = initializeSheetMap();Map<Class<?>, List<Object>> entityMap = initializeEntityMap(sheetMap);ExcelReader excelReader = null;//声明并初始化inputStreamtry (InputStream inputStream = file.getInputStream()) {excelReader = EasyExcel.read(inputStream).build();// 读取excelList<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.mzph.cn/news/610993.shtml

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

相关文章

逐步分解,一文教会你如何用 jenkins+docker 实现主从模式

jenkins 主从模式想必大家都不陌生&#xff0c;大家在学习过程中为了学习方便都在自己本地搭建了 jenkins 环境&#xff0c;然后通过 javaweb 方式实现&#xff0c;对于 docker 下实现主从模式大家好像兴趣挺大。 今天就通过这篇文章给大家讲讲怎么玩&#xff0c;希望对大家有帮…

Vivado开发FPGA使用流程、教程 verilog(建立工程、编译文件到最终烧录的全流程)

目录 一、概述 二、工程创建 三、添加设计文件并编译 四、线上仿真 五、布局布线 六、生成比特流文件 七、烧录 一、概述 vivado开发FPGA流程分为创建工程、添加设计文件、编译、线上仿真、布局布线&#xff08;添加约束文件&#xff09;、生成比特流文件、烧录等步骤&a…

交叉编译ARM64架构electron详解

基本介绍 本文主要参考Electron官方文档中 构建说明 和 构建步骤(Linux) 在amd64环境内构建arm64的electron包。 如果是arm64环境请查看文章arm64架构编译electron长征路 一、环境说明 操作系统版本:统信1060 操作系统架构:amd64 内存:32G 如下图: electron版本:v25…

企业微信forMAC,如何左右翻动预览图片

1、control commandshifd 进入企业微信的debug调试模式 2、按照如下步骤选择 3、重启企业微信

全球再生环保趋势的热门项目GRS认证

GRS&#xff0c;最初由世优认证&#xff08;CU&#xff09;于2008年制定&#xff0c;并于2011年1月1日将所有权转让给了纺织品交易所TE。 自2017年7月1日GRS4.0版本开始生效。是为在纺织工业的需求所制定&#xff0c;核查回收产品或某些特定产品。更重要的是让零售商和消费者了…

【K8S 存储卷】K8S的存储卷+PV/PVC

目录 一、K8S的存储卷 1、概念&#xff1a; 2、挂载的方式&#xff1a; 2.1、emptyDir&#xff1a; 2.2、hostPath&#xff1a; 2.3、NFS共享存储&#xff1a; 二、PV和PVC&#xff1a; 1、概念 2、请求方式 3、静态请求流程图&#xff1a; 4、PV和PVC的生命周期 5、…

基于ubuntu2204使用kubeadm部署k8s集群

部署k8s集群 基础环境配置安装container安装runc安装CNI插件部署1.24版本k8s集群&#xff08;flannel&#xff09;安装crictl使用kubeadm部署集群节点加入集群部署flannel网络配置dashboard 本集群基于ubuntu2204系统使用kubeadm工具部署1.24版本k8s&#xff0c;容器运行时使用…

Unity | Shader基础知识(第九集:shader常用单词基础知识速成)

目录 一、顶点&#xff08;Vertex&#xff09;和法线(Normal) 二、UV信息 三、 基础数据种类 1 基础数据种类 2 基础数据数组 3 基础数据数组的赋值 4 对数据数组的调用 四、 基础矩阵 1 基础矩阵种类 2 对矩阵数组的调用 2.1对一个数据的调用 2.2对多个数据的调用 2…

js判断当前是否是企业微信环境,微信环境

前言&#xff1a; js判断当前是否是企业微信环境&#xff0c;微信环境 封装方法&#xff1a; function envjudge() {var isMobile window.navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBro…

关于frida定位无误却无法hook到加密方法的见解

一、HOOK不到问题 原先使用 frida -U APP名 -l .\hook.js 这种方法进行hook加密函数&#xff0c;不料始终hook不到&#xff0c;没反应。思考了一下&#xff0c;应该是该app有多个进程&#xff0c;使用上面hook的不是加密进程&#xff0c;古应当用进程pid办法进行hook 二、解决办…

机器之心 AI 技术--人工智能助力个性化视频实战经验分享(文末送书)

【清华社&机器之心】视频生成前沿研究与应用特别活动 在视频生成即将迎来技术和应用大爆发之际&#xff0c;为了帮助企业和广大从业者掌握技术前沿&#xff0c;把握时代机遇&#xff0c;机器之心AI论坛就将国内的视频生成技术力量齐聚一堂&#xff0c;共同分享国内顶尖力量…

华为云AI:轻松实现图像识别调用

文章目录 前言一、环境配置关键步骤 二、图像识别实例媒资图像标签名人识别 总结 前言 基于华为云AI服务和java使用SDK实现图像识别&#xff0c;主要以媒资图像标签和名人识别为例。 一、环境配置 Maven&#xff08;没有直接下载华为的SDK包&#xff0c;而是使用Maven安装依赖…

韩语翻译是怎么收费的

近年来&#xff0c;随着中韩交流的日益密切&#xff0c;韩语翻译在国内的需求呈现出不断增长的态势。无论是韩语笔译还是口译&#xff0c;其应用领域都非常广泛。那么&#xff0c;韩语翻译的价格是否高昂&#xff1f;翻译公司又是如何进行报价的呢&#xff1f; 在翻译领域&…

C2-3.3.2 机器学习/深度学习——数据增强

C2-3.3.2 数据增强 参考链接 1、为什么要使用数据增强&#xff1f; ※总结最经典的一句话&#xff1a;希望模型学习的更稳健 当数据量不足时候&#xff1a; 人工智能三要素之一为数据&#xff0c;但获取大量数据成本高&#xff0c;但数据又是提高模型精度和泛化效果的重要因…

图数据库Gremlin语法(1)| 图基本概念与操作

图数据库Gremlin语法&#xff08;1&#xff09;| 图基本概念与操作 文章目录 图数据库Gremlin语法&#xff08;1&#xff09;| 图基本概念与操作[TOC] 前言一、本章学习重点二、图基本概念三、图基本操作总结 前言 Gremlin语言是图数据库最主流的查询语言&#xff0c;是Apache…

SQL查询连续两个时间段,以Hadoop为例

1、原理&#xff1a; 要实现连续两个时间段的数据查询&#xff0c;网上有很多&#xff0c;我也转载了别人写得比较好的文章。但是最简便的方法是用最原始的方法&#xff0c;将相同数据查询两遍&#xff0c;关联后将两个时间段的数据放在一行。 select a.*,b.列1&#xff0c;b…

Java中的List: 理解与实践

在Java编程语言中&#xff0c;List是一种被广泛使用的集合类型&#xff0c;它提供了一种灵活的方式来存储和操作有序的元素序列。List是Java集合框架&#xff08;Java Collections Framework&#xff09;的一部分&#xff0c;是一个接口&#xff0c;提供了一系列标准的方法来对…

LeetCode_4_困难_寻找两个正序数组的中位数

文章目录 1. 题目2. 思路及代码实现&#xff08;Python&#xff09;2.1 二分查找2.2 划分数组 1. 题目 给定两个大小分别为 m m m 和 n n n 的正序&#xff08;从小到大&#xff09;数组 nums1 和 nums2。请你找出并返回这两个正序数组的 中位数 。 算法的时间复杂度应该为…

UCF101 数据集介绍与下载

一、介绍 UCF101 是一个现实动作视频的动作识别数据集&#xff0c;收集自YouTube&#xff0c;提供了来自101个动作类别的13320个视频。官方&#xff1a;https://www.crcv.ucf.edu/research/data-sets/ucf101/ 数据集名称&#xff1a;UCF-101&#xff08;2012&#xff09; 总视…

06、Kafka ------ 各个功能的作用解释(ISR 同步副本、非同步副本、自动创建主题、修改主题、删除主题)

目录 CMAK 各个功能的作用解释★ ISR副本 (同步副本&#xff09;★ 非同步副本★ 自动创建主题★ 修改主题★ 删除主题 CMAK 各个功能的作用解释 ★ ISR副本 (同步副本&#xff09; 简单来说 &#xff0c;ISR 副本 就是 Kafka 认为与 领导者副本 同步的副本。 ISR&#xff0…