grep命令的知識.

tonyzhou_cn發表於2012-06-06

grep命令的知識

1.作用
Linux系統中grep命令是一種強大的文字搜尋工具,它能搜尋文字,並把匹配的行列印出來。grep全稱是Global Regular Expression Print,表示全域性版本,它的使用許可權是所有使用者。

2.格式
grep [options]

3.主要引數
[options]主要引數:
c:只輸出匹配行的計數。
I:不區分大小寫(只適用字元)
h:查詢多檔案時不顯示檔名。
l:查詢多檔案時只輸出包含匹配字元的檔名。
n:顯示匹配行及行號。
s:不顯示不存在或無匹配文字的錯誤資訊。
v:顯示不包含匹配文字的所有行。
pattern正規表示式主要引數:
\:忽略正規表示式中的原有含義。  脫義符
^:匹配正規表示式的開始行。        
$: 匹配正規表示式的結束行。
\<:從匹配正規表示式的行開始。    單詞開頭  的行
\>:到匹配正規表示式的行結束。 單詞結尾  的行
[ ]:單個字元,如[A]A符合要求 。
[ - ]:範圍,如[A-Z],即ABC一直到Z都符合要求 。
:所有的單個字元。
:有字元,長度可以為0   

a+ 表示aaaaaa乃至更多個a

a\{n\} 表示重複了n次的a   

 應用 1、 grep .\{x,y\}’ /usr/share/dict/words   查詢重複xy次的單詞.也就是位以上的單詞(   .\{x,\}  

2、 grep '^i.\{18,\}n$' /usr/share/dict/words  查詢以i開頭 n結尾 18位的單詞。

  

4.grep命令例項
$ grep test’ d*
顯示所有以d開頭的檔案中包含test的行。
$ grep test’ aa bb cc
顯示在aabbcc檔案中匹配test的行。
$ grep [a-z]\{5\}’ aa
顯示所有包含每個字串至少有5個連續小寫字元的字串的行。
$ grep w\(es\)t.*\1′ aa
如果west被匹配,則es就被儲存到記憶體中,並標記為1,然後搜尋任意個字元(.*),這些字元後面緊跟著另外一個es(\1),找到就顯示該行。如果用egrepgrep -E,就不用”\”號進行轉義,直接寫成’w(es)t.*\1′就可以了。

5.grep命令使用複雜例項
假設您正在’/usr/src/Linux/Doc’目錄下搜尋帶字串’magic’的檔案:
$ grep magic /usr/src/Linux/Doc/*
sysrq.txt:* How do I enable the magic SysRQ key?
sysrq.txt:* How do I use the magic SysRQ key?
其中檔案’sysrp.txt’包含該字串,討論的是 SysRQ 的功能。
預設情況下,’grep’只搜尋當前目錄。如果此目錄下有許多子目錄,’grep’會以如下形式列出:
grep: sound: Is a directory
這可能會使’grep’的輸出難於閱讀。這裡有兩種解決的辦法:
明確要求搜尋子目錄:grep -r
或忽略子目錄:grep -d skip
如果有很多輸出時,您可以透過管道將其轉到’less’上閱讀:
$ grep magic /usr/src/Linux/Documentation/* | less
這樣,您就可以更方便地閱讀。

有一點要注意,您必需提供一個檔案過濾方式(搜尋全部檔案的話用 *)。如果您忘了,’grep’會一直等著,直到該程式被中斷。如果您遇到了這樣的情況,按  ,然後再試。

下面還有一些有意思的

-?   同時顯示匹配行上下的?行,如:grep -2 pattern filename同時顯示匹配行的上下2行。
grep -i pattern files :不區分大小寫地搜尋。預設情況區分大小寫,
grep -l pattern files :只列出匹配的檔名,
grep -L pattern files :列出不匹配的檔名,
grep -w pattern files :只匹配整個單詞,而不是字串的一部分(如匹配’magic’,而不是’magical)
grep -C number pattern files :匹配的上下文分別顯示[number]行,
grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。

這裡還有些用於搜尋的
\和 \> 分別標註單詞的開始與結尾。
例如:
grep man * 會匹配 ‘Batman’、’manic’、’man’等,
grep \’ 匹配’manic’和’man’,但不是’Batman’,
grep \’ 只匹配’man’,而不是’Batman’或’manic’等其他的字串。
^’:指匹配的字串在行首,
$’:指匹配的字串在行尾

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/27038344/viewspace-732075/,如需轉載,請註明出處,否則將追究法律責任。

相關文章