最直接去掉所有空格应使用re.sub(r'\s+', '', s),因str.replace(' ', '')仅处理半角空格,无法识别制表符、换行符及全角空格等Unicode空白字符。

str.replace() 去掉所有空格最直接
想彻底清除字符串里的空格(包括开头、中间、结尾),str.replace() 是最直观的选择。它不区分空格位置,只要匹配就替换。
注意:str.replace(' ', '') 只去掉半角空格 ' ',对制表符 '\t'、换行符 '\n'、全角空格等无效。
- 如果确定只有 ASCII 空格,用
s.replace(' ', '')即可 - 若需处理多种空白字符,推荐改用
s.replace(' ', '').replace('\t', '').replace('\n', '').replace('\r', ''),或更稳妥地用正则 -
str.replace()返回新字符串,原字符串不变 —— Python 字符串不可变
join() + split() 会连带压缩多个空格并删首尾
写成 ''.join(s.split()) 看似简洁,但它行为不同:先用 str.split() 按任意空白切分(丢弃所有空白),再拼接。结果是不仅去空格,还把连续空格、制表符、换行全抹掉,且自动 strip 首尾。
这在清洗用户输入时有用,但若原始格式需保留非空格分隔符(比如字符串里有 'a b\tc',你只想删空格、留 \t),就不能用这个组合。
立即学习“Python免费学习笔记(深入)”;
-
s.split()默认以任意空白为分隔符,包括' '、'\t'、'\n'、'\r' -
''.join(s.split())等价于先s.strip().replace(' ', '').replace('\t', '').replace('\n', '')...,但更短 - 性能上,对超长字符串,
split()+join比多次replace()略快;但可读性差一点,容易误以为只是“去空格”
别踩这些坑:全角空格、None、bytes 类型
真实场景中,空格可能不是你以为的那个空格。比如从网页复制的文本常含全角空格 ' '(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(' ', '') 很容易漏掉。










