grep命令:正則表達式
模版:ide
M.Tansley 05/99 48311 Green 8 40 44.44spa
J.Lulu 06/99 48317 green 9 24 2678.文檔
P.Bunny 02/99 48 Yellow 12 35 2658字符串
J.Troll 07/99 4842 Brown-3 12 26 266666it
L.Tansley 05/99 4712 Brown-2 12 30 44544class
單雙引號:變量
在匹配模式時須要有單引號。擴展
在匹配字符串(「123 ABC」,若是不加雙引號grep命令會將ABC當成文件。)和變量時須要用雙引號。grep
grep容許使用國際字符模式匹配或匹配模式的類名形式。
類名及其等價的正則表達式
類等價的正則表達式
[[ : u p p e r : ]] [ A - Z ]
[[ : a l n u m : ]] [ 0 - 9 a - zA-Z]
[[ : l o w e r : ]] [ a - z ]
[[ : s p a c e : ]] 空格或t a b鍵
[[ : d i g i t : ]] [ 0 - 9 ]
[[ : a l p h a : ]] [ a - z A - Z ]
參數:
-c:計算匹配模式的個數。
例:[root@localhost GREP]# grep -c Green data.f
1
-i:不區分大小寫。
例:[root@localhost GREP]# grep -i green data.f
M.Tansley 05/99 48311 Green 8 40 44.44
J.Lulu 06/99 48317 green 9 24 2678.
[root@localhost GREP]# grep "[Gg]reen" data.f 釋:也能夠用範圍模式來匹配,單引號也能夠。
M.Tansley 05/99 48311 Green 8 40 44.44
J.Lulu 06/99 48317 green 9 24 2678.
-h:在多個文件中匹配模式,忽略文件名。
例:[root@localhost GREP]# grep green data.f data.f.bak
data.f:J.Lulu 06/99 48317 green 9 24 2678.
data.f.bak:J.Lulu 06/99 48317 green 9 24 2678.
[root@localhost GREP]# grep -h green data.f data.f.bak
J.Lulu 06/99 48317 green 9 24 2678.
J.Lulu 06/99 48317 green 9 24 2678.
-l:顯示匹配模式的所在文件。
例:[root@localhost GREP]# grep -l green data.f data.f.bak
data.f
data.f.bak
[root@localhost GREP]# grep -l green *釋:「*」 查找當前目錄下全部文件也能夠"*.後綴名"這樣使用,對其匹配。
data.f
data.f.bak
-n:顯示匹配模式的行號。
例:[root@localhost GREP]# grep -n green data.f
2:J.Lulu 06/99 48317 green 9 24 2678.
-s:忽略因文件不存在返回的信息。
例:[root@localhost GREP]# grep green ABC 釋:在本目錄下沒有ABC個文件,因此返回錯誤信息。加-s參數後錯誤信息忽略。
grep: ABC: 沒有那個文件或目錄
[root@localhost GREP]# grep -s green ABC
[root@localhost GREP]# echo $?
2
-v:反查找信息。
例:[root@localhost GREP]# cat data.f.bak 釋:用變量代替所要匹配的模式。
green
Yellow
[root@localhost GREP]# AAA=`cat data.f.bak`
[root@localhost GREP]# echo $AAA
green Yellow
[root@localhost GREP]# grep -v "$AAA" data.f
M.Tansley 05/99 48311 Green 8 40 44.44
J.Troll 07/99 4842 Brown-3 12 26 266666
L.Tansley 05/99 4712 Brown-2 12 30 44544
精確匹配:
例:[root@localhost GREP]# grep "48\>" data.f
P.Bunny 02/99 48 Yellow 12 35 2658
範圍匹配:
例:[root@localhost GREP]# grep "48[34]" data.f 釋:「[]」能夠用來指定字符串範圍。
M.Tansley 05/99 48311 Green 8 40 44.44
J.Lulu 06/99 48317 green 9 24 2678.
J.Troll 07/99 4842 Brown-3 12 26 266666
是否匹配行首:
例:[root@localhost GREP]# grep "^[^J]" data.f 釋:若是要抽其行首不是48,能夠在方括號中使用^記號,代表查詢在行首開始。
M.Tansley 05/99 48311 Green 8 40 44.44
P.Bunny 02/99 48 Yellow 12 35 2658
L.Tansley 05/99 4712 Brown-2 12 30 44544
例:[root@localhost GREP]# grep "^J" data.f 釋:「^」若是是已什麼來開頭就用這個符號。
J.Lulu 06/99 48317 green 9 24 2678.
J.Troll 07/99 4842 Brown-3 12 26 266666
任意匹配:
例:[root@localhost GREP]# grep "B.....2" data.f 釋:「.」點表明一位任意數。「*」表明多位任意數。
L.Tansley 05/99 4712 Brown-2 12 30 44544 樣例中表示已B開頭已2結尾和已B開頭已任意數結尾。
[root@localhost GREP]# grep "B.....[1-9]" data.f
J.Troll 07/99 4842 Brown-3 12 26 266666
L.Tansley 05/99 4712 Brown-2 12 30 44544
[root@localhost GREP]# grep "J...[a-z,A-Z][a-z,A-Z]" data.f 釋:
J.Lulu 06/99 48317 green 9 24 2678.
J.Troll 07/99 4842 Brown-3 12 26 266666
[root@localhost GREP]# grep "[a-z,A-Z]....ll" data.f 已逗號作分隔符
J.Troll 07/99 4842 Brown-3 12 26 266666
模式定位查找:
例:[root@localhost GREP]# grep '[A-Z,a-Z]\{5\}[w]' data.f 釋:查找5位字母(a-z和A-Z)並是已w結尾的模式,由於這是匹配的模式因此要用單引號
P.Bunny 02/99 48 Yellow 12 35 2658
模式隨機查找:
例:[root@localhost GREP]# grep '2\{1,6\}6' data.f釋:在文件中查找重複出現1~6次數字2而且這數字是已6結尾(2六、22六、2226以此類推出現六次)
J.Lulu 06/99 48317 green 9 24 2678.
P.Bunny 02/99 48 Yellow 12 35 2658
J.Troll 07/99 4842 Brown-3 12 26 266666
例:[root@localhost GREP]# grep '4\{1,10\}7' data.f
L.Tansley 05/99 4712 Brown-2 12 30 44544
範圍組合:
例:[root@localhost GREP]# grep "^[A-Z].[AB].*" data.f 釋:【A-Z】表明一位的任意字母后面的「.」點表明任意字符,【AB】表明這一位只能是兩個字母A和B,後面的「.*」多位任意數。
P.Bunny 02/99 48 Yellow 12 35 2658
空行和轉意:
例:[root@localhost GREP]# grep '^$' data.f
例:[root@localhost GREP]# grep 'J\.Troll' data.f釋:查詢有特殊含義的字符,要在特定字符前加「\」
J.Troll 07/99 4842 Brown-3 12 26 266666
grep -E 參數:
例:[root@localhost GREP]# grep -E --color=auto '[A-Z,a-z]reen|[A-Z]ellow' data.f 釋:egrep是grep的一種擴展用法,增長額爲匹配模式,--color=auto 爲匹配的模式添加顏色
M.Tansley 05/99 48311 Green 8 40 44.44
J.Lulu 06/99 48317 green 9 24 2678.
P.Bunny 02/99 48 Yellow 12 35 2658
[root@localhost GREP]# grep --color=auto '[A-Z,a-z]reen\|[A-Z]ellow' data.f釋:在豎槓前加轉意也能達到egrep的用途。
M.Tansley 05/99 48311 Green 8 40 44.44
J.Lulu 06/99 48317 green 9 24 2678.
P.Bunny 02/99 48 Yellow 12 35 2658
類名及其等價的正則表達式:
例:[root@localhost GREP]# grep '[[:upper:]]reen' data.f
M.Tansley 05/99 48311 Green 8 40 44.44
例:[root@localhost GREP]# grep 'J\.[[:upper:]]' data.f
J.Lulu 06/99 48317 green 9 24 2678.
J.Troll 07/99 4842 Brown-3 12 26 266666
egrep -f參數用法:
例:[root@localhost GREP]# cat data.f.bak
green
Yellow
266666
[root@localhost GREP]# egrep -f data.f.bak data.f 釋:egrep能夠將文檔裏保存的字符串用做本身使用的參數,並用-f開啓功能。
J.Lulu 06/99 48317 green 9 24 2678.
P.Bunny 02/99 48 Yellow 12 35 2658
J.Troll 07/99 4842 Brown-3 12 26 266666