Shell编程-基础正则表达式

一、正则表达式与通配符

  正则表达式:用来在文件中匹配符合条件的字符串,正则表达式是包含匹配。grep、awk、sed等命令可以支持正则表达式。

  通配符:用来匹配符合条件的文件名,通配符是完全匹配。ls、find、cp这些命令不支持正则表达式,所以只能使用shell自己的通配                        符来进行匹配。

二、基础正则表达式

元字符 作用
* 前一个字符匹配0次或任意多次
. 匹配除了换行符外任意一个字符
^ 匹配行首,例如:^hello会匹配以hello开头的行
$ 匹配行尾,例如hello$会匹配以hello结尾的行
[]

匹配中括号中指定的任意一个字符,只匹配一个字符

例如:[aoeiu]匹配任意一个元音字母

           [0-9]匹配任意一位数字

      [a-z][0-9]匹配一个小写字母和一位数字构成的两位字符

[^]

匹配除中括号的字符以外的任意一个字符

例如:[^0-9]匹配任意以为非数字字符

      [^a-z]匹配任意一位非小写字母的字符

\ 转义符,用于取消特殊符号的含义
\{n\}

表示其前面的字符恰好出现n次

例如:[0-9]\{4\}匹配4位数字

      [1][3-8][0-9]\{9\}匹配手机号码

\{n,\}

表示其前面的字符出现不小于n次

例如:[0-9]\{2,\}表示两位及以上的数字

\{n,m\}

表示其前面的字符至少出现n次,最多出现m次

例如:[a-z]\{6,8\}匹配6到8位的小写字母

  示例:

复制代码
# 测试文件
[root@bogon ~]# vi test.rule.txt
      1 Mr. Li Ming said:
      2 he was the honest man in LampBrother.
      3 123despise him.
      4 
      5 But since Mr. shen Chao come.
      6 he never said those words.
      7 $$$$$nice!
      8 
      9 because.actuaaaaliy.
     10 Mr. Shen Chao is the most honest man!
     11 
     12 Later,Mr. Li ming soid his hot body.
复制代码
复制代码
# *前一个字符匹配0次,或任意多次
# 匹配所有内容,包括空白行
[root@bogon ~]# grep "a*" test_rule.txt  
# 匹配至少包含有一个a的行
[root@bogon ~]# grep "aa*" test_rule.txt

# "." 匹配除了换行符外任意一个字符
# 匹配s和d之间一定有两个字符的行
[root@bogon ~]# grep "s..d" test_rule.txt
# 匹配在s和d之间有任意字符的行,包括s和d挨着的行
[root@bogon ~]# grep "s.*d" test_rule.txt
# 匹配所有内容
[root@bogon ~]# grep ".*" test_rule.txt

# "^"匹配行首,"$"匹配行尾
# 匹配以大写M开头的行
[root@bogon ~]# grep "^M" test_rule.txt
# 匹配以小写n结尾的行
[root@bogon ~]# grep "n$" test_rule.txt
# 匹配空白行,并标注行号
[root@bogon ~]# grep -n "^$" test_rule.txt

# "[]"匹配中括号中指定的任意一个字符
# 匹配s和i字符中间,要么是a、要么是0的行
[root@bogon ~]# grep "s[ao]id" test_rule.txt
# 匹配任意一个数字
[root@bogon ~]# grep "[0-9]" test_rule.txt
# 匹配用小写字母开头的行
[root@bogon ~]# grep "^[a-z]" test_rule.txt

# "[^]"匹配除中括号的字符以外的任意一个字符
# 匹配不用小写字母开头的行
[root@bogon ~]# grep "^[^a-z]" test_rule.txt
# 匹配不用字母开头的行
[root@bogon ~]# grep "^[^a-zA-Z]" test_rule.txt

# "\"转义符
# 匹配使用"."结尾的行
# 不转义,.表示除换行外任意一个字符,将匹配所有内容
[root@bogon ~]# grep "\.$" test_rule.txt

# "\{n\}"表示其前面的字符恰好出现n次
# 匹配a字母连续出现三次的行
[root@bogon ~]# grep "a\{3\}" test_rule.txt
# 匹配包含联系三个数字的行
[root@bogon ~]# grep "[0-9]\{3\}" test_rule.txt

# "\{n,\}" 表示其前面的字符出现不小于n次
# 匹配最少用连续三个数字开头的行
[root@bogon ~]# grep "^[0-9]\{3,\}[a-z]" test_rule.txt

# "\{n,m\}" 表示其前面的字符至少出现n次,最多出现m次
# 匹配在字母a和字母i之间最少一个a,最多三个a的行
[root@bogon ~]# grep "sa\{1,3\}i" test_rule.txt
复制代码

 

posted @   风雪夜_归人  阅读(48)  评论(0编辑  收藏  举报
(评论功能已被禁用)
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示