-
字符组
[]
[]
会匹配[]内出现的字符任意一次[Pp]ython 匹配Python或者python [0-9] 匹配数字0-9 [1-9a-z] 匹配1-9 a-z [\-] 对于特殊字符需要使用\转义,如匹配- [ 等
-
取反
^
^
为不匹配指定字符[^0-9] 不匹配0-9 爱[^你] 不匹配 你
-
快捷方式
\d 代表任意数字 \w 代表任意字母、数字、下划线 \s 代表空白字符,如空格、tab、换行 \b 匹配单词边界 比如\bapple\b就会匹配单独的单词apple或者,但是对于applea就不会匹配 取反操作 \D 非数字 \W 非字母、数字、下划线 \S 非空白
-
开始和结束
^ 在[]外使用的^指定字符串的开始 如^python,就会匹配以python开头的字符串 $ $用来指定字符串的结尾 如python$,就会匹配结尾处的python
如python is good, I love python
^python
会匹配到python is good, I love pythonpython$
会匹配到python is good, I love python -
任意字符
.
.
可以用来代表任意字符,除了\n
不匹配 -
可选字符
?
? 匹配前面标记出现零次或者一次 如honu?r,此时u就可以出现一次或者没有,即honur和honr都会匹配上
-
重复匹配
{N} 匹配标记连续N次 如\d{3},就会匹配连续的3个数字 如123dd11a可以匹配到123,但是匹配不到11 {M,N} 匹配前面标记M-N次,M下界,N上届,如\d{2,4}匹配1234aa,就会匹配到1234,12aa,就会匹配到12。 注意正则默认为贪婪模式匹配,即尽可能多的匹配字符,因此使用{M,N}匹配时,如果满足有N个标记,就会匹配N个而不会匹配M个,如果想要匹配M个,可以使用{M,N}?,使其变为慵懒模式,尽可能少的匹配标记 \d{2,4} 匹配1234aa就只能匹配到12 {M,} 匹配出现的M次以及M次以上的标记 贪婪模式 两种特殊的情况 +号相当于{1,} 匹配1到无数次 如a\d* 则a1、a12、a123...都会匹配上 *号相当于{0,} 匹配0到无数次 如a\d+ 则a、a1、a12...都会匹配上
-
总结
实例 描述 [Pp]ython
匹配 “Python” 或 “python”。 rub[ye]
匹配 “ruby” 或 “rube”。 [abcdef]
匹配中括号内的任意一个字母。 [0-9]
匹配任何数字。类似于 [0123456789]。 [a-z]
匹配任何小写字母。 [A-Z]
匹配任何大写字母。 [a-zA-Z0-9]
匹配任何字母及数字。 [^au]
除了au字母以外的所有字符。 [^0-9]
匹配除了数字外的字符。 实例 描述 .
匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任何字符,请使用象 ‘[.\n]’ 的模式。 ?
匹配一个字符零次或一次,另一个作用是非贪婪模式 +
匹配1次或多次 *
匹配0次或多次 \b
匹配一个长度为 0
的子串\d
匹配一个数字字符。等价于 [0-9]。 \D
匹配一个非数字字符。等价于 [^0-9]。 \s
匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。 \S
匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。 \w
匹配包括下划线的任何单词字符。等价于[A-Za-z0-9_]。 \W
匹配任何非单词字符。等价于 [^A-Za-z0-9_]。
常用正则匹配语法基础
最新推荐文章于 2024-07-25 16:39:13 发布