使用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;
}
相关推荐
大模型玩家七七3 小时前
基于语义切分 vs 基于结构切分的实际差异
java·开发语言·数据库·安全·batch
寻星探路8 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
曹牧10 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
爬山算法11 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
kfyty72511 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎11 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄11 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿11 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds11 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化