Linux基礎——grep匹配命令
阿新 • • 發佈:2019-01-29
正則就是有一定規律的字串,不僅可以使用命令列工具grep, sed,awk ,egrep去引用正則,還可以把正則嵌入到 nginx,apache,甚至php,python中。特殊符號(. * + ? |)
grep,主要用來過濾出指定的行。指定的條件,用正則表示式。
1、語法選項
grep [-civnABC] 'word' filename
-n 在輸出符合要求的行的同時,連同行號一起輸出
-c 列印符合要求的行數
-v 列印不符合要求的行
--color 匹配到的關鍵字用紅色標識
-A 後跟一個數字,空格可有可無,-A2 表示列印符合要求的行以及下面兩行
-B 後跟一個數字,-B2 表示列印符合要求的行以及上面兩行
-C 後跟一個數字,-C2 表示列印符合要求的行以及上下各兩行
-r 把目錄下面所有的檔案全部遍歷 【不是很常用】
-i 不區分大小寫
-E 脫意字元\的作用
#grep -r "iptables" /etc/* 顯示該目錄下所有包含該字元的資訊,包含檔案路徑
#grep -rh "iptables" /etc/* 不顯示檔案路徑,直接顯示結果
2、例子介紹
#alias grep='grep --color'
#cp /etc/passwd 1.txt
#grep '[cnsoe]' 1.txt 取其中任意一個進行匹配,匹配cnsoe中的任何一個
#grep '[0-9]' 1.txt 匹配包含任意數字
#grep '[^0-9]' 1.txt 匹配包含非數字的行,某行有數字,字母,特殊字元,也會顯示出來。
#grep '^[0-9]' 1.txt 取數字開頭的行
#grep -v '[0-9]' 1.txt 匹配不包含數字的行,可匹配空行,特殊字元
#grep -v '^[0-9]' 1.txt 匹配非0-9開頭的行,可匹配空行,特殊字元
#grep '^[^0-9]' 1.txt 取不以數字開頭的行,可匹配特殊符號,不包括空行
#grep '^$' 1.txt 取空行,不包含任何字元的行,空格也算特殊字元
#grep '[^a-zA-Z]' 匹配包含非字母的行,並非全部都沒有字母,只要含有非字母都可以
#grep '^[1-9][0-9]*$' 1.txt:匹配開頭為1到9其中一個數字,結尾是0個或多個數字 ?????
'r.o' .表示任意一個字元,包括特殊符號。
'r\?o' ?表示零個或一個?前面的字元;匹配出的結果又 roo ,r\?o中表示匹配前面字元0次或1次,即匹配ro或o,所以,roo應該分開看,前兩個字元ro是匹配字元‘r’一次,o是匹配字元‘r’0次,同理oo也是分開看,都是匹配字元‘r’0次。
'r+o' +表示大於等於1個+號前面的字元
'r*o' *表示零個或多個*號前面的字元,
'r.*o' .* 任意一個字元+任意一個星號*前面的字元==任意零個或多個任意字元,r開頭o結尾的字元,中間不重要,可以使特殊符號,貪婪匹配
'r*.o' 匹配出o前面有零個或者多個任意字元的行
-E 'r?o' -E 和 脫意符號\的作用一樣,grep -E == egrep
過濾出帶有某個關鍵字的行並輸出行號
#grep -n 'root' 1.txt
過濾出不帶某個關鍵詞的行並輸出行號
#grep -n -v 'root' 1.txt
過濾出所有包含數字的行
#grep '[0-9]' 1.txt 任意一個數字都可以匹配,多個也可以
過濾所有不包含數字的行
#grep -v '[0-9]' 1.txt
去除所有以"#"開頭的行
#grep -v '^#' 1.txt
去除所有空行和以 # 開頭的行
#grep -v '^$' 1.txt |grep -v '^#'
過濾英文字母開頭的行
#grep '^[a-zA-Z]' 1.txt
過濾以非數字開頭的行
#grep '^[^0-9]' 1.txt 匹配結果會首字母會顏色標出,匹配特殊符號
#grep -nv '^[0-9]' 1.txt 匹配結果差別在下面這個沒有顏色,匹配特殊符號以及空行
過濾任意一個或多個字元 包含r.o,s*.d,p.*x的字元
#grep 'r.o' 1.txt ; grep 'r*t' 1.txt ; grep 'r.*t' 1.txt
. 表示任意一個字元
* 表示 零個 或 多個 前面的字元
.* 表示零個或多個任意字元,空行也包含在內
過濾出包含 root 的行以及下面一行
#grep -A 1 'root' 1.txt
過濾出包含root的行以及上面一行
#grep -B 1 ‘root' 1.txt
指定過濾字元次數 匹配一個oo的行
#grep 'o\{2\}' 1.txt
過濾包含2個字母o的行
3、egrep
grep工具的擴充套件,可以實現所有的grep功能,可以用grep -E代替egrep。為方便可全部使用egrep來代替grep。
#alias egrep='egrep --color'
#grep 'r\?o' 1.txt == egrep 'r\?o' 1.txt== grep -E 'r?o' 1.txt
匹配 1 個或 1 個以上 + 前面的字元 匹配o+
#egrep 'o+' 1.txt
匹配 0 個或 1 個 ? 前面字元 匹配o?
#egrep 'o?' 1.txt
匹配 roo 或者 匹配 body
#egrep 'roo|body' 1.txt
匹配包含roo 並且 包含 log 的行
#egrep 'roo' 1.txt |egrep 'roo|log'
#egrep 'log' 1.txt |egrep 'roo|log'
用括號表示一個整體,例子會匹配 roo 或者 ato
#egrep 'r(oo)|(at)o' 1.txt
匹配 1 個或者多個 'oo'
#egrep '(oo)+' 1.txt
匹配 1 到 3 次 'oo'
#egrep '(oo){1,3}' 1.txt
匹配結果出現9個o,{1,3}進行了多次匹配,也可以理解為包含但不限於1-3次。1.txt檔案中某一行能匹配oo 1次、2次、3次都符合條件。對於 oooooooooo,前面6個o 符合:匹配oo3次;後面4個o符合匹配oo2次
#egrep '(oo){6}' 1.txt 匹配6個
#egrep '(oo)'{6,} 1.txt 匹配6個以上
4、. * + ? 總結 統配字元
. 任意字元,包括特殊字元,下劃線,空格,
* 零個 或者 多個 *前面的字元
.* 任意數量任意字元,包括空行
*. 'r*.o' 匹配出o前面有零個或者多個任意字元的行
+ 表示 1 個或 多個 + 前面的字元 僅限egrep
? 表示 0 個或 1 個?前面的字元 僅限egrep
grep 表示式裡面出現 ? + ( ) { } | 這幾個特殊符號,需要前面加脫意符號,或者使用 grep -E ,或者使用egrep,故方便起見,全部使用egrep。
擴充套件 --include 指定檔案
grep 其實還可以這樣使用:
在tmp目錄下,過濾所有 *.txt 文件中含有root的行
grep -r --include="*.txt" 'root' /
data目錄下,所有 *.php 文件中包含eval的行
egrep -rhn --include="*.php" 'eval' 1.txt