Excel 读取阶段就去掉换行

非常好 ✅

如果你想在 Excel 读取阶段就去掉换行 (即数据在进入 Java 实体类或 Map 之前就被清洗),

可以通过 EasyPOI 的自定义数据处理器 IExcelDataHandler 来实现。


🚀 实现思路

IExcelDataHandler 是 EasyPOI 提供的一个接口,

允许你在每个单元格被解析时,对值进行二次处理。

你可以拦截所有字符串字段,去掉换行、回车和多余空格。


✅ 实现步骤

第 1 步:定义自定义处理器

java 复制代码
import cn.afterturn.easypoi.handler.inter.IExcelDataHandler;

public class CleanLineBreakHandler implements IExcelDataHandler<Object> {

    @Override
    public Object importHandler(Object obj, String name, Object value) {
        if (value instanceof String) {
            // 去掉所有换行符、回车符,并去除首尾空格
            String cleaned = ((String) value)
                    .replaceAll("[\\r\\n]+", " ")  // 将换行符替换为空格
                    .replaceAll("\\s+", " ")       // 多个空格合并为一个
                    .trim();
            return cleaned;
        }
        return value;
    }

    @Override
    public String[] getNeedHandlerFields() {
        // null 表示处理所有字段
        return null;
    }
}

💡 说明:

  • 如果只想处理部分字段,可以返回字段名数组:

    java 复制代码
    return new String[]{"name", "remark"};
  • 返回 null 表示处理所有列。


第 2 步:在导入时设置该处理器

java 复制代码
ImportParams params = new ImportParams();
params.setDataHandler(new CleanLineBreakHandler());

List<MyExcelVO> dataList = ExcelImportUtil.importExcel(
        file.getInputStream(),
        MyExcelVO.class,
        params
);

💡 此时,所有字符串字段在导入时就会自动清除换行符,不需要再手动遍历清洗。


第 3 步(可选):Map 模式导入同样适用

java 复制代码
ImportParams params = new ImportParams();
params.setDataHandler(new CleanLineBreakHandler());

List<Map<String, Object>> dataList = ExcelImportUtil.importExcel(
        file.getInputStream(),
        Map.class,
        params
);

✅ 效果演示

Excel 原始值 处理后结果
"张三\n李四" "张三 李四"
"地址\r\n深圳市南山区" "地址 深圳市南山区"
" 多个 空格 " "多个 空格"

是否希望我帮你再加上一个完整的 Spring Boot Controller 示例(上传 Excel → 自动去换行 → 返回 JSON)?

可以直接复制运行。

相关推荐
骆驼爱记录3 小时前
Word通配符技巧:高效文档处理指南
开发语言·c#·自动化·word·excel·wps·新人首发
AI刀刀3 小时前
豆包怎么生成excel
ai·excel·豆包·deepseek·ds随心转
骆驼爱记录4 小时前
Word表格题注自动设置全攻略
开发语言·c#·自动化·word·excel·wps·新人首发
天荒地老笑话么5 小时前
Vim核心快捷键与运维实战指南
运维·vim·excel
开开心心就好1 天前
键盘改键工具免安装,自定义键位屏蔽误触
java·网络·windows·随机森林·计算机外设·电脑·excel
fqbqrr1 天前
2601Mfc,自动化excel
自动化·excel·mfc
tlwlmy1 天前
python excel图片批量导出
开发语言·python·excel
TracyDemo2 天前
excel 透视图怎么进行删除透视图
excel
骆驼爱记录2 天前
Excel邮件合并嵌入图片技巧
自动化·word·excel·wps·新人首发
avi91112 天前
Unity Data Excel读取方法+踩坑记;和WPS Excel的一些命令
unity·游戏引擎·excel·wps·data