shell腳本三劍客之grep命令

grep命令:


模版:

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

J.Troll   07/99 4842  Brown-3 12 26 266666

L.Tansley 05/99 4712  Brown-2 12 30 44544


單雙引號:

在匹配模式時需要有單引號。

在匹配字符串(“123 ABC”,如果不加雙引號grep命令會將ABC當成文件。)和變量時需要用雙引號。


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結尾(26、226、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



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章