使用EasyExcel时踩过的坑

目录

一、问题描述

使用EasyExcel读取文件数据时,出现数据无法读取情况。

二、使用EasyExcel的版本

xml 复制代码
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>easyexcel</artifactId>
  <version>3.0.5</version>
</dependency>

三、场景复现

使用了@Accessors(chain = true)(lombok.experimental.Accessors)注解导致无法读取excel文件中的数据。

读取对象定义如下:

java 复制代码
@Data
@Accessors(chain = true)
@EqualsAndHashCode
public class DemoDTO implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "编号")
    @ExcelProperty("编号")
    private String number;

    @ApiModelProperty(value = "名称")
    @ExcelProperty("名称")
    private String name;
}

读取逻辑如下:

java 复制代码
private List<DemoDTO> parseExcelFileData(MultipartFile multipartFile) {
        List<DemoDTO> demoDTOList = new ArrayList<>();
        // 创建临时文件
        File excelFile = FileUtil.createTempFile();
        try {
            // 文件转换
            multipartFile.transferTo(excelFile);
            Assert.notNull(excelFile, "文件不存在,请重新上传");

            EasyExcel.read(FileUtil.getInputStream(Objects.requireNonNull(excelFile))).sheet("Sheet1")
                    .head(DemoDTO.class)
                    .headRowNumber(1)
                    .registerReadListener(new AnalysisEventListener<DemoDTO>() {
                        @Override
                        public void invoke(DemoDTO data, AnalysisContext context) {
                            // 获取当前index
//                            Integer currentRowNum = context.readRowHolder().getRowIndex();
                            // 校验格式
                            if (BeanUtil.isNotEmpty(data)) {
                                demoDTOList.add(data);
                            }
                        }
                        @Override
                        public void doAfterAllAnalysed(AnalysisContext context) {
                            log.info("数据读取完毕");
                        }
                    }).doRead();
        } catch (Exception e) {
            log.error("文件解析失败", e);
        } finally {
            FileUtil.del(excelFile);
        }
        return demoDTOList;
    }

四、问题修复

定义的映射类中不能使用@Accessors(chain = true)(lombok.experimental.Accessors)注解。

java 复制代码
@Data
@EqualsAndHashCode
public class DemoDTO implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "编号")
    @ExcelProperty("编号")
    private String number;

    @ApiModelProperty(value = "名称")
    @ExcelProperty("名称")
    private String name;
}
相关推荐
想用offer打牌19 小时前
2025年总结:一个树苗倔强生长
java·后端·开源·go
a程序小傲20 小时前
国家电网面试被问:FactoryBean与BeanFactory的区别和动态代理生成
java·linux·服务器·spring boot·spring·面试·职场和发展
电商API&Tina20 小时前
Python请求淘宝商品评论API接口全指南||taobao评论API
java·开发语言·数据库·python·json·php
若鱼191920 小时前
SpringBoot4.0新特性-Resilience之失败重试
java·spring
摩西蒙20 小时前
业务监控和常用产品
java·大数据·人工智能
哪里不会点哪里.20 小时前
Spring 核心原理解析:它到底解决了什么问题?
java·后端·spring
qq_2546744120 小时前
Cisco Nexus 9504交换机上
java·linux·服务器
咕噜企业分发小米20 小时前
腾讯云在多云管理工具上如何实现合规性要求?
java·云计算·腾讯云
invicinble21 小时前
关于对后端开发工程师,在项目层面的基本需求与进阶方向
java
懒鸟一枚21 小时前
Java17新特性详解
java