日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Linux行處理工具之grep?正則表達式詳解_正則表達式

作者:pdudo ? 更新時間: 2022-10-04 編程語言

之前我們學習了linux grep的基本操作,以及提及了linux grep的孿生兄弟egrep 和 fgrep,這次我們來看下。

在介紹正則表達式之前,我們先來嘗試一下,假如有如下文本。

我們想獲取空行,應該如何來寫呢?

命令:

grep ^$ test1 -n

通過上述例子,我們使用正則表達式^$已經成功拿到了第四行數據,那么,這究竟如何解呢,我們細看博文。

正則表達式在grep應用以及差別

grep表達式有三種不同的版本,分別為basic(BRE) 、extendedERE) 以及 perl(PCRE) ,我們grep默認支持的是BRE,而EREegrep支持的,或者說是grep -E支持的, 而PCRE則是grep -P支持的,那么這三者究竟有啥區別呢?

? BRE ERE PCRE
任意字符 . . .
前一個字符0次或者出現1次 ? ? ?
前一個字符出現0次或無數次 * * *
前一個字符出現一個或者更多 + + +
字符集 [...] [...] [...]
字符集取反 [^...] [^...] [^...]
匹配前面字符出現的n次 {n} {n} {n}
匹配前面字符出現的n次以上 {n,} {n,} {n,}
匹配前面字符出現的n次到m次 {n,m} {n,m} {n,m}
開頭
結尾 $ $ $
多表達式連接 | ? ? ? ?
單詞 \w \w \w 或者 [[:word:]]
字母大寫/小寫 [[:upper:]]/[[:lower:]] [[:upper:]]/[[:lower:]] [[:upper:]]/[[:lower:]]
非單詞 ? ? \W
空白字符 \s 或者 [[:space:]] \s 或者 [[:space:]] ?
非空白字符 [^[:space:]] [^[:space:]] \S
數字 \d 或者 [[:digit:]] [[:digit:]] [[:digit:]]
非數字 \D [^[:digit:]] [^[:digit:]]

那么如何進行切換呢? 如上面所示,我們來看下。

如上所述,若我們需要連接多個匹配項,在BRE(grep)中則是|,而在ERE(egrep)PCRE(grep -P)中則是|,所以我們可以順利獲取出結果,更多匹配項如上所述

匹配案例

匹配電話號碼

若電話號碼為xxx-xxxx-xxxx類型的,如何進行匹配呢? 我們可以使用'[0-9]{3}-[0-9]{4}-[0-9]{4}'進行匹配。

例如:

命令:

echo "telphone: 180-1234-5678" | grep  '[0-9]{3}-[0-9]{4}-[0-9]{4}' -o

同樣的,該方法還可以用來匹配其ip地址,正則: [0-9]{0,3}.[0-9]{0,3}.[0-9]{0,3}.[0-9]{0,3}

匹配空行

若我們想匹配空行,則可以使用^$進行匹配,即: 開頭就是結尾。

例如:

如上命令,我們順利取出了 第3、5、6行數據

匹配所有字母

命令:

echo 'Ac123e23dddwQW21' | grep "[[:upper:]]|[[:lower:]]" -o

取出redis在使用的配置文件

我們知道redis服務器是以#來注釋的,我們可以利用grep或者egrep來過濾掉注釋和空格,例如:

fgrep

fgrep最為簡單,它不會啟用正則表達式,而是按照字符來進行搜索,什么意思呢? 我們舉個小案例就清楚了,

它不會進行任何正則匹配,所以可以直接使用搜索選就成,不用考慮轉移啥的。

總結

我們一般將BRE稱之為 基本正則表達式、ERE稱之為 擴展正則表達式 而 PCRE稱之為Perl兼容的正則表達式,如上正則表達式不是grep工具所實現的,而是單獨的一套表達式,有很多語言在使用中,例如 sed默認正則表達式是 BRE, 而我們之前所學習的awk使用的正則表達式則是ERE,是不是感覺知識被串聯起來了呢,好巧,我也是,怎么樣,快來動手試驗一下吧。

原文鏈接:https://juejin.cn/post/7129495277093797918

欄目分類
最近更新