EasyExcel 导出排除基类字段,不给基类加@ExcelIgnore 的方式。

在使用 EasyExcel 进行数据导出时,如果实体类继承了包含审计字段(如 createBycreateTimeupdateTime 等)的基类,这些字段会默认被导出

假设你有如下基类:

java 复制代码
public class BaseEntity {
    private String createBy;
    private LocalDateTime createTime;
    private String updateBy;
    private LocalDateTime updateTime;
    // getter/setter...
}

业务实体继承它:

java 复制代码
public class UserDTO extends BaseEntity {
    private String name;
    private String email;
    // ...
}

常见的做法

给基类字段加 @ExcelIgnore

给基类加上@ExcelIgnore可以解决这个问题,或者增加excel相关的pojo类,但我不想这么做。侵入性强:污染了通用基类

手动硬编码排除字段

比如

java 复制代码
Set<String> exclude = Set.of("createBy", "createTime", "updateBy", "updateTime");
EasyExcel.write(...).excludeColumnFieldNames(exclude).doWrite(list);

我的解决方式:反射动态获取基类字段,自动排除

java 复制代码
import java.lang.reflect.Field;
import java.util.Arrays;
import java.util.Set;
import java.util.stream.Collectors;

public class ExcelExportUtils {

    /**
     * 获取指定类的所有字段名称(自动用于排除)
     * @param classes 要排除的类,例如 BaseEntity.class
     * @return 字段名称集合
     */
    public static Set<String> getExcludeFieldNames(Class<?>... classes) {
        return Arrays.stream(classes)
                .flatMap(clazz -> Arrays.stream(clazz.getDeclaredFields()))
                .map(Field::getName)
                .collect(Collectors.toSet());
    }
}

使用方式:

在导出逻辑中使用:

java 复制代码
// 查询数据
List<UserDTO> list = userService.queryExportData();

// 自动获取基类字段并排除
Set<String> excludeFields = ExcelExportUtils.getExcludeFieldNames(BaseEntity.class);

// 导出
EasyExcel.write(response.getOutputStream(), UserDTO.class)
        .excludeColumnFieldNames(excludeFields)
        .sheet("用户列表")
        .doWrite(list);
相关推荐
坚持就完事了7 分钟前
数据结构之树(Java实现)
java·算法
Monly2110 分钟前
Java:修改打包配置文件
java·开发语言
roman_日积跬步-终至千里11 分钟前
【架构设计与实现】动态数据源切换:核心代码实现手册
java
XiaoFan01219 分钟前
免密批量抓取日志并集中输出
java·linux·服务器
顾北1226 分钟前
MCP服务端开发:图片搜索助力旅游计划
java·spring boot·dubbo
我命由我1234532 分钟前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
赛姐在努力.34 分钟前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
yxc_inspire37 分钟前
Java学习第二天
java·面向对象
毕设源码-赖学姐39 分钟前
【开题答辩全过程】以 基于net超市销售管理系统为例,包含答辩的问题和答案
java
island131440 分钟前
CANN ops-nn 算子库深度解析:核心算子(如激活函数、归一化)的数值精度控制与内存高效实现
开发语言·人工智能·神经网络