> 백엔드 개발 > PHP 튜토리얼 > 一句正则不懂

一句正则不懂

WBOY
풀어 주다: 2016-06-06 20:48:05
원래의
1189명이 탐색했습니다.

<code>preg_match_all("#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\</code>
로그인 후 복사
로그인 후 복사

这个正则中的|\s|()代表什么意思?有人知道吗

回复内容:

<code>preg_match_all("#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\</code>
로그인 후 복사
로그인 후 복사

这个正则中的|\s|()代表什么意思?有人知道吗

我把每一部分都解释给题主吧。

<code class="lang-regexp">#(^|\s|\()((http(s?)://)|(www\.))(\w+[^\s\)\</code>
로그인 후 복사

两边的 # 是 PCRE 分隔符,最后一个 i 表示忽略大小写。

<code class="lang-regexp">(^|\s|\()
</code>
로그인 후 복사

字符串开头,或者有空格分隔,或者匹配一个左括号。这个部分是一个未命名分组。

<code class="lang-regexp">((http(s?)://)|(www\.))
</code>
로그인 후 복사

匹配 http:// 或者 https:// 或者 www. 。这个部分是一个未命名分组,其中又分成两个未命名分组。

<code class="lang-regexp">(\w+[^\s\)\</code>
로그인 후 복사

匹配至少一个字母数字,之后再匹配至少一个不是空格、右括号、左尖括号的字符。这里又是一个未命名分组。

结束。

推荐两个debug正则的站点:

  • debuggex 界面凑合,功能强大,支持多种语言的正则
  • regexper 比较好看,只支持javascript的正则
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