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);
相关推荐
源代码•宸2 小时前
Golang原理剖析(interface)
服务器·开发语言·后端·golang·interface·type·itab
冬奇Lab2 小时前
【Kotlin系列09】委托机制与属性委托实战:组合优于继承的最佳实践
android·开发语言·kotlin
Vallelonga2 小时前
浅谈 Rust bindgen 工具
开发语言·rust
ElfBoard2 小时前
ElfBoard技术贴|如何在ELF-RK3506开发板上构建AI编程环境
c语言·开发语言·单片机·嵌入式硬件·智能路由器·ai编程·嵌入式开发
洲星河ZXH2 小时前
Java,泛型
java·开发语言·windows
木木木一2 小时前
Rust学习记录--C13 Part1 闭包和迭代器
开发语言·学习·rust
木木木一2 小时前
Rust学习记录--C13 Part2 闭包和迭代器
开发语言·学习·rust
Wcy30765190662 小时前
文件包含漏洞及PHP伪协议
开发语言·php
海南java第二人2 小时前
SpringBoot循环依赖全解:从根源到解决方案的深度剖析
java·spring