>  기사  >  백엔드 개발  >  PHP의 모든 문자 정규 매칭이 실패하는 이유와 해결 방법

PHP의 모든 문자 정규 매칭이 실패하는 이유와 해결 방법

小云云
小云云원래의
2018-03-31 14:31:302547검색

이 글은 주로 모든 문자의 PHP 정규 매칭 실패에 대한 이유와 해결 방법을 공유합니다. 이 글이 모든 사람에게 도움이 되기를 바랍니다.

<?php$str = &#39;
@@@@i ( PCRE_CASELESS)
如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配。@@@@
m ( PCRE_MULTILINE)&#39;;// 正则1:$preg = &#39;/@@@@(.*)@@@@/&#39;; 无法匹配换行符\n// 正则2:$preg = &#39;/@@@@(.*)@@@@/s&#39;;// \s   匹配任意一个空白符,等价于[\f\n\r\t\v]// \S   匹配除空白符以外任何字符,等价于[^\f\n\r\t\v]preg_match_all( $preg, $str, $matches);

print_r($matches);// 结果1:Array(
    [0] => Array()
    [1] => Array()
)// 结果2:Array(
    [0] => Array
        (
            [0] => @@@@i ( PCRE_CASELESS)
如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配。@@@@
        )
    [1] => Array
        (
            [0] => i ( PCRE_CASELESS)
如果设置了这个修饰符,模式中的字母会进行大小写不敏感匹配。
        )

)

PHP 정규식 수정자:

  • i: 이 수정자를 설정하면 패턴의 문자가 대소문자를 구분하지 않고 일치합니다.

  • m: 기본적으로 PCRE는 대상 문자열이 단일 문자열로 구성되어 있다고 간주합니다. 한 줄의 문자(그러나 실제로는 여러 줄을 포함할 수 있음), "줄 시작" 메타 문자(^)는 문자열의 시작 부분에만 일치하고 "줄 끝" 메타 문자(

    , 설정

  • s: 이 수정자가 설정되면 패턴의 점 메타 문자는 줄 바꿈을 포함한 모든 문자와 일치합니다. 이 수정자는 /와 일치하지 않습니다. Perl의 s 수정자. [^a]와 같은 부정 문자 클래스는 이 수정자의 설정과 관계없이 항상 개행 문자와 일치합니다.

  • x: 이것이 수정자로 설정된 경우 공백 데이터 문자는 이스케이프되거나 문자 클래스에 없는 문자는 항상 무시되며 # 문자와 이스케이프되지 않은 문자 클래스 외부의 다음 개행 문자 사이의 문자도 무시됩니다. 이 수정자는 Perl의 /x 수정자와 동일하므로 컴파일된 패턴에 다음이 포함될 수 있습니다. 참고: 이는 데이터 문자에만 적용됩니다. 공백 문자는 여전히 시퀀스(?()와 같은 특수 문자 시퀀스에 나타날 수 없습니다. 조건부 하위 그룹이 도입되었습니다. 구문을 사용하면 컴파일 오류가 발생합니다. 예를 들어 (?(는 오류를 발생시킵니다.).

  • e: 이 수정자가 설정되면 preg_replace()는 대체 문자열의 역참조 대체를 수행한 후 평가하고 대체된 문자열을 PHP 코드(평가 함수 메소드)로 실행하고 실행 결과를 실제로 대체에 참여하는 문자열로 사용합니다. 역참조 대체 중에 작은따옴표, 큰따옴표, 백슬래시() 및 NULL 문자가 백슬래시로 이스케이프됩니다.

    Tip
    请确保replacement参数由合法php代码字符串组成, 否则php将会 在preg_replace()调用的行上 产生一个解释错误.
    Note: 仅 preg_replace()使用此修饰符, 其他PCRE函数忽略此修饰符.

  • A: 이 수정자를 설정하면 모드가 "고정" 모드로 강제 설정됩니다. 즉, 대상 문자열의 시작 부분에서만 검색하도록 일치를 제한합니다. 이 효과는 다음을 사용하여 구성할 수도 있습니다. 적절한 패턴이며 이것이 Perl에서 이 패턴을 구현하는 유일한 방법입니다.

  • D: 이 수정자가 설정된 경우 패턴의 달러 기호 메타 문자는 이 수정자가 다음과 같은 경우에만 대상 문자열의 끝과 일치합니다. 설정되지 않은 경우 문자열이 개행 문자로 끝나면 달러 기호도 개행 문자와 일치합니다(단, 이전 개행 문자는 제외). 수정자 m이 설정된 경우 해당 수정자는 무시됩니다.

  • S: 패턴을 여러 번 사용해야 하는 경우 일치 속도가 향상되므로 추가 분석을 수행하는 데 시간을 투자할 가치가 있습니다. 추가 분석은 현재 고정되지 않은 패턴 일치에만 적용됩니다(즉, 별도의 고정 시작 문자가 없음).

  • U: 이 수정자는 수량자의 "탐욕" 모드를 반전시킵니다. . 이는 기본적으로 수량자를 non-greedy로 만들고, 수량자? 를 따르면서 펄과 호환되지 않습니다. 이는 모드 내 수정자 설정(?U) 또는 뒤에 있는 물음표를 사용하여 설정할 수도 있습니다. 탐욕스럽지 않은 것으로 표시하는 수량자(예: .*?).

    Note:
    
    在非贪婪模式, 通常不能匹配超过 pcre.backtrack_limit的字符.
  • X: 이 수정자는 Perl과 호환되지 않는 PCRE의 첨부 기능을 켭니다. 패턴의 백슬래시 뒤에 다음 문자가 옵니다. 특별한 의미가 없으면 오류가 발생하지만 이러한 문자는 이전 버전과의 호환성을 보장하기 위해 보존됩니다. 기본적으로 Perl에서는 특별한 의미가 없는 문자가 뒤에 오는 백슬래시가 현재 해당 문자의 원본 텍스트로 간주됩니다.

  • J: 내부 옵션 설정(?J)은 로컬 PCRE_DUPNAMES 옵션을 수정합니다. (주석: 내부 옵션으로만 설정할 수 있으며, 외부 /J 설정은 오류를 생성합니다.)

  • u: 이 수정자는 Perl과 호환되지 않는 추가 기능을 활성화합니다. 패턴 문자열 UTF-8로 간주됩니다. 이 수정자는 Unix 버전의 PHP 4.1.0 이상과 Win32 버전의 PHP에서 사용할 수 있습니다. 4.2.3. PHP 4.3.5에서는 모드의 UTF-8 유효성 검사를 시작합니다.

위 내용은 PHP의 모든 문자 정규 매칭이 실패하는 이유와 해결 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.