이 글은 주로 정규식0폭 어설션을 소개합니다. 폭이 0인 어설션의 개념, 분류, PHP 구현 기술 및 관련 주의사항을 간략하게 소개합니다. 정규식의 너비가 0인 어설션입니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
머리말저는 이전에 정규식에 관한 기사를 쓴 적이 있습니다(http://www.jb51.net/article/111359.htm). 기사에서는 정규화를 자세히 소개하지만 너비가 0인 어설션의 도입은 거의 언급되지 않습니다. 이제 이 내용을 추가해 보세요. 이 기사에서는 주로 다음 문제를 해결합니다.
① 너비가 0인 어설션이 무엇인가요?
② 너비가 0인 어설션을 사용하는 방법개념 폭이 0인 어설션은 대부분의 곳에서 이렇게 정의합니다. 특정 콘텐츠(이러한 콘텐츠는 포함하지 않음) 앞이나 뒤의 항목을 찾는 데 사용됩니다. 즉, b ^ $ <와 같은 앵커링 기능이 있습니다. 특정 조건(예: 어설션)을 충족해야 하는 위치를 지정하므로 너비가 0인 어설션이라고도 합니다. 내 이해는 제한된 위치에서
string앞이나 뒤에 일치 검색을 수행하는 것입니다. 따라서 너비가 0인 Assertion의 실행 과정은 두 가지 상황으로 구분됩니다. Forward Assertion인 경우 첫 번째 단계는 Assertion이 참인지(즉, 특정 조건을 충족하는지) 판단하는 것입니다. 두 번째 단계는 한 단계에서 조건이 충족되면 다음 단계로 진행하는 것입니다. 역어설션인 경우 첫 번째 단계는 정규식 순서대로 일치시키는 것입니다. 두 번째 단계는 역배서에 직면했을 때 역배서에 부합하는지 여부를 결정하는 것입니다.
긍정적 예측 어설션긍정적 예측 어설션이란 문자열에서 해당 위치 이전을 검색하여 일치시키고 (?=exp)를 사용하여 exp 이전 위치를 일치시키는 것입니다.
Example
$str="abcgwcab"; $parent='/bc(?=gw)/'; $str=preg_match($parent,$str,$match); var_dump($match); /** 输出结果: int 1 array (size=1) 0 => string 'bc' (length=2) */
분석: 먼저 "abcgwcab" 문자열에서 gw 위치를 찾아 그것이 참이라고 주장한 다음 bc를 일치시킵니다. 정규식을 $parent='/bc(?=gw)ca/'로 작성하면 일치가 실패합니다.
Anti-lookahead 어설션Anti-lookahead 어설션이란 무엇입니까? (?!exp)를 사용하여 뒤에 exp가 오지 않는 항목을 일치시킵니다.
예:
$str="abcgwcab"; $parent='/bc(?!ww)gw/'; $str=preg_match($parent,$str,$match); var_dump($str); var_dump($match); /** 输出: int 1 array (size=1) 0 => string 'bcgw' (length=4) */
분석: 먼저 문자열에 bc가 포함되어 있는지 확인한 다음 ww가 뒤에 오는지 확인하고 마지막으로 gw와 일치합니다. reverse Assertion 전후에 다른 매칭 조건이 추가될 수 있음을 알 수 있다.
Front 및 Post AssertionPost 및 Post Assertion이란? 문자열의 해당 위치(?<=exp)가 exp
다음 위치와 일치하는지 검색하여 일치시키는 것입니다.
$str="abcgwcab"; $parent='/(?<=gw)ca/'; $str=preg_match($parent,$str,$match); var_dump($str); var_dump($match); /** 输出结果: int 1 array (size=1) 0 => string 'ca' (length=2) */
분석: 첫 번째 단계는 문자 "abcgwcab"에 gw가 포함되어 있는지 확인하는 것입니다. 반환 결과가 true인지 확인한 다음 두 번째 단계로 진행하여 gw 뒤에 ca가 있는지 확인합니다.
안티-포스테리어 어설션안티-포스테리어 어설션이 무엇인가요? (?
$str="abcgwcab"; $parent='/(?<!bc)gw/'; $str=preg_match($parent,$str,$match); var_dump($str); var_dump($match); /** int 0 array (size=0) empty */
분석: 문자열에서 먼저 gw를 일치시킨 다음, 앞의 것이 bc인지 확인하고, 앞의 것이 무엇인지 알아보세요. 하나는 bc이므로 false를 반환합니다.
예제 1:d+(?=abc)
문자열에 'abc'가 포함되어 있는지 확인하고 하나 이상의 숫자가 포함되어 있는지 확인하세요. 앞쪽 예제 2: (?<=dd)w
d+(?=abc)
判断一个字符串中是否包含'abc',且其前面是否包含一个或多个数字
例2:(?<=dd)w
判断字符串中是否存在连续两个数字,且其后面包含一个字母
例3:d{3} (?!55)
判断字符串中是否包含连续三个数字,且三个数字后面不是55
例4:(?<!ac)wd
예 3: d{3 } ( ?!55)
문자열에 세 개의 연속 숫자가 포함되어 있고 세 숫자 뒤에 55가 없는지 확인
예 4: (?<!ac)wd
문자열에 문자와 숫자의 조합이 포함되어 있고 앞에 ac
예측 어설션은 무엇입니까? 은 Assertion 앞의 정규식이고, Assertion은 다른 정규식에 있습니다. Post-Assertion은 Assertion 앞의 정규식이고, Assertion은 다른 정규식 앞의 순서입니다.
PS: 여기서는 참조용으로 매우 편리한 2가지 정규식 도구를 제공합니다.http:/ /tools.jb51.net/regex/ javascript
정규 표현식 온라인 생성 도구:
위 내용은 정규식의 너비가 0인 어설션 예에 대한 자세한 설명_정규식의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!