使用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;
}
相关推荐
白仑色16 分钟前
在 Java 中操作 Map时,高效遍历和安全删除数据
java·开发语言·安全
Mr_hwt_12324 分钟前
基于nacos和gateway搭建微服务管理平台详细教程
java·spring boot·spring cloud·微服务·nacos
weixin_4383354044 分钟前
Spring RestTemplate + MultiValueMap vs OkHttp 多值参数的处理
java·spring·okhttp
chengchong_cc1 小时前
java IDEA 引用第三方的jar包
java·intellij-idea·jar
forestsea1 小时前
Maven多模块项目架构设计:聚合、继承与依赖治理
java·maven
码递夫1 小时前
Java在IDEA中终端窗口输出正常,但打包成JAR后中文乱码问题
java·jar·idea
伊成1 小时前
idea使用技巧分享
java·ide·intellij-idea
码码不爱我1 小时前
报错:Maven无法解析插件 org.apache.maven.plugins:maven-surefire-plugin:3.0.0
java·数据库·maven
ggdpzhk1 小时前
不用idea,记事本写helloworld
java·ide·intellij-idea
BillKu1 小时前
Java + Spring Boot + MyBatis 枚举变量传递给XML映射文件做判断
java·spring boot·mybatis