【EasyExcel】字段赋值错乱问题

背景:@ExcelProperty(value = "立木序号") private String number;没有导入成功,但是数据赋值到 @ApiModelProperty(value = "检尺类型") private String gaugeType;字段上了

问题: EasyExcel 导入时数据赋值错位:标注 "立木序号" 的number字段没拿到值,而本该赋给 "检尺类型" 的gaugeType字段却接收了 "立木序号" 的数据,核心原因是列名匹配混乱或列索引错位(其他字段正常说明全局导入逻辑无问题)

思考:

原因 1:列名重复 / 注解 value 写错(最常见)

这种错位本质是 EasyExcel 在匹配列名时 "找错了对象",常见场景:

  • Excel 中同时存在 "立木序号" 和 "检尺类型" 列,但gaugeType字段的@ExcelProperty注解value误写成了 "立木序号"(和number字段注解重复);

  • Excel 中列名有相似性(比如 "检尺类型" 列名被误写为 "立木序号"),导致 EasyExcel 把同一列数据匹配到了两个字段中,最终后匹配的字段覆盖 / 抢占了数据。

查看:核对两个字段的@ExcelProperty注解,确保value和 Excel 列名一一对应

原因 2:列索引错位(列名无错但顺序匹配错)

若 Excel 中列的顺序和实体类字段的 "默认匹配顺序" 不一致,且未指定index,EasyExcel 会按 "字段定义顺序" 匹配 "Excel 列顺序",导致错位:比如:

  • Excel 列顺序:立木序号(第 1 列)、检尺类型(第 2 列);

  • 实体类字段定义顺序:先gaugeType、后number;EasyExcel 会把第 1 列(立木序号)的数据赋给第一个字段gaugeType,第 2 列(检尺类型)赋给第二个字段number(若第 2 列无值则number为 null)。

解决:给每个字段指定index,但是我不想额外增加index固定死

核心解决方案:排除无需导入的字段

之所以出现数据错位赋值,是因为gaugeType字段虽然没写@ExcelProperty,但 EasyExcel 在 "按顺序匹配列" 时,仍会把列数据赋给未排除的字段;只需给gaugeType添加@ExcelIgnore注解,明确排除该字段的导入映射,就能让数据正确赋给number字段。

java 复制代码
import com.alibaba.excel.annotation.ExcelIgnore;
import com.alibaba.excel.annotation.ExcelProperty;
import io.swagger.annotations.ApiModelProperty;

public class YourEntity {
    // 立木序号:需要导入
    @ApiModelProperty(value = "立木序号")
    @ExcelProperty(value = "立木序号") 
    private String number;

    // 检尺类型:不需要导入,添加@ExcelIgnore排除映射(核心修改点)
    @ApiModelProperty(value = "检尺类型")
    @ExcelIgnore // 关键:告诉EasyExcel忽略该字段的导入/导出
    private String gaugeType;

    // 必须保留number字段的setter(之前确认过的核心要求)
    public void setNumber(String number) {
        this.number = number;
    }

    // gaugeType的setter可保留(不影响,因为已被@ExcelIgnore排除)
    public void setGaugeType(String gaugeType) {
        this.gaugeType = gaugeType;
    }

    // getter方法(方便调试查看值)
    public String getNumber() {
        return number;
    }

    public String getGaugeType() {
        return gaugeType;
    }
}

最终:导入正常赋值

相关推荐
28岁青春痘老男孩17 小时前
JDK8+SpringBoot2.x 升级 JDK 17 + Spring Boot 3.x
java·spring boot
方璧17 小时前
限流的算法
java·开发语言
元Y亨H17 小时前
Nacos - 服务注册
java·微服务
Hi_kenyon17 小时前
VUE3套用组件库快速开发(以Element Plus为例)二
开发语言·前端·javascript·vue.js
曲莫终17 小时前
Java VarHandle全面详解:从入门到精通
java·开发语言
一心赚狗粮的宇叔18 小时前
中级软件开发工程师2025年度总结
java·大数据·oracle·c#
奋进的芋圆18 小时前
DataSyncManager 详解与 Spring Boot 迁移指南
java·spring boot·后端
ghie909018 小时前
基于MATLAB GUI的伏安法测电阻实现方案
开发语言·matlab·电阻
Gao_xu_sheng18 小时前
Inno Setup(专业安装/更新 EXE)
开发语言