Shell正则表达式

发布于:2025-03-24 ⋅ 阅读:(24) ⋅ 点赞:(0)

基本正则列表

正则符号 描述
^ 匹配行首
$ 匹配行尾
[] 集合,匹配集合中的任意单个字符
[^] 对集合取反
. 匹配任意单个字符
* 匹配前一个字符任意次数 [*不允许单独使用]
\{n,m\} 匹配前一个字符n到m次
\{n\} 匹配前一个字符n次
\{n,\} 匹配前一个字符n次及以上
\(\) 组合为整体,保留

扩展正则列表

正则符号 描述
+ 最少匹配一次
最多匹配一次
{n,m} 匹配前一个字符n到m次
() 组合为整体,保留
| 或者
\b 单词边界

步骤

1)基本正则表达式
[root@sv7 ~]# cp /etc/passwd user  #准备素材

测试 ^  $  []  [^]
[root@sv7 ~]# grep root user        #查找root相关的行
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

[root@sv7 ~]# grep ^root user       #找以root开头的行
root:x:0:0:root:/root:/bin/bash

[root@sv7 ~]# grep bash$ user       #找以bash结尾的行
root:x:0:0:root:/root:/bin/bash
alice:x:1001:1001::/home/alice:/bin/bash
jim:x:1002:1002::/home/jim:/bin/bash
...

[root@sv7 ~]# grep ^$ user         #找空行
[root@sv7 ~]# grep -v ^$ user      #取反,显示除了空行的内容
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
...

[root@sv7 ~]# grep "[root]" user      #找r、o、t任意一个字符 
[root@sv7 ~]# grep "[rot]" user       #效果同上
[root@sv7 ~]# grep "[^rot]" user      #对集合取反,显示r或o或t以外的内容

[root@sv7 ~]# grep "[0123456789]" user   #找所有数字
[root@sv7 ~]# grep "[0-9]" user       #效果同上
[root@sv7 ~]# grep "[^0-9]" user      #显示数字以外内容

[root@sv7 ~]# grep "[a-z]" user       #找所有小写字母
[root@sv7 ~]# grep "[A-Z]" user       #找所有大写字母
[root@sv7 ~]# grep "[a-Z]" user       #找所有字母
[root@sv7 ~]# grep "[^0-9a-Z]" user     #找所有符号

 

测试 .  *
[root@sv7 ~]# grep "." user         #找任意单个字符,文档中每个字符都可以理解为任意字符
[root@sv7 ~]# grep "r..t" user      #找rt之间有2个任意字符的行
[root@sv7 ~]# grep "r.t" user       #找rt之间有1个任意字符的行,有匹配就输出;没有匹配就无输出
[root@sv7 ~]# grep "*" user         #错误用法,*号是匹配前一个字符任意次,不能单独使用
[root@sv7 ~]# grep "a*" user        #此时看到的结果是带a的已经匹配出来,但是仔细看结果发现没有a的行也匹配出来了。这是因为a匹配前一个字符任意次(包括0次,a不出现也行),如果想要解决这问题,可以匹配时再加一个a,如 grep "aa*" user(第一个a必须出现,第二个a匹配可以没有,也可以有)
[root@sv7 ~]# grep "ro*t" user       #找rt,中间的o有没有都行,有几次都行
[root@sv7 ~]# grep ".*" user        #找任意,包括空行 .与*的组合在正则中相当于通配符的效果

测试  \{n\}  \{n,\}  \{n,m\}  \(\)
[root@sv7 ~]# grep "o\{1,2\}" user              #找o,可以匹配1~2次
[root@sv7 ~]# echo rooooot | grep "o\{3,\}"     #找o,可以匹配3个以及以上,都会匹配
[root@sv7 ~]# echo rooooot | grep "o\{3\}"      #找o,只匹配3个

[root@sv7 ~]# echo ababab | grep "\(ab\)\{3,5\}"    #匹配ab 3~5次,小括号的作用是将字符组合为一个整体
ababab  

2)扩展正则表达式,以上命令均可以加-E选项并且去掉所有\,-E使用扩展正则的用法
[root@sv7 ~]# grep a+ user          #使用扩展正则没反应
[root@sv7 ~]# grep -E a+ user       #-E选项使用扩展正则,有结果显示,最少匹配a一次,上不封顶
[root@sv7 ~]# egrep a+ user         #使用扩展正则

[root@sv7 ~]# echo ababab | grep "\(ab\)\{3,5\}"    #匹配ab 3~5次,小括号的作用是将字符组合为一个整体
ababab  
可以简写为以下步骤
[root@sv7 ~]# echo ababab | grep -E "(ab){3,5}"
ababab

测试 | 或者的意思
[root@sv7 ~]# echo abcdef | grep -E "(ab|ef)"    #找ab或者ef
abcdef

测试\b 单词边界
[root@sv7 ~]# echo iwanttheapple | grep "the"   #可以过滤出the
iwangttheapple
[root@sv7 ~]# echo iwanttheapple | grep -E "\bthe"  #结果the不出来,the前面不能有内容,需要是一个独立的the才能出来

[root@sv7 ~]# echo iwant theapple | grep -E "\bthe" #字符串the前面加空格
iwant theapple
[root@sv7 ~]# echo iwant theapple | grep -E "\bthe\b"   #后面加\b结果也是出不来,the后面也能不能有内容
[root@sv7 ~]# echo iwant the apple | grep -E "\bthe\b"  #the后面加空格,才能出来
iwant the apple


网站公告

今日签到

点亮在社区的每一天
去签到