0

0

php判断字符串长度包含换行符吗_php换行符计数说明【技巧】

看不見的法師

看不見的法師

发布时间:2026-01-28 14:19:10

|

899人浏览过

|

来源于php中文网

原创

strlen() 计算字符串字节数,包含换行符;mb_strlen() 按字符计数,换行符仍计入;需显式清理换行符才能排除其影响。

php判断字符串长度包含换行符吗_php换行符计数说明【技巧】

strlen() 计算字符串长度时包含换行符

strlen() 统计的是字节数,不是字符数,所有字节都会被计入,包括 \n\r\r\n 这些换行相关字节。比如:

echo strlen("a\nb"); // 输出 3:'a'(1字节) + '\n'(1字节) + 'b'(1字节)

在 Windows 下若用双引号写 "a\r\nb"strlen() 会返回 4;Linux/macOS 下 "a\nb" 是 3。

  • 换行符在 ASCII 中是单字节:\n = 0x0A(1 字节),\r = 0x0D(1 字节)
  • 文件读入时换行符保留原样,fgets()file_get_contents() 都不会自动过滤
  • 如果从表单或 textarea 接收文本,用户按 Enter 输入的极大概率就是 \n浏览器统一标准化为 LF)

mb_strlen() 同样计入换行符,但按字符而非字节

mb_strlen() 的行为取决于 $encoding 参数,但它依然把换行符当作一个“字符”来计数——只不过这个“字符”在 UTF-8 中占 1 字节,在 GBK 中也占 1 字节,所以结果通常和 strlen() 一致(除非遇到多字节汉字)。

echo mb_strlen("你好\n", 'UTF-8'); // 输出 3:'你' + '好' + '\n'
  • 换行符在绝大多数编码下都是单字符单字节,所以 mb_strlen()strlen() 对含换行的纯 ASCII 文本结果相同
  • 真正差异出现在中文、日文等场景:strlen("你好") 返回 6(UTF-8 下每个汉字 3 字节),而 mb_strlen("你好", 'UTF-8') 返回 2
  • 别指望 mb_strlen() 自动“忽略换行”,它不负责语义过滤

想排除换行符再算长度?得先清理

没有内置函数直接“算不含换行的长度”,必须显式移除换行符后再调用长度函数。常见做法:

立即学习PHP免费学习笔记(深入)”;

RecoveryFox AI
RecoveryFox AI

AI驱动的数据恢复、文件恢复工具

下载
  • str_replace(["\r\n", "\r", "\n"], '', $str) 彻底清除所有换行变体
  • preg_replace('/[\r\n]+/', '', $str) 更简洁,但注意 PCRE 开销略高
  • 若只要去除首尾换行,用 trim($str, "\r\n") 更轻量,但中间的换行仍保留

示例:

$text = "line1\r\nline2\nline3";
$clean = str_replace(["\r\n", "\r", "\n"], '', $text);
echo strlen($clean); // 输出 15("line1line2line3")

实际校验场景中容易忽略的点

做字段长度限制(如数据库 varchar(255))时,如果后端没清理换行符,用户粘贴带空行的文本就可能超长报错,而前端 JS 的 .length 在大多数情况下也计入 \n,看似一致,但 JS 的 \r\n 是两个字符,PHP 的 "\r\n" 是两个字节 —— 表面一致,底层逻辑不同。

  • MySQL TEXT 类型存储时保留换行符,但某些客户端显示会折叠,造成“长度对不上”的错觉
  • 使用 wordwrap()nl2br() 前,先确认原始字符串是否已含多余换行,否则可能重复处理
  • API 接口接收 JSON 字段时,JSON 解析器(如 json_decode())不会修改字符串内容,换行符原样保留

换行符不是隐形的,它实实在在占空间。判断长度前,先想清楚:你要的是“用户看到的行数”,还是“存进数据库的字节数”,还是“前端展示的视觉宽度”——三者完全不是一回事。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

668

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

533

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

602

2023.08.14

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 812人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号