首頁 >php教程 >PHP开发 >grep 常用指令

grep 常用指令

高洛峰
高洛峰原創
2016-12-13 14:34:201225瀏覽

這個--include選項, 可以這樣使用:
grep -rn --include='*.c' --include='*.h' re .

可以指定多次, 如果真是上面的這種情況,其實可以用
grep -rn --include='*.[ch]' re .

但是, 如果源文件中含有C++源代碼, 上面的方法就不湊效了, 因為[]中只能放一個字元.
grep -rn --include='*.{cpp,h}' 也是不行的.
此時需要不加引號的展開(由bash執行grep之前就已經完成, 可以透過set -x觀察)

grep -rn --include=*.{cpp,h} re .

bash中對{A,B}這種形式的展開, 會忽略是否在當前目錄下存在相應的文件. 這樣的寫法, 可以避免手指累殘在命令列上.

 

高亮顯示

grep --color=auto 'pattern'   'text'

 

echo -e '字串-e 表示特殊處理e 這個e必須跟著[符號

 

 

grep 常用 

grep [-acinv] '搜尋字串' filename

參數 說明:

檔案的方式搜尋資料

-c :計算找到'搜尋字串' 的次數

-i :忽略大小寫的不同,所以大小寫視為相同

-n :順便輸出行號

-v :反向選擇,亦即顯示出沒有'搜尋字串' 內容的那一行!

 

 

1.搜尋特定的字元 

grep 'oo' pp.txt  以下僅用pp 代表pp.

查看非oo的字符 

grep -v 'oo' pp

 

查看大小寫忽略的字符

grep -i 'oo' p

 

查看tast 和test的字串

grep -n 't[ae]st' pp  這裡[ae]只當一個字元處理a 或是e 這樣就能匹配上面的要求

 

若是希望匹配t( x)st 這個x是任意的字符的話,那麼可以如下處理方式

grep 't[.]st' pp  .符號代表任意的字符

 

查看包含oo字符的信息

grep -n 'oo ' pp

 

若是希望在oo之前沒有g的字符信息

grep -n '[^g]oo' pp 這裡的^就是取反的意思非goo得字符

 

前面非字符的字符

grep -n '[^a-zA-Z]oo' pp 

 

得到數字的字符的話

grep -n '[0-9]' pp  // 其實這個等同於gren' [0-9[0-9]*' pp * 代表0個或多個重複的訊息

 

 

3.行首和行尾的特殊處理$^ 

若是希望取得第一行是the 開頭的字元行

grep -n '^the' pp 

 

若是希望取得以英文字元開頭的字元

grep -n '^[a-zA-Z]' pp以英文字開頭的訊息

grep -n '^[^a-zA-Z]' pp   // 裡面的^是取反外面的^是以上方開頭

 

取得小數點結尾的行

grep -n '.$' pp     //小數點是特殊字元需要用進行轉義

注意在windows下換行時^M 這個符號 

 

 

gre

取得一個空行的方式

' pp 這裡就是取空行了

 

希望取得所有文件中非註解掉得內容的話那麼可如下

grep -v '^$' pp|grep -v ^#            的資料第一個管道是取非#開頭的資料

我像有時候更多的是取#開頭的行

grep -n '^#' pp 

 

4.任意字元和重複字元

 

4.任意字元和重複字元

. :絕對的任意字元

* :0個或是多個相同字元

 

要查看gf中間是兩個字元的資料

grep -n 'g..f' pp

有一個是o的字串

grep -n 'oo*' pp  //因為*代表0個或是多個

 

以g開頭和結尾,中間至少一個o

grep -n 'goo* g' 

 

查找gg中間是任意字元的字串

grep -n 'g.*g' pp 這裡.就代表任意字元

 

5.限定符{}

間存在兩個連個o的字串

grep -n 'go{2,5}p'

 

找出至少兩個的字元創

grep -n 'go{2,}p' pp

 

找出只有兩個的字串

grep -n 'go{2}p' pp

 

 

