學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 操作系統(tǒng) > Linux教程 > Linux系統(tǒng)中g(shù)rep命令的參數(shù)及用法詳解

Linux系統(tǒng)中g(shù)rep命令的參數(shù)及用法詳解

時(shí)間: 佳洲1085 分享

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">

學(xué)習(xí)啦 > 學(xué)習(xí)電腦 > 操作系統(tǒng) > Linux教程 > Linux系統(tǒng)中g(shù)rep命令的參數(shù)及用法詳解

Linux系統(tǒng)中g(shù)rep命令的參數(shù)及用法詳解

時(shí)間: 佳洲1085 分享

  或者:

  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)一步了解。

3637133