时间:2021-07-01 10:21:17 帮助过:8人阅读
preg_match_all("#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\<]+)#i", $str, $matches)
这个正则中的|\s|()代表什么意思?有人知道吗
preg_match_all("#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\<]+)#i", $str, $matches)
这个正则中的|\s|()代表什么意思?有人知道吗
我把每一部分都解释给题主吧。
#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\<]+)#i
两边的 #
是 PCRE 分隔符,最后一个 i
表示忽略大小写。
(^|\s|\()
字符串开头,或者有空格分隔,或者匹配一个左括号。这个部分是一个未命名分组。
((http(s?)://)|(www\.))
匹配 http://
或者 https://
或者 www.
。这个部分是一个未命名分组,其中又分成两个未命名分组。
(\w+[^\s\)\<]+)
匹配至少一个字母数字,之后再匹配至少一个不是空格、右括号、左尖括号的字符。这里又是一个未命名分组。
结束。
推荐两个debug正则的站点: