字符 | 描述 |
---|---|
[ABC] | 匹配中括号中的所有字符,例如 [abc] 匹配字符串"abcdefg"中所有的a,b,c字母。 |
[^ABC] | 匹配除了中括号中的所有字符,例如[^abc]匹配字符串"abcdefg"中所有的不是a,b,c的字母 |
[A-Z] | 表示一个区间,例如[a-z]表示匹配所有的小写字母 |
. | 表示匹配除换行符(\n、\r)之外的任何单个字符,相等于 [^\n\r]。 |
\s | 表示匹配所有空白符,包括换行 |
\S | 表示匹配所有非空白符,不包括换行 |
\w | 表示匹配所有字母,数字,下划线。等价于[A-Za-z0-9_] |
\W | 匹配非字母、数字、下划线。等价于[^A-Za-z0-9_]。 |
\cx | 匹配由x指明的控制字符。例如, \cM 匹配一个 Control-M 或回车符。x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一个原义的 'c' 字符。 |
\f | 匹配一个换页符。等价于 \x0c 和 \cL。 |
\n | 匹配一个换行符。等价于 \x0a 和 \cJ。 |
\r | 匹配一个回车符。等价于 \x0d 和 \cM。 |
\t | 匹配一个制表符。等价于 \x09 和 \cI。 |
\v | 匹配一个垂直制表符。等价于 \x0b 和 \cK。 |
$ | 表示匹配输入字符串的结尾位置。 |
( ) | 标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。要匹配这些字符,请使用 \( 和 \) 。 |
* | 匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 \* 。 |
+ | 匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 \+ 。 |
[] | 匹配一个中括号表达式的开始。要匹配 [,请使用 \[ 。 |
? | 匹配前面的子表达式零次或一次,或指明一个非贪婪限定符。要匹配 ? 字符,请使用 \? 。 |
\ | 将下一个字符标记为或特殊字符、或原义字符、或向后引用、或八进制转义符。例如, 'n' 匹配字符 'n'。'\n' 匹配换行符。序列 '\' 匹配 "",而 '(' 则匹配 "("。 |
^ | 匹配输入字符串的开始位置,除非在方括号表达式中使用,当该符号在方括号表达式中使用时,表示不接受该方括号表达式中的字符集合。要匹配 ^ 字符本身,请使用 \^ 。 |
{ | 标记限定符表达式的开始。要匹配 {,请使用 \{ 。 |
| | 指明两项之间的一个选择。要匹配 |,请使用 | 。 |
{n} |
n 是一个非负整数。匹配确定的 n 次。例如,o{2} 不能匹配 "Bob" 中的 o,但是能匹配 "food" 中的两个 o。 |
{n,} |
n是一个非负整数,表示匹配至少n次。例如,o{2,} 不能匹配"Bob"中的 o,但是能匹配 "fooooood"中的所有o。o{1,}等价于o+,o{0,}等价于o* |
{n,m} |
n,m是两个非负整数,其中n<=m,表示最少匹配n次,最多匹配m次。例如,o{1,3}匹配"fooooood"的前三个o |
\b | 匹配一个单词边界,即字与空格间的位置。 |
\B | 非单词边界匹配。 |
exp1(?=exp2) |
查找 exp2 前面的 exp1。例如:/abc(?=[\d+])/g 表示匹配一个字符串中数字前面的字符abc,"abc123abc324"会匹配到这个字符串中的两个abc字符串 |
(?<=exp2)exp1 |
查找exp2后面的exp1。例如:/(?<=[\d+])abc/g 表示匹配一个字符串中数字后面的字符abc,"abc123abc123"会匹配到这个字符串中的第二个abc字符串 |
exp1(?!exp2) |
查找后面不是exp2的exp1。例如:/abc(?![\d+])/g 表示匹配一个字符串中为abc且后面不是数字的字符串,"abcd123abc123"会匹配到这个字符串"abcd"中的abc字符串 |
(?<!exp2)exp1 |
查找前面不是exp2的exp1。例如:/(?<![\d+])abc/g 表示匹配一个字符串中为abc且前面不是数字的字符串,"abcd123abc123"会匹配到这个字符串"abcd"中的abc字符串 |
i(标记) | 将匹配设置为不区分大小写,搜索时不区分大小写: A 和 a 没有区别。此为标记,使用方式与位于表达式之外,格式为:/表达式/标记 。例如:/[A-Z]/i 表示匹配A-Z,a-z中的所有字符 |
g(标记) | 全局匹配,查找所有的匹配项。会匹配字符串中所有符合规则的匹配项。例如/[a]/g 会匹配一个字符串中的所有的a,如"abcdaa"会匹配字符串中所有的a |
m(标记) | 多行匹配,使边界字符 ^ 和 $ 匹配每一行的开头和结尾,记住是多行,而不是整个字符串的开头和结尾。 |
s(标记) | 特殊字符圆点. 中包含换行符\n ,默认的字符圆点. 是匹配除换行符\n 之外的任何字符,加上 s 修饰符之后,. 中包含换行符\n 。 |
(?:pattern) |
匹配pattern但不获取匹配结果.也就是说这是一个非获取匹配,不进行存储供以后使用。这在使用 "或" 字符 (|) 来组合一个模式的各个部分是很有用。例如, 'industr(?:y|ies) 就是一个比 'industry|industries' 更简略的表达式。 |
\d | 匹配一个数字字符。等价于 [0-9]。 |
\D | 匹配一个非数字字符。等价于 [^0-9]。 |
\xn | 匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。例如,'\x41' 匹配 "A"。'\x041' 则等价于 '\x04' & "1"。正则表达式中可以使用 ASCII 编码。 |
\num | 匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。例如,'(.)\1' 匹配两个连续的相同字符。 |