이 기사의 예에서는 PHP 일반 수정자의 사용법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
<?php //标记在整个模式之外; // 例://$mode="/\bis\b/U",其中U在外面; //修正符:i 不区分大小写的匹配; //如:"/abc/i"可以与abc或aBC或ABc等匹配; //修正符:m 将字符串视为多行,不管是那行都能匹配; // 例://模式为:$mode="/abc/m"; //要匹配的字符串为:$str="bcefg5e\nabcdfe" //注意其中\n,换行了;abc换到了下一行; //$str和$mode仍可以匹配,修正符m使得多行也可匹配; //修正符:s 将字符串视为单行,换行符作为普通字符; // 例://模式为:$mode="/pr.y/"; //要匹配字符串为:$str="pr\ny"; //两者不可匹配; . 是除了换行以外的字符可匹配; //修改下模式为:$mode="/pr.y/s"; //其中修正符s将\n视为普通字符,即不是换行; //最后两者可以匹配; //修正符:x 将模式中的空白忽略; //修正符:A 强制从目标字符串开头匹配; // 例://$mode="/abc/A"; //可以与$str="abcsdfi"匹配, //不可以与$str2="sdsdabc"匹配; //因为$str2不是以abc开头; //修正符:D 如果使用$限制结尾字符,则不允许结尾有换行; // 例://模式为:$mode="/abc$/"; //可以与最后有换行的$str="adshabc\n"匹配; //元子符$会忽略最后的换行\n; //如果模式为:$mode="/abc/D", //则不能与$str="adshabc\n"匹配, //修正符D限制其不可有换行;必需以abc结尾; //修正符:U 只匹配最近的一个字符串;不重复匹配; // 例: // 如模式为: $mode="/a.*c/"; $str="abcabbbcabbbbbc" ; preg_match($mode,$str,$content); echo $content[0]; //输出:abcabbbcabbbbbc; //如果$mode="/a.*c/";变成$mode="/a.*c/U"; // 则只匹配最近一个字符串,输出:abc; //修正符:e 配合函数preg_replace()使用, // 可以把匹配来的字符串当作正则表达式执行; ?>
수정자:
POSIX 호환 정규식에는 수정자가 없습니다.
PERL 호환 정규 표현식에 사용 가능한 수정자(수정자의 공백과 줄바꿈은 무시되며 다른 문자는 오류를 유발합니다):
i (PCRE_CASELESS):
Upper 및 Newline과 일치할 때 무시됩니다. 소문자.
m(PCRE_MULTILINE):
이 수식자를 설정하면 줄의 시작(^)과 줄의 끝($)이 전체 문자열의 시작과 끝과 일치할 뿐만 아니라, 기호(n) 뒤와 앞의 개행 문자도 각각 일치시킵니다.
s (PCRE_DOTALL):
이 수정자를 설정하면 패턴의 점 메타 문자(.)가 줄 바꿈을 포함한 모든 문자와 일치합니다. 이 설정이 없으면 개행 문자가 포함되지 않습니다.
x (PCRE_EXTENDED):
이 수정자를 설정하면 패턴의 공백 문자는 이스케이프되거나 문자 클래스 내에 있는 문자를 제외하고 완전히 무시됩니다.
e:
이 수정자가 설정되면 preg_replace()는 대체 문자열에서 역참조의 일반적인 대체를 수행하고 이를 PHP 코드로 평가한 다음 검색을 해당 결과 문자열로 바꿉니다. preg_replace()만이 이 수정자를 사용하고, 다른 PCRE 함수는 이를 무시합니다.
A(PCRE_ANCHORED):
이 수정자를 설정하면 패턴이 강제로 "고정"됩니다. 즉, 패턴은 대상 문자열의 시작 부분에서만 강제로 일치하게 됩니다.
D(PCRE_DOLLAR_ENDONLY):
이 수정자를 설정하면 패턴의 줄 끝($)은 대상 문자열의 끝과만 일치합니다. 이 옵션이 없으면 마지막 문자가 개행 문자인 경우에도 일치됩니다. m 수정자가 설정된 경우 이 옵션은 무시됩니다.
S:
패턴이 여러 번 사용될 경우 먼저 분석하여 일치 속도를 높이는 것이 좋습니다. 이 수정자가 설정되면 추가 분석이 수행됩니다. 현재 패턴 분석은 고정된 시작 문자가 하나도 없는 고정되지 않은 패턴에만 유용합니다.
U(PCRE_UNGREEDY):
'?'를 기본 일치로 설정하세요.
X(PCRE_EXTRA):
패턴의 백슬래시 뒤에 특별한 의미가 없는 문자가 오면 오류가 발생하므로 향후 확장을 위해 이 조합이 유지됩니다. 기본적으로 백슬래시 뒤에 특별한 의미가 없는 문자가 오면 문자 자체로 처리됩니다.
u(PCRE_UTF8):
패턴 문자열은 UTF-8로 처리됩니다.
참고:
패턴 수정자
i - 대문자와 소문자 모두 일치할 수 있습니다.
M - 문자열을 여러 줄로 처리합니다.
S - 문자열을 다음과 같이 처리합니다. 줄 바꿈을 일반 문자로 처리하여 "."가 모든 문자와 일치하도록 합니다.
X - 패턴의 공백은 무시됩니다.
U - 가장 가까운 문자열과 일치합니다.
e - 대체된 문자열을 표현
이 글이 PHP 프로그래밍에 종사하는 모든 분들에게 도움이 되기를 바랍니다.
PHP 정규 수식어의 더 자세한 사용예와 관련 글은 PHP 중국어 홈페이지를 주목해주세요!