Linux正则表达式简介
一、为什么要学习正则表达式
Linux运维操作主要面对的即是含有大量的字符串的文本,而我们也经常会迫切的需要从大量的字符串中去找到特定的文本信息,正则表达式就是为过滤这样的字符串而生的。
二、什么是正则表达式
正则表达式就是处理大量的字符串的一套规则和方法,快速过滤、替换或者输出需要的信息。
三、正则表达式怎么来用
符号含义
. 匹配除了换行符以外的任意字符
^ 匹配一行的开始位置
$ 匹配一行的结束位置
* 匹配零次或多次前面的字符或表达式
\ 对下一个字符进行转义,使其成为普通的字符,例如\^会将^转义,使其成为普通的^符号,而不再表示匹配一行的开始位置。
[] 中括号可以匹配括号内的任一字符,例如 [aeiou] 表示匹配a、e、i、o、u中的任意一个字符,如果要匹配范围的话,可以在中间加'-',例如:[0-9]表示匹配0到9的任一字符。
() 对正则表达式进行分组
| 在分组中可以匹配|左侧的部分,或者匹配|右侧的部分
? 前面的字符可以存在,也可以不存在,例如a?bc表示匹配abc或者bc
{n} 匹配n次前面的字符
{n,m} 匹配最少n次,最多m次前面的字符
{n,} 匹配最少n次前面的字符,可以超过n次
实际使用示例:
. 匹配除了换行符以外的任意字符
[root@master zhengze]# cat 2 | grep .
aaa bbb
ccc ddd
fff eee
apple
jenkins
kubernetes
docker
docker ps
kubectl get node
kubectl get pod -n namespace
^ 匹配一行的开始位置
[root@master zhengze]# cat 2 | grep ^k
kubernetes
kubectl get node
kubectl get pod -n namespace
$ 匹配一行的结束位置
[root@master zhengze]# cat 2 | grep e$
fff eee
apple
kubectl get pod -n namespace
*匹配零次或多次前面的字符或表达式
[root@master zhengze]# cat 2 | grep eee*
fff eee
\ 对下一个字符进行转义,使其成为普通的字符,例如^会将转义,使其成为普通的符号,而不再表示匹配一行的开始位置。
[root@master zhengze]# cat 2 | grep ^\^
^^^
[] 中括号可以匹配括号内的任一字符,例如 [aeiou] 表示匹配a、e、i、o、u中的任意一个字符,如果要匹配范围的话,可以在中间加’-’,例如:[0-9]表示匹配0到9的任一字符。
[root@master zhengze]# cat 2 | grep "[aeiou0-9k]"
aaa bbb
fff eee
apple
jenkins
kubernetes
docker
docker ps
kubectl get node
kubectl get pod -n namespace
78910jqk
4567567
120320211024
888
666
777
() 对正则表达式进行分组
[root@master zhengze]# cat 2 | grep "\(8\)"
78910jqk
888
[root@master zhengze]# cat 2 | grep "^\(8\)"
888
| 在分组中可以匹配|左侧的部分,或者匹配|右侧的部分
[root@master zhengze]# cat 2 | grep "\(^8\)\|\(7\)$"
4567567
888
777
? 前面的字符可以存在,也可以不存在,例如a?bc表示匹配abc或者bc
[root@master zhengze]# cat 2 | grep '8\?88'
888
{n} 匹配n次前面的字符
{n,m} 匹配最少n次,最多m次前面的字符
{n,} 匹配最少n次前面的字符,可以超过n次