標(biāo)題: grep命令 [打印本頁]

作者: 51黑tt    時(shí)間: 2016-3-6 15:19
標(biāo)題: grep命令
既然要使用 grep 當(dāng)然就得要先了解一下 grep 的語法啰~
[root@test root]# grep [-acinv] '搜尋字符串' filename
參數(shù)說明:
-a :將 binary 檔案以 text 檔案的方式搜尋數(shù)據(jù)
-c :計(jì)算找到 '搜尋字符串' 的次數(shù)
-i :忽略大小寫的不同,所以大小寫視為相同
-n :順便輸出行號
-v :反向選擇,亦即顯示出沒有 '搜尋字符串' 內(nèi)容的那一行!
范例:
[root@test root]# grep 'root' /var/log/secure
將 /var/log/secure 這個(gè)檔案中有 root 的那一行秀出來

[root@test root]# grep -v 'root' /var/log/secure
若該行沒有 root 才將數(shù)據(jù)秀出來到屏幕上!

[root@test root]# last | grep root
若該行有 root 才將數(shù)據(jù)秀出來到屏幕上!

grep 是一個(gè)很常見也很常用的指令,他最重要的功能就是進(jìn)行字符串?dāng)?shù)據(jù)的比對, 然后將符合使用者需求的字符串打印出來。 需要說明的是『grep 在資料中查尋一個(gè)字符串時(shí),是以 "整行" 為單位來進(jìn)行數(shù)據(jù)的擷取的!』也就是說,假如一個(gè)檔案內(nèi)有 10 行,其中有兩行具有你所搜尋的字符串,則將那兩行顯示在屏幕上,其它的就丟棄了!

而 grep 除了可以進(jìn)行檔案的資料搜尋之外,也常常被應(yīng)用在 input/output 的數(shù)據(jù)處理當(dāng)中,例如常見的 管線命令 ( pipe ) 就可以常常見到他的蹤影! 以上面表格中的例子來看,我們可以發(fā)現(xiàn)前兩個(gè)例子是查尋檔案的內(nèi)容,有沒有加上 -v 所顯示出來的結(jié)果是『相反的!』,而第三個(gè)例子則是以 pipe 的功能進(jìn)行數(shù)據(jù)的處理的喔!

好了,我們就開始以 grep 來進(jìn)行正規(guī)表示法的簡易說明吧!我們先以底下這個(gè)檔案來作為范例:

[root@test root]# vi regular_express.txt
"Open Source" is a good mechanism to develop programs.
apple is my favorite food.
Football game is not use feet only.
this dress doesn't fit me.
However, this dress is about $ 3183 dollars.
GNU is free air not free beer.
Her hair is very beauty.
I can’t finish the test.
Oh! The soup taste good.
motorcycle is cheap than car.
This window is clear.
the symbol '*' is represented as start.
Oh! My god!
The gd software is a library for drafting programs.
You are the best is mean you are the no. 1.
The world is the same with "glad".
I like dog.
google is the best tools for search keyword.
goooooogle yes!
go! go! Let's go.
# I am VBird


需要特別注意的是,上面這個(gè)檔案鳥哥是在 Windows 的環(huán)境下編輯的, 并且經(jīng)過特殊處理過,因此,他雖然是純文字文件,但是內(nèi)含一些 Windows 環(huán)境下的軟件常常自行加入的一些特殊字符,例如斷行字符(^M)就是一例! 所以,您可以直接將上面的文字以 vi 儲(chǔ)存成 regular_express.txt 這個(gè)檔案, 不過,比較建議直接點(diǎn)底下的連結(jié)下載:

此外,因?yàn)椴煌恼Z系編碼是不一樣的,所以,您必須要將語系改成英文語系, 才能夠進(jìn)行底下的測試,否則,可能會(huì)有顯示的內(nèi)容與底下的輸出不符的狀況喔! 修改語系的方法為:
[root@test root]# LANG=en
[root@test root]# export LANG
好了,現(xiàn)在開始我們一個(gè)案例一個(gè)案例的來介紹吧!

◎grep -- print lines matching a pattern
grep [options] PATTERN [FILE...]
grep [options] [-e PATTERN | -f FILE] [FILE...]
    grep用以在file內(nèi)文中比對相對應(yīng)的部分,或是當(dāng)沒有指定檔案時(shí),由標(biāo)準(zhǔn)輸入中去比對。 在預(yù)設(shè)的情況下,grep會(huì)將符合樣式的那一行列出。
    此外,還有兩個(gè)程式是grep的變化型,egrep及fgrep其中egrep就等同於grep -E ,fgrep等同於grep -F 。
◎參數(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 panda mv  
         Binary file mv matches   
         (這表示此檔案有match之處,詳見--binary-files=TYPE )
         $ (正確!!!)
         $ grep -a panda mv  
        
    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行,預(yù)設(shè)值是2。
              
         ex:   (列出file中除包含panda樣式的行外并列出其上下2行)
               (若要改變預(yù)設(shè)值,直接改變NUM即可)
               $ grep -C[NUM]  panda file  
              
    5. -b, --byte-offset
       列出樣式之前的內(nèi)文總共有多少byte ..
               
        ex:  $ grep -b  panda 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)生簡短的help訊息。
   16.  -I
        grep會(huì)強(qiáng)制認(rèn)為此二進(jìn)位檔案沒有包含任何搜尋樣式,
        與--binary-files=without-match參數(shù)相同。
        ex:  $ grep -I  panda 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)上行號。
               
         ex:  $ grep -n  panda file   
                顯示結(jié)果相似於下:
                行號:符合行的內(nèi)容
   22.  -q, --quiet, --silent  
        不顯示任何的一般輸出。請參閱-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的版本號到標(biāo)準(zhǔn)錯(cuò)誤。
        當(dāng)您在回報(bào)有關(guān)grep的bugs時(shí),grep版本號是必須要包含在內(nèi)的。
   26.  -v, --invert-match
        顯示除搜尋樣式行之外的全部。
                    
   27.  -w, --word-regexp
        將搜尋樣式視為一個(gè)字去搜尋,完全符合該"字"的行才會(huì)被列出。
   28.  -x, --line-regexp
        將搜尋樣式視為一行去搜尋,完全符合該"行"的行才會(huì)被列出。






歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1