>  기사  >  백엔드 개발  >  정규식의 모든 기호에 대한 설명

정규식의 모든 기호에 대한 설명

巴扎黑
巴扎黑원래의
2017-04-20 18:02:153190검색

이전에 많은 정규식 기호가 등장했습니다. 이 기사에서는 일반적으로 사용되는 모든 기호를 요약합니다.

모든 기호 설명

문자 설명

다음 문자를 특수 문자, 리터럴 문자, 역참조 또는 8진수로 표시 탈출 문자. 예를 들어 'n'은 문자 "n"과 일치합니다. 'n'은 개행 문자와 일치합니다. 시퀀스 '\'는 ""와 일치하고 "("는 "("와 일치합니다.

^은 입력 문자열의 시작 부분과 일치합니다. RegExp 개체의 Multiline 속성이 설정된 경우 ^는 'n' 또는 'n'과도 일치합니다.

$ 뒤의 'r'은 RegExp 개체의 Multiline 속성이 설정된 경우 입력 문자열의 끝과 일치하고, $는 'n' 또는 'r' 앞의 위치와도 일치합니다. 0개 이상의 이전 하위 표현식과 일치합니다. 예를 들어, zo*는 "z" 및 "zoo"와 일치할 수 있습니다. *는 이전 하위 표현식과 한 번 이상 일치합니다. 예를 들어 'zo+'는 "zo"와 일치할 수 있습니다. "z". +는 {1,}과 동일합니다.  

? 앞의 하위 표현을 0번 또는 한 번 일치합니다. 예를 들어 "do(es)?"는 "do" 또는 " does" ?는 {0,1}과 같습니다. n은 음수가 아닙니다. 정수입니다. 특정 횟수와 일치합니다. 예를 들어 'o{2}'는 "Bob"의 'o'와 일치할 수 없지만 일치할 수는 있습니다. "food"에서 두 개의 o와 일치합니다. 음수가 아닌 정수입니다. 예를 들어 'o{2,}'는 "Bob"에서 'o'와 일치할 수 없지만 모든 'o{1, }'는 'o+'와 동일합니다. 'o{0,}'는 'o*'와 동일합니다.

{n,m} m과 n은 모두 음수가 아닌 정수입니다. n

? 이 문자 뒤에 다른 제한 기호(*, +, ?, {n}, {n,}, {)가 오는 경우 n,m}. ), 일치 모드는 비탐욕 모드입니다. 비탐욕 모드는 검색된 문자열과 최대한 일치하는 반면, 기본 탐욕 모드는 검색된 문자열과 최대한 일치합니다. 문자열 "oooo", 'o+?'는 단일 'o'와 일치하고, 'o+'는 모든 'o'와 일치합니다.

모든 문자와 일치합니다. 패턴을 사용하세요. '[.n]'

(pattern)과 같이 패턴과 일치하고 해당 일치 항목을 얻습니다. 얻은 일치 항목은 VBScript의 SubMatches 컬렉션 또는 JScript의 $0…$9 속성을 사용하여 생성된 Matches 컬렉션에서 얻을 수 있습니다. 괄호 문자를 일치시키려면 '(' 또는 ')'를 사용하십시오.

(?:pattern)은 패턴과 일치하지만 일치 결과를 얻지 못합니다. 즉, 이는 비획득 일치이며 나중에 사용하기 위해 저장되지 않습니다. 이는 "or" 문자(|)를 사용하여 패턴의 일부를 결합할 때 유용합니다. 예를 들어, 'industr(?:y|ies)는 'industry|industries'보다 짧은 표현입니다.

(?=pattern) 정방향 조회, 패턴과 일치하는 문자열의 시작 부분에서 검색 문자열을 일치시킵니다. 이는 가져오지 않는 일치입니다. 즉, 나중에 사용하기 위해 일치 항목을 가져올 필요가 없습니다. 예를 들어, 'Windows (?=95|98|NT|2000)'는 "Windows 2000"의 "Windows"와 일치하지만 "Windows 3.1"의 "Windows"와 일치하지 않습니다. 프리페치는 문자를 소비하지 않습니다. 즉, 일치가 발생한 후 다음 일치 항목에 대한 검색은 프리페치를 포함하는 문자 뒤에서 시작하는 것이 아니라 마지막 일치 직후에 시작됩니다.

(?!pattern) 부정 조회, 패턴과 일치하지 않는 문자열의 시작 부분에 있는 검색 문자열과 일치합니다. 이는 가져오지 않는 일치입니다. 즉, 나중에 사용하기 위해 일치 항목을 가져올 필요가 없습니다. 예를 들어, 'Windows(?!95|98|NT|2000)'는 "Windows 3.1"의 "Windows"와 일치할 수 있지만 "Windows 2000"의 "Windows"는 일치하지 않습니다. 사전 검사는 문자를 소비하지 않습니다. 즉, 일치가 발생한 후 사전 검사를 포함하는 문자 뒤에서 시작하는 것이 아니라 마지막 일치 직후에 다음 일치 항목에 대한 검색이 시작됩니다.