6.重要的特殊字元

行首!

範例:grep -n '^#' pp 搜尋行首為 # 開始的那一行!

 

 

word$待搜尋的字串(word)在行尾!

範例:grep -n '!$' pp 將行尾為 ! 的那一行印出來!

 

 

.代表任意的一個字元

範例; grep -n 'g.' pp 將是g開頭的兩個字元印-n ' pp  搜尋單引號的那一行

 

*:符合0個或是多個字元

grep -n 'o*' pp 符合擁有零個或是多個o的字元

 

{n,m} :符合的數量

grep -n 'o{2}' pp 印出擁有兩個oo的字元

 

[]符合單一字元 

  1.[list] : [abl]匹配abl中任一個

  2.[^xx]:對其中的字符進行取反 這裡只能對的那個字符進行取反若是希望是多個字符取反的話還需要看看

  3.[char1 -char2]:符合某個範圍之內的資料例如[a-z][A-Z][0-9]

 

7.擴張的grep --- > egrep  這個等同於grep -E 

 

v '^$' pp | grep -v '^#'

用egrep來表示就是

egrep -v '^$|^'

 

8.找出內容有「或」的關係:

#找出數字為23或24的內容,並顯示內容與行號

grep -E '23|24' * -n

 

9.找出data.檔案有多少個空白行:txt

grep '^ $' data.txt -c

 

10.查詢目前目錄中還有多少目錄:

ls -l | grep '^d'

 

11.的內容

grep 'a$' data.txt -i -n

 

$ grep "sort it" *      (#或在所有檔案中查詢單字「sort it」)

指在單一文件中查詢

 行配對

$ grep -c "48" data.f

$ 4                  " data.f          (#顯示包含「4 8」字串的4行文字)

 顯示所有符合模式的行行數:

[root@mypc oid2000] 

3:1234ab

6. 精確比對
[root@mypc oid2000]# grep "1234>" 111.txt 
1234

7.查詢查詢空行,txt 
1234

7.查詢發送空行,txt以某個條件開頭或結尾的行。
結合使用^和$可查詢空白行。使用- n參數顯示實際行數
[root@mypc oid2000]# grep -n "^$" 111.txt    (回傳結果2:   #說明第二行是空白行)
[root@mypc oid2000]# grep - n "^abc" 111.txt (#查詢以abc開頭的行)

[root@mypc oid2000]# grep -n "abc$" 111.txt (#查詢以abc結尾的行)


8. 符合特殊字符,查詢有特殊意義的字符,諸如$ . ' " * [] ^ | + ? ,必須在特定字符前面加。
[root@mypc oid2000]# grep "." 111.txt (#在111.txt中查詢包含「.」的所有行)

[root@mypc oid2000]# grep "my.conf" 111.txt (#查詢有檔案名稱my. c o n f的行)


9.目錄的查詢
[root@ mypc oid2000]# ls –l |grep “^d”   (#如果要查詢目錄清單中的目錄)
[root@mypc oid2000]# ls –l |grep “^d[d]” (#在一個目錄中查詢不包含目錄的所有檔案)
[root@mypc]# ls –l |grep “^d…..x..x” (#查詢其他使用者和使用者群組成員有可執行權限的目錄集合)

10.排除自身

ps -ef|grep telnet | grep -v grep (在顯示的進程中抽出「telnet」進程;並丟棄ps中的grep進程)

 

egrep的幾個特殊字元

+ :至少一個或多個  egrep -n 'go+d' pp

? :0個或是一個       egrep -n 'go?d' pp

| :用或的方式來找出  egrep -n 'go| good' pp 查找go或是good

():找出群組的資料     egrep -n 'g(o|pp)d' pp 查看god 或是gppd  這個類似[] 但是比[]強大的是可以比[]強大的是可以比[]強大的是可以比較是多個字元進行亂換

egrep -n 'd(r|o)e' pp  ===== grep -n 'd[ro]e' pp 

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:grep linux 指令下一篇:grep linux 指令