使用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;
}
相关推荐
吾日三省吾码1 小时前
JVM 性能调优
java
弗拉唐2 小时前
springBoot,mp,ssm整合案例
java·spring boot·mybatis
oi772 小时前
使用itextpdf进行pdf模版填充中文文本时部分字不显示问题
java·服务器
少说多做3433 小时前
Android 不同情况下使用 runOnUiThread
android·java
知兀3 小时前
Java的方法、基本和引用数据类型
java·笔记·黑马程序员
蓝黑20203 小时前
IntelliJ IDEA常用快捷键
java·ide·intellij-idea
Ysjt | 深3 小时前
C++多线程编程入门教程(优质版)
java·开发语言·jvm·c++
shuangrenlong3 小时前
slice介绍slice查看器
java·ubuntu
牧竹子3 小时前
对原jar包解压后修改原class文件后重新打包为jar
java·jar