Linux系統(tǒng)中grep命令的參數(shù)及用法詳解
Linux系統(tǒng)中grep命令的參數(shù)及用法詳解
Linux系統(tǒng)中grep命令是基本的文本處理工具之一。下面由學習啦小編為大家整理了Linux系統(tǒng)中grep命令的參數(shù)及用法詳解的相關知識,希望對大家有幫助!
Linux系統(tǒng)中grep命令的參數(shù)及用法詳解:參數(shù)說明
1. -A NUM,--after-context=NUM
除了列出符合行之外,并且列出后NUM行。
ex: $ grep-A 1 panda file
(從file中搜尋有panda樣式的行,并顯示該行的后1行)
2. -a或--text
grep原本是搜尋文字文件,若拿二進制的檔案作為搜尋的目標,
則會顯示如下的訊息: Binary file 二進制文件名 matches 然后結束。
若加上-a參數(shù)則可將二進制檔案視為文本文件搜尋,
相當于--binary-files=text這個參數(shù)。
ex: (從二進制檔案mv中去搜尋panda樣式)
(錯誤!!!)
$ grep pandamv
Binary file mv matches
(這表示此檔案有match之處,詳見--binary-files=TYPE )
$
(正確!!!)
$ grep-a pandamv
3. -B NUM,--before-context=NUM
與 -A NUM 相對,但這此參數(shù)是顯示除符合行之外
并顯示在它之前的NUM行。
ex: (從file中搜尋有panda樣式的行,并顯示該行的前1行)
$ grep-B 1 panda file
4. -C [NUM], -NUM, --context[=NUM]
列出符合行之外并列出上下各NUM行,默認值是2。
ex: (列出file中除包含panda樣式的行外并列出其上下2行)
(若要改變默認值,直接改變NUM即可)
$ grep-C[NUM]panda file
5. -b, --byte-offset
列出樣式之前的內(nèi)文總共有多少byte ..
ex: $ grep-bpanda file
顯示結果類似于:
0:panda
66:pandahuang
123:panda03
6. --binary-files=TYPE
此參數(shù)TYPE預設為binary(二進制),若以普通方式搜尋,只有2種結果:
1.若有符合的地方:顯示Binary file 二進制文件名 matches
2.若沒有符合的地方:什么都沒有顯示。
若TYPE為without-match,遇到此參數(shù),
grep會認為此二進制檔案沒有包含任何搜尋樣式,與-I 參數(shù)相同。
若TPYE為text, grep會將此二進制文件視為text檔案,與-a 參數(shù)相同。
Warning: --binary-files=text 若輸出為終端機,可能會產(chǎn)生一些不必要的輸出。
7. -c, --count
不顯示符合樣式行,只顯示符合的總行數(shù)。
若再加上-v,--invert-match,參數(shù)顯示不符合的總行數(shù)。
8. -d ACTION, --directories=ACTION
若輸入的檔案是一個資料夾,使用ACTION去處理這個資料夾。
預設ACTION是read(讀取),也就是說此資料夾會被視為一般的檔案;
若ACTION是skip(略過),資料夾會被grep略過:
若ACTION是recurse(遞歸),grep會去讀取資料夾下所有的檔案,
此相當于-r 參數(shù)。
9. -E, --extended-regexp
采用規(guī)則表示式去解釋樣式。
10. -e PATTERN, --regexp=PATTERN
把樣式做為一個partern,通常用在避免partern用-開始。
11. -f FILE, --file=FILE
事先將要搜尋的樣式寫入到一個檔案,一行一個樣式。
然后采用檔案搜尋。
空的檔案表示沒有要搜尋的樣式,因此也就不會有任何符合。
ex: (newfile為搜尋樣式文件)
$grep-f newfile file
12. -G, --basic-regexp
將樣式視為基本的規(guī)則表示式解釋。(此為預設)
13. -H, --with-filename
在每個符合樣式行前加上符合的文件名稱,若有路徑會顯示路徑。
ex: (在file與testfile中搜尋panda樣式)
$grep-H panda file ./testfile
file:panda
./testfile:panda
$
14. -h, --no-filename
與-H參數(shù)相類似,但在輸出時不顯示路徑。
15. --help
產(chǎn)生簡短的help訊息。
16. -I
grep會強制認為此二進制檔案沒有包含任何搜尋樣式,
與--binary-files=without-match參數(shù)相同。
ex: $ grep-Ipanda mv
17. -i, --ignore-case
忽略大小寫,包含要搜尋的樣式及被搜尋的檔案。
ex: $ grep-i panda mv
18. -L, --files-without-match
不顯示平常一般的輸出結果,反而顯示出沒有符合的文件名稱。
19. -l, --files-with-matches
不顯示平常一般的輸出結果,只顯示符合的文件名稱。
20. --mmap
如果可能,使用mmap系統(tǒng)呼叫去讀取輸入,而不是預設的read系統(tǒng)呼叫。
在某些狀況,--mmap 能產(chǎn)生較好的效能。 然而,--mmap
如果運作中檔案縮短,或I/O 錯誤發(fā)生時,
可能造成未定義的行為(包含core dump),。
21. -n, --line-number,---常用
在顯示行前,標上行號。
ex: $ grep-npanda file
顯示結果相似于下:
行號:符合行的內(nèi)容
22. -q, --quiet, --silent
不顯示任何的一般輸出。請參閱-s或--no-messages
23. -r, --recursive,---常用
遞歸地,讀取每個資料夾下的所有檔案,此相當于 -d recsuse 參數(shù)。
24. -s, --no-messages
不顯示關于不存在或無法讀取的錯誤訊息。
小注: 不像GNU grep,傳統(tǒng)的grep不符合POSIX.2協(xié)議,
因為缺乏-q參數(shù),且他的-s 參數(shù)表現(xiàn)像GNU grep的 -q 參數(shù)。
Shell Script傾向將傳統(tǒng)的grep移植,避開-q及-s參數(shù),
且將輸出限制到/dev/null。
POSIX: 定義UNIX及UNIX-like系統(tǒng)需要提供的功能。
25. -V, --version
顯示出grep的版本號到標準錯誤。
當您在回報有關grep的bugs時,grep版本號是必須要包含在內(nèi)的。
26. -v, --invert-match
顯示除搜尋樣式行之外的全部。
27. -w, --word-regexp
將搜尋樣式視為一個字去搜尋,完全符合該"字"的行才會被列出。
28. -x, --line-regexp
將搜尋樣式視為一行去搜尋,完全符合該"行"的行才會被列出。
Linux系統(tǒng)中的grep命令參數(shù)及用法詳解:用法詳解
ls -l | grep '^a' 通過管道過濾ls -l輸出的內(nèi)容,只顯示以a開頭的行。
grep 'test' d* 顯示所有以d開頭的文件中包含test的行。
grep 'test' aa bb cc 顯示在aa,bb,cc文件中匹配test的行。
grep '[a-z]' aa 顯示所有包含每個字符串至少有5個連續(xù)小寫字符的字符串的行。
grep 'w(es)t.*' aa 如果west被匹配,則es就被存儲到內(nèi)存中,并標記為1,然后搜索任意個字符(.*),這些字符后面緊跟著另外一個es(),找到就顯示該行。如果用egrep或grep -E,就不用""號進行轉義,直接寫成'w(es)t.*'就可以了。
grep -i pattern files :不區(qū)分大小寫地搜索。默認情況區(qū)分大小寫
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 的行。
補充說明:Linux系統(tǒng)中的grep命令之正則表達式
匹配字符:這部分和基本正則表達式一樣
匹配次數(shù):
* :和基本正則表達式一樣
? :基本正則表達式是\?,二這里沒有\(zhòng)。
{m,n} :相比基本正則表達式也是沒有了\。
+ :匹配其前面的字符至少一次,相當于{1,}。
位置錨定:和基本正則表達式一樣。
分組及引用:
(string) :相比基本正則表達式也是沒有了\。
class="main">
Linux系統(tǒng)中grep命令的參數(shù)及用法詳解
或者:
a|b :匹配a或b,注意a是指 | 的左邊的整體,b也同理。比如 C|cat 表示的是 C或cat,而不是Cat或cat,如果要表示Cat或cat,則應該寫為 (C|c)at 。記住(string)除了用于引用還用于分組。
常用正則表達式部分就說到這里,以后用到在另行補充,如果你有興趣也可以去網(wǎng)上查找其他文章來進一步了解。