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)?

可以直接复制运行。

相关推荐
用户2986985301414 小时前
C#: 高效移动与删除Excel工作表
后端·.net·excel
缺点内向1 天前
Java: 如何在Excel中添加或删除分页符?
java·excel
不想上班的小吕1 天前
SAP EXCEL模板下载导入
excel·sap
向日葵同志443301 天前
使用@univerjs纯前端渲染excel, 显示图片、链接、样式
前端·react.js·excel
Smile_2542204181 天前
nodered 下载 excel 文件
node.js·excel
办公解码器1 天前
Excel怎么检测录入身份信息的准确性?
excel
CodeCraft Studio2 天前
国产化Excel处理控件Spire.XLS教程:如何使用 Java 将 TXT 文本转换为 Excel 表格
java·word·excel·spire·文档格式转换·txt转excel
测试老哥2 天前
python+requests+excel 接口测试
自动化测试·软件测试·python·测试工具·测试用例·excel·接口测试
屹奕3 天前
基于EasyExcel实现Excel导出功能
java·开发语言·spring boot·excel
我只会写Bug啊3 天前
Vue文件预览终极方案:PNG/EXCEL/PDF/DOCX/OFD等10+格式一键渲染,开源即用!
前端·vue.js·pdf·excel·预览