国产宅男网站在线|亚洲A级性爱免费视频|亚洲中精品级在线|午夜福利AA毛

  • <dd id="gf5jf"><th id="gf5jf"></th></dd>

    <cite id="gf5jf"><label id="gf5jf"></label></cite>
  • <div id="gf5jf"><listing id="gf5jf"></listing></div>
    學(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ù)說明

      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之處,詳見--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é)果類似于:

      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.若沒有符合的地方:什么都沒有顯示。

      若TYPE為without-match,遇到此參數(shù),

      grep會(huì)認(rèn)為此二進(jìn)制檔案沒有包含任何搜尋樣式,與-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(讀取),也就是說此資料夾會(huì)被視為一般的檔案;

      若ACTION是skip(略過),資料夾會(huì)被grep略過:

      若ACTION是recurse(遞歸),grep會(huì)去讀取資料夾下所有的檔案,

      此相當(dāng)于-r 參數(shù)。

      9. -E, --extended-regexp

      采用規(guī)則表示式去解釋樣式。

      10. -e PATTERN, --regexp=PATTERN

      把樣式做為一個(gè)partern,通常用在避免partern用-開始。

      11. -f FILE, --file=FILE

      事先將要搜尋的樣式寫入到一個(gè)檔案,一行一個(gè)樣式。

      然后采用檔案搜尋。

      空的檔案表示沒有要搜尋的樣式,因此也就不會(huì)有任何符合。

      ex: (newfile為搜尋樣式文件)

      $grep-f newfile file

      12. -G, --basic-regexp

      將樣式視為基本的規(guī)則表示式解釋。(此為預(yù)設(shè))

      13. -H, --with-filename

      在每個(gè)符合樣式行前加上符合的文件名稱,若有路徑會(huì)顯示路徑。

      ex: (在file與testfile中搜尋panda樣式)

      $grep-H panda file ./testfile

      file:panda

      ./testfile:panda

      $

      14. -h, --no-filename

      與-H參數(shù)相類似,但在輸出時(shí)不顯示路徑。

      15. --help

      產(chǎn)生簡(jiǎn)短的help訊息。

      16. -I

      grep會(huì)強(qiáng)制認(rèn)為此二進(jìn)制檔案沒有包含任何搜尋樣式,

      與--binary-files=without-match參數(shù)相同。

      ex: $ grep-Ipanda mv

      17. -i, --ignore-case

      忽略大小寫,包含要搜尋的樣式及被搜尋的檔案。

      ex: $ grep-i panda mv

      18. -L, --files-without-match

      不顯示平常一般的輸出結(jié)果,反而顯示出沒有符合的文件名稱。

      19. -l, --files-with-matches

      不顯示平常一般的輸出結(jié)果,只顯示符合的文件名稱。

      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)于不存在或無法讀取的錯(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移植,避開-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' 通過管道過濾ls -l輸出的內(nèi)容,只顯示以a開頭的行。

      grep 'test' d* 顯示所有以d開頭的文件中包含test的行。

      grep 'test' aa bb cc 顯示在aa,bb,cc文件中匹配test的行。

      grep '[a-z]' aa 顯示所有包含每個(gè)字符串至少有5個(gè)連續(xù)小寫字符的字符串的行。

      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)義,直接寫成'w(es)t.*'就可以了。

      grep -i pattern files :不區(qū)分大小寫地搜索。默認(rèn)情況區(qū)分大小寫

      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ǔ)充說明:Linux系統(tǒng)中的grep命令之正則表達(dá)式

      匹配字符:這部分和基本正則表達(dá)式一樣

      匹配次數(shù):

      * :和基本正則表達(dá)式一樣

      ? :基本正則表達(dá)式是\?,二這里沒有\(zhòng)。

      {m,n} :相比基本正則表達(dá)式也是沒有了\。

      + :匹配其前面的字符至少一次,相當(dāng)于{1,}。

      位置錨定:和基本正則表達(dá)式一樣。

      分組及引用:

      (string) :相比基本正則表達(dá)式也是沒有了\。

       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)該寫為 (C|c)at 。記住(string)除了用于引用還用于分組。

      常用正則表達(dá)式部分就說到這里,以后用到在另行補(bǔ)充,如果你有興趣也可以去網(wǎng)上查找其他文章來進(jìn)一步了解。

    3637133