Java中replaceAll去除不掉空格解决方案

时间:2025-02-15 21:04:23


项目场景:

解压解析一个上传的压缩包下的word,存入数据库



问题描述:

存入数据库某描述字段时发现有乱码 "?" 的存入,经排查后发现是一个空格导致的,于是想要把存储的内容进行去空格处理,使用replaceAll 发现去除无效!!!

String a = "17660号针对协调退车位费问题派单至北京首都创业集团有限公司。 此件为接派一体,请按照“接诉即办”工作要求处理。烦请贵单位参照诉求回复模版给予回复。模版为:承办单位+联系情况(联系来电人或联系网民)+问题的处理情况或答复口径。【特别提醒】请注意严格保护反映人信息!  ";
((" ", ""));



原因分析:

自己重新定义一个带有空格的字符串,是可以去除的,那么问题就可能是给出的字符串中的空格不是普通的空格,经过一系列的排查后,可以确定是因为该文档是html转的,去不掉的空格是html的一个转义符  



解决方案:

知道问题的后就好解决了,百度下  的ASCII值是160,我们常见的普通空格是32,怪不得去不掉,找一下160空格的正则,下面上代码:

("[\\s\\u00A0]", "")

这里面的\u00A0就是用于去除160这种空格的,而\s是用于去除普通空格,问题搞定!