使用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;
}
相关推荐
茂桑2 分钟前
MVCC(多版本并发控制)
java·开发语言·数据库
customer0817 分钟前
【开源免费】基于SpringBoot+Vue.JS医疗报销系统(JAVA毕业设计)
java·vue.js·spring boot·后端·开源
barcke26 分钟前
【深度解析】Java接入DeepSeek大模型:从零实现流式对话+多轮会话管理(完整项目实战) —— SpringBoot整合、API安全封装、性能优化全攻略
java·spring boot
zl97989938 分钟前
MybatisPlus-注解
java·spring·maven
杰九1 小时前
【环境配置】maven,mysql,node.js,vue的快速配置与上手
java·vue.js·spring boot·mysql·node.js·maven
wapicn991 小时前
‌挖数据平台对接DeepSeek推出一键云端部署功能:API接口驱动金融、汽车等行业智能化升级
java·人工智能·python·金融·汽车·php
逸狼2 小时前
【JavaEE进阶】Spring DI
java·开发语言
yonuyeung2 小时前
代码随想录算法【Day54】
java·数据结构·算法
敲上瘾2 小时前
基础dp——动态规划
java·数据结构·c++·python·算法·线性回归·动态规划