Shell编程:正则表达式(位置锚定、分组或者、扩展正则)



正则表达式 2

位置锚定

行锚定

  • ^ 行首锚定:用于模式的最左侧,表示匹配行首。
  • $ 行尾锚定:用于模式的最右侧,表示匹配行尾。

示例:

  • ^root$ 匹配整行,只有 “root” 的行。
  • ^$ 匹配空行。
  • ^[[:space:]]*$ 匹配空白行。

单词锚定

  • \<\b 词首锚定:用于单词模式的左侧,表示匹配词首(单词由连续的字母、数字、下划线组成)。
  • \>\b 词尾锚定:用于单词模式的右侧,表示匹配词尾。

示例:

  • \<root\> 匹配整个单词 “root”。

示例

  1. 过滤出不是以 # 号开头的非空行:

    grep "^[^#]" /etc/fstab
    
  2. 匹配整行内容为 “google” 的行:

    grep "^google$" test.txt
    
  3. 匹配空白行:

    grep "^[[:space:]]*$" /etc/fstab
    
  4. 匹配以单词 “123” 开头的字符串:

    echo hello-123 | grep "\b123"
    
  5. 匹配单词 “hello” 的字符串:

    echo hello-123 | grep "\bhello"
    
  6. 匹配以 “o-123” 为词首的字符串(匹配不到,因为 “o” 不是词首):

    echo hello-123 | grep "\bo-123"
    

分组与其他

分组

  • () 用于将多个字符捆绑在一起,当作一个整体处理。

或者

  • \| 用于表示逻辑“或”。

示例

  1. 匹配字符 c 出现 3 次的字符串:

    echo abccc | grep "abc\{3\}"
    
  2. 匹配字符串 “abcabcabc” 中的 “abc” 出现 3 次:

    echo abcabcabc | grep "\(abc\)\{3\}"
    
    echo abcabcabc | grep "\(ab\)\{3\}" 
    #不能匹配,因为要连续的出现才能匹配
    
  3. 匹配字符串 “golgogle” 中的 “go” 出现 1 次:

    echo golgogle | grep '\(go\)\{1\}'
    
    echo golgogle | grep  '\(go\)\{1\}gle' 
    #只能匹配后面的 golgogle
    
  4. 匹配字符串 “1abc” 中的字符 “1” 或 “2abc”:

    echo 1abc | grep "1\|2abc"
    
  5. 匹配字符串 “1abc2abc” 中的 “1abc” 或 “2abc”:

    echo 1abc2abc | grep "\(1\|2\)abc"
    

扩展正则表达式

扩展正则表达式可以使用 grep -Eegrep,或使用 sed -r。可以省去转义符 \ ,点 . 仍需要转义。(表示字符相差不大)

表示次数

  • * 匹配前面的字符任意次。
  • ? 匹配前面的字符 0 或 1 次。
  • + 匹配前面的字符 1 次或多次。
  • {n} 匹配前面的字符 n 次。
  • {m,n} 匹配前面的字符至少 m 次,至多 n 次。
  • {,n} 匹配前面的字符至多 n 次,n 可以为 0。
  • {n,} 匹配前面的字符至少 n 次,n 可以为 0。

表示分组

  • () 用于分组,将多个字符捆绑在一起。

  • | 用于表示逻辑“或”。

    a|b     #a或b
    C|cat   #C或cat
    (C|c)at #Cat或cat
    

示例

  1. 匹配 IP 地址:

    ifconfig ens33 | grep netmask | grep -E '[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+'
    
  2. 匹配电话号码:

    grep -E "[0-9]+-[0-9]+" number.txt
    

    输出示例:

    025-83346023
    0510-8776655
    0527-9888899
    
  3. 匹配邮箱地址:

    echo "544564317@qq.com" | grep -E "[0-9]+@[a-z]+\.[a-z]+"
    
  4. 匹配手机号:

    echo "13770725194" | grep -E "\b1[3456789][0-9]{9}\b"
    
  5. 匹配邮箱地址(包括大小写字母):

    echo "CICIfireway@163.com" | grep -E "[a-zA-Z]+@[0-9]+\.[a-z]+"
    
  6. 匹配混合字符的邮箱地址:

    grep -E "[a-zA-Z0-9]+@[0-9a-z]+\.[a-z]+" email.txt
    
  7. 匹配美国电话号码:

    grep -E '^(\([0-9]+\)|[0-9]+)[ -]?[0-9]+[ -]?[0-9]+' file.txt
    

    文件内容示例:

    987-123-4567
    987 456-1230
    (123) 456-7890
    

  • 11
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值