正则表达式符号

正则表达式

正则表达式又称规则表达式,通常被用来检索、替换那些符合某个模式(规则)的文本。使用正则表达式可以让我们表达出某种规则,和我们的想法。正则就是规则,正则表达式就是能够让我们表达出自己想法的规则,只要学会了这种规则,我们就能够表达自己的想法。

位置匹配

1
2
3
4
5
6
7
^:表示锚定行首,此字符后面的任意内容必须出现在行首,才能匹配。
$:表示锚定行尾,此字符前面的任意内容必须出现在行尾,才能匹配。
^$:表示匹配空行,这里所描述的空行表示回车,而空格或tab等都不能算作此处所描述的空行。
^abc$:表示abc独占一行时,会被匹配到。
\<或者\b:匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现。
\>或者\b:匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
\B:匹配非单词边界,与\b正好相反。

连续次数的匹配

1
2
3
4
5
6
7
8
9
*:表示前面的字符连续出现任意次,包括0次。
.:表示任意单个字符
.*:表示任意长度的任意字符,与通配符中的*的意思相同。
\?:表示匹配其前面的字符0或1次。
\+:表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
\{n\}:表示前面的字符连续出现n次,将会被匹配到。如果字符连续出现的次数大于指定的次,也是可以匹配到的。
\{x,y\}:表示之前的字符至少连续出现x次,最多连续出现y次,都能被匹配到,换句话说,只要之前的字符连续出现的次数在x与y之间,即可被匹配到。
\{,n\}:表示之前的字符连续出现至多n次,最少0次,都会被匹配到。
\{n,\}表示之前的字符连续出现至少n次,才会被匹配到。

常用符号

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
. :表示匹配任意单个字符
* 表示匹配前面的字符任意次,包括0次
[]:表示匹配指定范围内的任意单个字符
[^ ]:表示匹配指定范围外的任意单个字符

[[:alpha:]]:表示任意大小写字母
[[:lower:]]表示任意小写字母
[[:digit:]]表示0到9之间的任意单个数字(包括0和9)
[[:upper:]]表示任意大写字母
[[:alnum:]]表示任意数字或字母
[[:space:]]表示任意空白字符,包括空格、tab键等。
[[:punct:]]表示任意标点符号

[0-9]与[[:digit:]]等效
[a-z]与[[:lower:]]等效
[A-Z]与[[:upper:]]等效
[a-zA-Z]与[[:alpha:]]等效
[a-zA-Z0-9]与[[:alnum:]]等效
[^0-9]与[[:digit:]]等效

#简短格式并非所有正则表达式解析器都可以识别
\d:表示任意单个0到9的数字
\D:表示任意单个非数字字符
\t:表示匹配单个横向制表符(相当于一个tab键)
\s:表示匹配单个空白字符,包括空格、tab制表符等。
\S:表示匹配单个非空白字符
\w:任意一个字母或数字或下划线,也就是A~Z,a~z,0~9,_ 中任意一个

分组与后向引用

1
2
3
4
\(\):表示分组,我们可以将其中的内容当做一个整体,分组可以嵌套,规则是从左向右的,第1个分组是最左边的括号
\(ab\):表示将ab当做一个整体去处理。
\1:表示引用整个表达式中第1个分组中的正则匹配到的结果。
\2:表示引用整个表达式中第2个分组中的正则匹配到的结果,依次类推。

转义符

\与正则中的符号结合在一起时,就表示这个符号本身的含义。如果是?和+只需要把前面\去掉就表示本身

扩展正则表达式

扩展正则表达式中多了一个|表示或者
其他不同的
?,+,{n},{x,y},{,n},{n,},(),(ab)去掉了反斜线就是扩展正则表达式

grep默认不支持扩展正则表达式,要加上-E来支持扩展正则表达式。