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