正則表達(dá)特殊符號(hào)
grep命令-字符串搜尋
-a :將 binary 檔案以 text 檔案的方式搜尋數(shù)據(jù)
-c :計(jì)算找到 '搜尋字符串' 的次數(shù)
-i :忽略大小寫的不同逐哈,所以大小寫視為相同
-n :順便輸出行號(hào)
-v :反向選擇鳞尔,亦即顯示出沒有 '搜尋字符串' 內(nèi)容的那一行孕蝉!
實(shí)例:
查找小寫字母:
grep -n '[[:lower:]]' regular_express.txt
查找數(shù)字:
grep -n '[[:digit:]]' regular_express.txt
搜尋特定字符串‘the’
$ grep -n 'the' regular_express.txt
$ grep -in 'the' regular_express.txt
$ grep -n 'the' regular_express.txt
反向查找,也就是說當(dāng)該行沒有”the“ 字符時(shí)才顯示在屏幕上呐馆。
$ grep -vn 'the' regular_express.txt
grep命令-字符串匹配
[]中包含的任意一個(gè)字符风科。只能是一個(gè)斯议。
字符組支持由連字符“ - ”來表示一個(gè)范圍产捞。當(dāng)“ - ”前后構(gòu)成范圍時(shí),要求前面字符的碼位小于后面字符的碼位哼御。
[^...] 排除型字符組坯临。排除后面的字符。
[abc] :表示“a”或“b”或“c”
[0-9] :表示 0~9 中任意一個(gè)數(shù)字艇搀,等價(jià)于[0123456789]
[\u4e00-\u9fa5] :表示任意一個(gè)漢字
[^a1<] :表示除“a”尿扯、“1”、“<”外的其它任意一個(gè)字符
[^a-z] :表示除小寫字母外的任意一個(gè)字符
實(shí)例:
查找“tast”或者“test”兩個(gè)字符串焰雕。
grep -n 't[ae]st' regular_express.txt
查找不包含“#”的字符串
grep -n '[^#]' regular_express.txt
查找字符“oog”衷笋,如果我不想要“oog”字符前面有 g,則查找“[^g]oog”矩屁,同理辟宗,查找“[^go]oog”是指字符“oog”前面不能為 g 或者 o。
grep -n 'oog' regular_express.txt
grep -n '[^g]oog' regular_express.txt
grep -n '[^go]oog'regular_express.txt
grep -n '[^go]oog'regular_express.txt 結(jié)果返回為空吝秕,表明沒有匹配到滿足要求的字符串泊脐。
行首符^與行尾符$
找行首為大寫字母的所有行:
'^[A-Z]' 表示以大寫字母開頭。
'[^A-Z]' 表示除了大寫字母 A-Z 的所有字符烁峭。
grep -n '^[A-Z]' regular_express.txt
實(shí)例:
查找行首為“the”的字符行容客,則使用以下命令:
grep -n '^the' regular_express.txt
查找以 d 字母結(jié)尾的行:
grep -n 'd$' regular_express.txt
查找空行:
grep -n '^$' regular_express.txt
'^$' : 過濾掉空白行
'^#' :過濾掉注釋行(以#號(hào)開頭)
任意一個(gè)字符小數(shù)點(diǎn)與重復(fù)字符星號(hào)
(星號(hào)):代表重復(fù)前面 0 個(gè)或者多個(gè)字符秕铛。
e: 表示具有空字符或者一個(gè)以上 e 字符。
ee缩挑,表示前面的第一個(gè) e 字符必須存在但两。第二個(gè) e 則可以是 0 個(gè)或者多個(gè) e 字符。
eee供置,表示前面兩個(gè) e 字符必須存在谨湘。第三個(gè) e 則可以是 0 個(gè)或者多個(gè) e 字符。
ee*e :表示前面的第一個(gè)與第三個(gè) e 字符必須存在芥丧。第二個(gè) e 則可以是 0 個(gè)或者多個(gè) e 字符紧阔。
限定連續(xù)字符范圍{}
{ }可限制一個(gè)范圍區(qū)間內(nèi)的重復(fù)字符數(shù)。舉個(gè)例子续担,若要找出 2~5 個(gè) o 的連續(xù)字符串擅耽,如何做? 此時(shí)便要用到{}了赤拒。由于 { 與 } 在 shell 中有特殊意義秫筏,需要用到轉(zhuǎn)義字符\。
實(shí)例:
查找連續(xù)的兩個(gè) o 字符:
grep -n 'o\{2\}' regular_express.txt
結(jié)果與命令 grep -n 'ooo*' regular_express.txt 的結(jié)果相同挎挖。
查找 g 后面接 2 到 5 個(gè) o,然后再接 g 的字符串
grep -n 'go\{2,5\}g' regular_express.txt