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

可以直接复制运行。

相关推荐
向宇it1 天前
php高性能的导出excel读写扩展——xlswriter,比传统的Spreadsheet要快很多
php·excel·xlswriter
yanweijie03171 天前
对比VLOOKUP、XLOOKUP、INDEX+MATCH三大查找函数
excel
Codiggerworld1 天前
Vim的语法:删除、复制、粘贴,像说话一样自然
编辑器·vim·excel
Pentane.1 天前
【数据分析 | 农业项目】蔬菜类商品的自动定价与补货决策 | Tableau & Excel
数据挖掘·数据分析·excel·tableau
happy_baymax1 天前
Simulink 端口自动生成工具 (v2.1)(EXCEL+m语言)
服务器·matlab·excel·simulink
SunnyDays10111 天前
如何使用 C# 高效实现 Excel 与 CSV 的互相转换
c#·excel·csv
热爱生活的五柒1 天前
excel的使用教程
excel
城数派1 天前
2025年我国省市县三级的平均坡度数据(Excel\Shp格式)
arcgis·信息可视化·数据分析·excel
大佬,救命!!!2 天前
etp中未运行用例顺序的定位及补齐脚本自动化生成
python·学习笔记·excel·自动化脚本·用例整理清洗
专职2 天前
cursor中与vim插件冲突时的配置
编辑器·vim·excel