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() 的结果差异会更刺眼——这点常被忽略。
