我们先定义一个字符串,如图,假设要从这段字符串里,匹配找出网站的名字“搜狗”
然后定义一个正则表达式,解析下代码,正则要放在斜杠符号(/)里面,如果表达式里有用到斜杠(/)符号的,则需要用反斜杠来转义。
最后面的 “i” 标记是让正则表达式在匹配的时候不需要区分大小写。
这里定义一个数组,并调用php的preg_match方法,方法的第一个参数是上面定义的正则表达式,第二个参数是要查找的字符串,第三个参数是定义的数组,当有匹配到数据时,数组第一项是匹配的原字符串,数组第二项就是要查找的数据
最后用dump方法输出数组的内容,显示匹配结果。
所有的代码就是这几行。
运行这些代码后,我们看到结果如图,有匹配到数据,但得到的结果(数组第二项内容)把字符串后面的内容都匹配上了。
为什么会这样?
是因为我们的正式表达式,默认情况是贪婪匹配,就是匹配尽量多的内容。
如何修正?我们只要加多一个U标记就行了,代码如图,加上这个标记就会告诉正则表达式,执行非贪婪匹配。
再运行下代码,看下结果。
如图,这次能正确匹配到网站名字了。
0 篇文章
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!