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

可以直接复制运行。

相关推荐
啊哈哈哈哈啊有17 小时前
导出树形结构,excel
java·windows·excel
Dxy123931021621 小时前
Elasticsearch 聚合入门:像 Excel 透视表一样分析数据
elasticsearch·excel
一位代码1 天前
Excel | .xls 与 .xlsx 文件的区别及使用 Excel 打开 CSV 文件出现乱码的解决办法
excel
CodeCraft Studio1 天前
Excel处理控件Aspose.Cells教程:使用C#在Excel中创建树状图
前端·c#·excel·aspose·c# excel库·excel树状图·excel sdk
悟能不能悟1 天前
vue导出excel文件
前端·vue.js·excel
CodeCraft Studio1 天前
国产化Excel开发组件Spire.XLS教程:以Python编程方式在Excel中高亮重复值
开发语言·python·excel·spire.xls·excel自动化·excel高亮重复值·python处理excel
喝汽水的猫^2 天前
Java实现Excel 导出(多 Sheet、复杂格式)
java·excel
小费的部落2 天前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel
缺点内向2 天前
如何在 C# 中重命名 Excel 工作表并设置标签颜色
开发语言·c#·excel
wtsolutions2 天前
Sheet-to-Doc: Automate Document Generation with Excel Data and Word Templates
word·excel·wtsolutions