今天在CSDN问答上看到一个这样的问题。
代码如下
$str= 'abc def ijk' ;
preg_match('/f$/m',$str,$arr);
var_dump($arr);
我们都知道m 此模式中如果有回车或换行,^
和$
将匹配每行的行首和行尾 ,既然这样,那应该能匹配到第二行。但是$arr结果为空?这是为什么呢?
因为f后面有一个回车符。
- Unix系统里,每行结尾只有“<换行>”,即”\n”;
- Windows系统里面,每行结尾是“<换行><回车 >”,即“\n\r”;
- Mac系统里,每行结尾是“<回车>”,即”\n”;
这也是Unix/Mac系统下的文件在 Windows里打开的话,所有文字会变成一行。那么我在win下测试,就会导致上诉原因。当然换句话说,如果在linux下测试,肯定会没有问题的。既然这样,我将代码改成如下:
$str= 'abc def ijk' ;
preg_match('/f\r$/m',$str,$arr);
测试正常,返回了希望的值。
下面补充一下正则的一些基础知识。
\f 匹配换页符
\n 匹配换行符
\r 匹配回车符
\t 匹配制表符
\v 匹配垂直制表符
模式修正符
i 不区分大小写
m 此模式中如果有回车或换行,^
和$
将匹配每行的行首和行尾
s 让.能匹配\n
x 忽略空白
U 取消贪婪,相当于(.*?)
A 与^效果一样
D 结尾处不忽略回车 ,在结束处有 符的时候,在匹配的字符串后面加上回车, 依然能够匹配它成功。但是加上D之后,结尾的回车,不再匹配