這個--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開頭的行)
8. 符合特殊字符,查詢有特殊意義的字符,諸如$ . ' " * [] ^ | + ? ,必須在特定字符前面加。
[root@mypc oid2000]# grep "." 111.txt (#在111.txt中查詢包含「.」的所有行)
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的幾個特殊字元