解决EasyPoi导入Excel获取不到第一列的问题

2024-04-17 05:44

本文主要是介绍解决EasyPoi导入Excel获取不到第一列的问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1. 复现错误
  • 2. 分析错误
    • 2.1 导入的代码
    • 2.2 DictExcel实体类
    • 2.2 表头和标题
  • 3. 解决问题

1. 复现错误


使用EasyPoi导入数据时,Excel表格如下图:

在这里插入图片描述

但在导入时,出现如下错误:

在这里插入图片描述

name为英文名称,在第一列,Excel表格有值,但导入的代码中为null,就很奇怪?

2. 分析错误

2.1 导入的代码


因涉及公司代码,暂时就不贴出全部代码,只贴出部分问题的代码:

@Overridepublic void importExcel(WorkspaceUser user, MultipartFile file, Boolean coverFlag) {try {//【1】首先判断是不是空的文件if (file.isEmpty()) {throw new RuntimeException(IMPORT_EMPTY);}//【2】检查文件格式...//【3】设置EasyPoi参数ImportParams params = new ImportParams();//【3.1】设置标题params.setTitleRows(0);//【3.2】设置表头params.setHeadRows(2);//【3.3】导入数据List<DictExcel> dictExcels = ExcelImportUtil.importExcel(file.getInputStream(), DictExcel.class, params);//【4】检查是否存在导入数据......//【5】检查是否存在数据问题......} catch (Exception e) {log.error("error on import test excel", e);throw new RuntimeException(e);}}

2.2 DictExcel实体类

@Data
@ExcelTarget("dictExcel")
public class DictExcel {@Excel(name = "*英文缩写")private String abbreviation;@Excel(name = "英文名称")private String name;@Excel(name = "*中文名称")private String cnName;@Excel(name = "描述")private String description;
}

2.2 表头和标题


以上代码咋一看没有问题,进而分析Excel的表头和标题:

在这里插入图片描述

在有标题时,titleRows设置1,如果没有,设置 0 或者不设置(默认是0)。

因而,上述代码:

  1. params.setTitleRows(0);不对,应该是params.setTitleRows(1);,标题设置一行

  2. params.setHeadRows(2);不对,应该是params.setHeadRows(1);,表头设置一行

3. 解决问题

  1. params.setTitleRows(0);修改为是params.setTitleRows(1);,即标题设置一行

  2. params.setHeadRows(2);修改为params.setHeadRows(1);,即表头设置一行

//省略代码......
ImportParams params = new ImportParams();
//标题设置一行
params.setTitleRows(1);
//表头设置一行
params.setHeadRows(1);
//省略代码......

重新导入数据:

在这里插入图片描述

这篇关于解决EasyPoi导入Excel获取不到第一列的问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/910934

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

C#实现将Excel工作表拆分为多个窗格

《C#实现将Excel工作表拆分为多个窗格》在日常工作中,我们经常需要处理包含大量数据的Excel文件,本文将深入探讨如何在C#中利用强大的Spire.XLSfor.NET自动化实现Excel工作表的... 目录为什么需要拆分 Excel 窗格借助 Spire.XLS for .NET 实现冻结窗格(Fro

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

使用Python实现高效复制Excel行列与单元格

《使用Python实现高效复制Excel行列与单元格》在日常办公自动化或数据处理场景中,复制Excel中的单元格、行、列是高频需求,下面我们就来看看如何使用FreeSpire.XLSforPython... 目录一、环境准备:安装Free Spire.XLS for python二、核心实战:复制 Exce