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);
相关推荐
彭于晏Yan4 分钟前
OkHttp 与 RestTemplate 技术选型对比
java·spring boot·后端·okhttp
jzlhll1235 分钟前
Kotlin 协程高级用法之 NonCancellable
android·开发语言·kotlin
金銀銅鐵14 分钟前
[Java] 如何理解 class 文件中字段的 descriptor?
java·后端
5008418 分钟前
Graph Engine 是什么,为什么需要它
java·人工智能·性能优化·ocr·wpf
我是唐青枫18 分钟前
C#.NET YARP + OpenTelemetry:网关链路追踪实战
开发语言·c#·.net
芯芯点灯20 分钟前
gd32f303烧录提示Flash Timeout. Reset the Target and try it again.;
开发语言·前端·javascript
未若君雅裁21 分钟前
服务雪崩、降级、熔断与服务保护
java·微服务
枫叶丹424 分钟前
【HarmonyOS 6.0】Enterprise Space Kit:空间管理服务深入解析
开发语言·华为·harmonyos
就叫_这个吧39 分钟前
Java实现线程间的通讯--使用synchronized关键字和JUC方式实现
java·开发语言