加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

扩展正则表达式

发布时间:2020-12-13 22:23:03 所属栏目:百科 来源:网络整理
导读:去除空行与#开头的行 grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次 下面使用扩展正则表达式 egrep -v '^$|^#' a.txt + 重复一个或一个以上的字符 搜索god good goood等字符串,o+代表一个以上的o egrep -n 'go+d' a.txt ? 0个或1个字符 搜索gd


去除空行与#开头的行
grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次
下面使用扩展正则表达式
egrep -v '^$|^#' a.txt

+ 重复一个或一个以上的字符
搜索god good goood等字符串,o+代表一个以上的o
egrep -n 'go+d' a.txt
? 0个或1个字符
搜索gd 或者 god字符串的行
egrep -n 'go?d' a.txt
| 用或(or)的方式找出数个字符串
egrep -n 'gd|good' a.txt
找出含有gd或者god的字符串的行
() 找出含有glad或good或gaad或glod这两个字符串的行
egrep -n 'g(la|oo|aa|lo)' a.txt
!在正则表达式中不是特殊字符
查找出含有(!)与(>)的行
grep -n '[!>]' a.txt
RE 字符 意义与范例
+ 重复『一个或一个以上』的前一个 RE 字符
范例:egrep -n 'go+d' regular_express.txt
搜寻 (god) (good) (goood)... 等等的字符串。 那个 o+ 代表『一个以上的 o 』所以,上面的执行成果会将第 1,9,13 行列出来。
? 『零个或一个』的前一个 RE 字符
范例:egrep -n 'go?d' regular_express.txt
搜寻 (gd) (god) 这两个字符串。 那个 o? 代表『空的或 1 个 o 』所以,上面的执行成果会将第 13,14 行列出来。
有没有发现到,这两个案例( 'go+d' 与 'go?d' )的结果集合与 'go*d' 相同? 想想看,这是为什么喔! ^_^
| 用或( or )的方式找出数个字符串
范例:egrep -n 'gd|good' regular_express.txt
搜寻 gdgood 这两个字符串,注意,是『或』! 所以,第 1,14 这三行都可以被打印出来喔!那如果还想要找出 dog 呢?就这样啊:
egrep -n 'gd|good|dog' regular_express.txt
( ) 找出『群组』字符串
范例:egrep -n 'g(la|oo)d' regular_express.txt
搜寻 (glad) 或 (good) 这两个字符串,因为 g 与 d 是重复的,所以, 我就可以将 la 与 oo 列于 ( ) 当中,并以 | 来分隔开来,就可以啦!
此外,这个功能还可以用来作为『多个重复群组』的判别喔!举例来说:
echo 'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C'
上面的例子当中,意思是说,我要找开头是 A 结尾是 C ,中间有一个以上的 "xyz" 字符串的意思~

以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
    grep -n '[!>]' regular_express.txt
这样可以了解了吗?!常常看到有陷阱的题目写:『反向选择这样对否? '[!a-z]'?』, 呵呵!是错的呦~要 '[^a-z] 才是对的!
去除空行与#开头的行
grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次
下面使用扩展正则表达式
egrep -v '^$|^#' a.txt

+ 重复一个或一个以上的字符
搜索god good goood等字符串,o+代表一个以上的o
egrep -n 'go+d' a.txt
? 0个或1个字符
搜索gd 或者 god字符串的行
egrep -n 'go?d' a.txt
| 用或(or)的方式找出数个字符串
egrep -n 'gd|good' a.txt
找出含有gd或者god的字符串的行
() 找出含有glad或good或gaad或glod这两个字符串的行
egrep -n 'g(la|oo|aa|lo)' a.txt
!在正则表达式中不是特殊字符
查找出含有(!)与(>)的行
grep -n '[!>]' a.txt
RE 字符 意义与范例
+ 重复『一个或一个以上』的前一个 RE 字符
范例:egrep -n 'go+d' regular_express.txt
搜寻 (god) (good) (goood)... 等等的字符串。 那个 o+ 代表『一个以上的 o 』所以,上面的执行成果会将第 1,13 行列出来。
? 『零个或一个』的前一个 RE 字符
范例:egrep -n 'go?d' regular_express.txt
搜寻 (gd) (god) 这两个字符串。 那个 o? 代表『空的或 1 个 o 』所以,上面的执行成果会将第 13,14 行列出来。
有没有发现到,这两个案例( 'go+d' 与 'go?d' )的结果集合与 'go*d' 相同? 想想看,这是为什么喔! ^_^
| 用或( or )的方式找出数个字符串
范例:egrep -n 'gd|good' regular_express.txt
搜寻 gdgood 这两个字符串,注意,是『或』! 所以,第 1,14 这三行都可以被打印出来喔!那如果还想要找出 dog 呢?就这样啊:
egrep -n 'gd|good|dog' regular_express.txt
( ) 找出『群组』字符串
范例:egrep -n 'g(la|oo)d' regular_express.txt
搜寻 (glad) 或 (good) 这两个字符串,因为 g 与 d 是重复的,所以, 我就可以将 la 与 oo 列于 ( ) 当中,并以 | 来分隔开来,就可以啦!
此外,这个功能还可以用来作为『多个重复群组』的判别喔!举例来说:
echo 'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C'
上面的例子当中,意思是说,我要找开头是 A 结尾是 C ,中间有一个以上的 "xyz" 字符串的意思~

以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
    grep -n '[!>]' regular_express.txt
这样可以了解了吗?!常常看到有陷阱的题目写:『反向选择这样对否? '[!a-z]'?』, 呵呵!是错的呦~要 '[^a-z] 才是对的!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读