x|y 일치 x 또는 y. 예를 들어 'z|food'는 "z" 또는 "food"와 일치합니다. '(z|f)ood'는 "zood" 또는 "food"와 일치합니다.

[xyz] 문자 집합입니다. 포함된 문자 중 하나와 일치합니다. 예를 들어 '[abc]'는 'plain'의 'a'와 일치합니다.

[^xyz] 음수 문자 집합입니다. 포함되지 않은 모든 문자와 일치합니다. 예를 들어 '[^abc]'는 "plain"의 'p'와 일치합니다.

[a-z] 문자 범위. 지정된 범위 내의 모든 문자와 일치합니다. 예를 들어 '[a-z]'는 'a'부터 'z'까지의 범위에 있는 모든 소문자 알파벳 문자와 일치합니다.

[^a-z] 부정 문자 범위. 지정된 범위 내에 없는 모든 문자와 일치합니다. 예를 들어 '[^a-z]'는 'a'에서 'z' 범위에 없는 모든 문자와 일치합니다.

b 단어와 공백 사이의 위치를 ​​나타내는 단어 경계와 일치합니다. 예를 들어, 'erb'는 "never"의 'er'와 일치하지만 "동사"의 'er'와는 일치하지 않습니다.

B 비단어 경계와 일치합니다. 'erB'는 '동사'의 'er'와 일치하지만 'never'의 'er'는 일치하지 않습니다.

cx x로 지정된 제어 문자와 일치합니다. 예를 들어, cM은 Control-M 또는 캐리지 리턴 문자와 일치합니다. x 값은 A-Z 또는 a-z 중 하나여야 합니다. 그렇지 않으면 c는 리터럴 'c' 문자로 처리됩니다.

d는 숫자와 일치합니다. [0-9]와 동일합니다.

D는 숫자가 아닌 문자와 일치합니다. [^0-9]와 동일합니다.

f는 폼 피드와 일치합니다. x0c 및 cL과 동일합니다.

n은 개행 문자와 일치합니다. x0a 및 cJ와 동일합니다.

r은 캐리지 리턴 문자와 일치합니다. x0d 및 cM과 동일합니다.

s는 공백, 탭, 폼 피드 등을 포함한 모든 공백 문자와 일치합니다. [fnrtv]와 동일합니다.

S는 공백이 아닌 모든 문자와 일치합니다. [^ fnrtv]와 동일합니다.

탭 문자와 일치하지 않습니다. x09 및 cI와 동일합니다.

v는 세로 탭 문자와 일치합니다. x0b 및 cK와 동일합니다.

w 밑줄을 포함한 모든 단어 문자와 일치합니다. '[A-Za-z0-9_]'와 동일합니다.

W는 단어가 아닌 문자와 일치합니다. '[^A-Za-z0-9_]'와 동일합니다.

xn은 n과 일치합니다. 여기서 n은 16진수 이스케이프 값입니다. 16진수 이스케이프 값은 정확히 두 자리 길이여야 합니다. 예를 들어 'x41'은 "A"와 일치합니다. 'x041'은 'x04' & "1"과 동일합니다. ASCII 인코딩은 정규식에서 사용할 수 있습니다. .

num은 num과 일치하며, 여기서 num은 양의 정수입니다. 획득한 일치 항목에 대한 참조입니다. 예를 들어 '(.)1'은 두 개의 연속된 동일한 문자와 일치합니다.

n은 8진수 이스케이프 값 또는 역참조를 식별합니다. n 앞에 가져온 n개 이상의 하위 표현식이 있는 경우 n은 역방향 참조입니다. 그렇지 않고 n이 8진수(0-7)이면 n은 8진수 이스케이프 값입니다.

nm은 8진수 이스케이프 값 또는 역참조를 식별합니다. nm 앞에 최소 nm개의 획득 가능한 하위 표현식이 있는 경우 nm은 역방향 참조입니다. nm 앞에 최소한 n의 획득이 있으면 n은 역방향 참조이고 그 뒤에는 리터럴 m이 옵니다. 이전 조건 중 어느 것도 참이 아닌 경우, n과 m이 모두 8진수(0-7)이면 nm는 8진수 이스케이프 값 nm과 일치합니다.

nml n이 8진수(0-3)이고 m과 l이 모두 8진수(0-7)인 경우 8진수 이스케이프 값 nml과 일치합니다.

un은 n과 일치합니다. 여기서 n은 4개의 16진수 숫자로 표시되는 유니코드 문자입니다. 예를 들어, u00A9는 저작권 기호(?)와 일치합니다.

위 내용은 정규식의 모든 기호에 대한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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