最直接的方法是用str_replace(' ', '', $str)去半角空格再strlen();若需处理全角空格及所有空白符,应使用preg_replace('/\s+/u', '', $str)后strlen()。

用 strlen() + str_replace() 去空格再测长最直接
PHP 没有内置“忽略空格的字符串长度”函数,所以得手动先清理再计算。最稳妥的做法是用 str_replace(' ', '', $str) 去掉所有半角空格,再套 strlen()。注意它不处理全角空格、制表符或换行符,只针对 ASCII 空格。
常见错误是误用 trim() —— 它只删首尾空格,中间的还在,测出来还是偏长。
-
str_replace(' ', '', $str)快且明确,适合纯英文/数字+空格场景 - 如果字符串含中文、全角空格(U+3000)、
\t或\n,得改用preg_replace('/\s+/u', '', $str) -
mb_strlen()不能跳过空格,它只解决多字节字符计数问题,和“忽略空格”无关
要兼容全角空格和所有空白符?用 preg_replace() 配合 \s
\s 在 PCRE 中默认匹配空格、制表符、换行、回车、垂直制表、换页,加上 /u 修饰符后还能识别 Unicode 空白(包括全角空格)。这是真正“去所有空白再算长度”的方案。
示例:$len = strlen(preg_replace('/\s+/u', '', $str));
立即学习“PHP免费学习笔记(深入)”;
- 正则中用
+是为了把连续空白缩成一次替换,效率略高 - 不用
mb_系列函数做替换,因为preg_replace()加/u已支持 UTF-8 - 如果原字符串可能为
null或非字符串,记得先is_string($str)判断,否则preg_replace会警告
trim() + strlen() 是常见误解点
很多人以为 strlen(trim($str)) 就能“忽略空格”,其实它只影响开头和结尾。比如 "a b" 经 trim() 还是 "a b",strlen() 返回 5,不是 2。
这种写法只在你**只关心首尾是否有多余空格、但中间空格需保留计数**时才有意义 —— 和“忽略空格测长度”目标完全相反。
- 典型误用场景:表单提交后验证“用户昵称是否为空”,写了
if (strlen(trim($name)) === 0)—— 这是对的;但若想“昵称有效字符不能超10个”,就不能只trim -
ltrim()/rtrim()同理,作用范围更窄,别混淆
性能差异小,但大文本下正则稍慢,优先选 str_replace 简单场景
对普通表单字段或日志片段,两种方法耗时都可忽略。但如果批量处理上万条含大量空格的日志行,str_replace() 比 preg_replace() 快约 20%–30%,因为无正则引擎开销。
不过,如果业务逻辑本身就要处理各种空白(比如清洗用户输入),别为了这点性能牺牲健壮性 —— 直接上 /\s+/u 更省心。
真正容易被忽略的是编码一致性:确保源字符串是 UTF-8,否则 /u 修饰符会失效,全角空格可能被漏掉。读数据库或接收 POST 数据时,留意 mb_internal_encoding() 和实际编码是否匹配。











