strlen()统计字节数,将\n、\r各计1字节,\r\n计2字节;统计可见字符长需trim()预处理;查换行数用substr_count();含中文等多字节字符时须用mb_strlen()。

strlen() 会把换行符和回车符当做一个字符算
strlen() 统计的是字节数,不是“视觉上的字符数”。在 PHP 中,\n(LF)、\r(CR)或 \r\n(Windows 换行)都会被当作 1 或 2 个字节计入长度:
-
\n→ 1 字节 →strlen()返回 +1 -
\r→ 1 字节 →strlen()返回 +1 -
\r\n→ 2 字节 →strlen()返回 +2
比如:strlen("a\r\nb") 返回 4(a、\r、\n、b),不是 3。
想忽略换行回车只算“可见内容长度”?用 trim() + strlen() 组合
如果目标是判断用户输入的“实际文字长度”,不希望把开头/结尾的空白(含换行、制表、空格)算进去,得先清理:
-
strlen(trim($str, "\r\n\t " ))—— 显式指定要去除的字符 - 更稳妥写法:
strlen(trim($str)),因为trim()默认就处理\r、\n、\t、\0、\x0B和空格 - 注意:这只会去掉首尾,中间的换行仍会被
strlen()计入
要统计“有多少个换行符”?别用 strlen(),改用 substr_count()
如果需求是“这个字符串里有几个换行”,strlen() 完全不适用。正确方式是:
立即学习“PHP免费学习笔记(深入)”;
- 查
\n个数:substr_count($str, "\n") - 查
\r\n(Windows 风格)个数:substr_count($str, "\r\n") - 查所有回车或换行(粗略统计行数):
substr_count($str, "\n") + substr_count($str, "\r") - substr_count($str, "\r\n")(避免\r\n被重复计算)
直接对含 \r\n 的字符串用 substr_count($str, "\r") + substr_count($str, "\n") 会多算 1 次,这点容易错。
多字节字符(如中文)下 strlen() 失效,必须用 mb_strlen()
如果字符串含中文、emoji 或其他 UTF-8 多字节字符,strlen() 返回的是字节数,不是字符数。例如:strlen("你好") 返回 6(UTF-8 下每个汉字占 3 字节),但你通常想要的是 “2 个字符”。
- 统一用:
mb_strlen($str, 'UTF-8') - 它同样会把
\n、\r当作 1 个字符计数(因为它们在 UTF-8 中也是单字节) - 若不确定编码,加个检测:
mb_detect_encoding($str),但生产环境建议显式指定'UTF-8'
换行符本身不改变 mb_strlen() 的字符计数逻辑,但它和中文混在一起时,strlen() 和 mb_strlen() 的结果差异会更刺眼——这点常被忽略。











