首先列出一个强大的网站
基础语法
/(pattern)/(flag)
试例
pattern部分
元字符 | 描述 |
---|---|
^ | 匹配输入的开始。如果多行标志被设置为 true,那么也匹配换行符后紧跟的位置。如^a abc 会被匹配 bca不会被匹配 |
. | 默认匹配除换行符之外的任何单个字符。如果 s 标志位被设为 true,它也会匹配换行符 |
[ ] | 括号表达式。匹配包含在方括号内的单个字符。例如,[abc]匹配“a”、“b”或“c”。[a-z]指定与从“a”到“z”的任何小写字母匹配的范围。 |
[^ ] | 匹配括号内未包含的单个字符。例如,[^abc] 匹配除“a”、“b”或“c”之外的任何字符。 [^a-z] 匹配从“a”到“z”的任何不是小写字母的单个字符。同样,文字字符和范围可以混合使用。 |
$ | 匹配输入的结束。如果多行标志被设置为 true,那么也匹配换行符前的位置。例如,/t$/ 并不会匹配 “eater” 中的 ‘t’,但是会匹配 “eat” 中的 ‘t’。 |
\n | 匹配第n个标记的子表达式匹配的内容,其中n是 1 到 9 之间的数字。例如,/(^8)\1/如果有多个8开始的字符串\1就会匹配第一个匹配到结果 |
* | 匹配前面的元素零次或多次。例如,ab*c匹配“ac”、“abc”、“abbbc”等 |
{m,n} | 匹配前面的元素至少m次但不超过n次。例如,a{3,5}仅匹配“aaa”、“aaaa”和“aaaaa”。 |
? | 匹配前面的元素零次或一次。例如,ab?c仅匹配“ac”或“abc” |
+ | 匹配前面的元素一次或多次。例如,ab+c匹配“abc”、“abbc”、“abbbc”等,但不匹配“ac”。 |
| | 匹配运算符之前的表达式或运算符之后的表达式。例如,abc |
字元集合 | 描述 |
---|---|
\b | 匹配一个词的边界。一个词的边界就是一个词不被另外一个“字”字符跟随的位置或者前面跟其他“字”字符的位置, 如 /m\b/ 就会匹配到“enm”中的m而不会匹配“moon”中的m |
\B | 匹配一个非单词边界。匹配如下几种情况: 字符串第一个字符为非“字”字符 字符串最后一个字符为非“字”字符两个单词 字符之间两个非单词字符之间空字符串 例如,/\B…/匹配"noonday"中的’oo’, 而/y\B…/匹配"possibly yesterday"中的’yes |
\w | 匹配一个单字字符(字母、数字或者下划线)。等价于 [A-Za-z0-9_]。 例如, /\w/ 匹配 “apple,” 中的 ‘a’,"$5.28,"中的 ‘5’ 和 “3D.” 中的 ‘3’。 |
\W | 匹配一个非单字字符。等价于 [^A-Za-z0-9_]。例如, /\W/ 或者 /[^A-Za-z0-9_]/ 匹配 “50%.” 中的 ‘%’。 |
\s | 匹配一个空白字符 |
\S | 匹配一个非空白字符 |
\d | 匹配一个数字。等价于[0-9]。 |
\D | 匹配一个非数字字符。等价于[^0-9]。 |
\z | 匹配字符串的结尾(在单行和多行模式下都是对整个输入而言) |
. | 匹配除换行的字符之外的所有字符。 |
左右合样 | 描述 |
---|---|
() | 定义一个标记的子表达式。括号内匹配的字符串可以稍后调用。模式 /(foo) (bar) \1 \2/ 中的 ‘(foo)’ 和 ‘(bar)’ 匹配并记住字符串 “foo bar foo bar” 中前两个单词 |
(?:x) | 匹配 ‘x’ 但是不记住匹配项。这种括号叫作非捕获括号,使得你能够定义与正则表达式运算符一起使用的子表达式。例如“industr(?:y |
x(?=y) | 匹配’x’仅仅当’x’后面跟着’y’.这种叫做先行断言。 |
(?<=y)x | 匹配’x’仅当’x’前面是’y’.这种叫做后行断言。 |
x(?!y) | 仅仅当’x’后面不跟着’y’时匹配’x’,这被称为正向否定查找。例如,/\d+(?!.)/ 匹配一个数字。正则表达式/\d+(?!.)/"3.141"匹配‘141’而不是‘3.141’ |
flag部分
g global:全局模式
m Multiline :多行模式
i case insensitive:忽略大小写
s singleline:单行模式