

新闻资讯
技术学院最直接去掉所有空格应使用re.sub(r'\s+', '', s),因str.replace(' ', '')仅处理半角空格,无法识别制表符、换行符及全角空格等Unicode空白字符。
想彻底清除字符串里的空格(包括开头、中间、结尾),str.replace() 是最直观的选择。它不区分空格位置,只要匹配就替换。
注意:str.replace(' ', '') 只去掉半角空格 ' ',对制表符 '\t'、换行符 '\n'、全角空格等无效。
s.replace(' ', '') 即可s.replace(' ', '').replace('\t', '').replace('\n', '').replace('\r', ''),或更稳妥地用正则str.replace() 返回新字符串,原字符串不变 —— Python 字符串不可变写成 ''.join(s.split()) 看似简洁,但它行为不同:先用 str.split() 按任意空白切分(丢弃所有空白),再拼接。结果是不仅去空格,还把
连续空格、制表符、换行全抹掉,且自动 strip 首尾。
这在清洗用户输入时有用,但若原始格式需保留非空格分隔符(比如字符串里有 'a b\tc',你只想删空格、留 \t),就不能用这个组合。
s.split() 默认以任意空白为分隔符,包括 ' '、'\t'、'\n'、'\r'
''.join(s.split()) 等价于先 s.strip().replace(' ', '').replace('\t', '').replace('\n', '')...,但更短split()+join 比多次 replace() 略快;但可读性差一点,容易误以为只是“去空格”真实场景中,空格可能不是你以为的那个空格。比如从网页复制的文本常含全角空格 ' '(Unicode U+3000),replace(' ', '') 完全无效。
repr(s),看是否出现 '\u3000' 或其他 Unicode 空白字符import re; re.sub(r'\s+', '', s) —— \s 匹配所有 Unicode 空白(含全角空格、不间断空格 \xa0 等)s 可能是 None,直接调 .replace() 会报 AttributeError,务必先判空:s if s is None else s.replace(' ', '')
bytes 对象(比如从文件读出未解码),不能用字符串方法,得用 b.replace(b' ', b'')
import res = " hello\tworld python\xa0" # 含空格、\t、全角空格、不间断空格 print(repr(s)) # ' hello\tworld\u3000python\xa0'
正确清除所有空白
clean = re.sub(r'\s+', '', s) print(clean) # 'helloworldpython'
真正麻烦的不是选 replace() 还是 join(),而是没意识到“空格”本身就有好几种 —— 不检查 repr(),光靠肉眼和 .replace(' ', '') 很容易漏掉。