這個--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[34mhaha\e[m' 這樣會輸出帶顏色的字符串 -e 表示特殊處理 \e 這個 \e必須跟着 [符號
grep 常用
grep [-acinv] '搜尋字符串' filename
參數說明:
-a :將 binary 檔案以 text 檔案的方式搜尋數據
-c :計算找到 '搜尋字符串' 的次數
-i :忽略大小寫的不同,所以大小寫視為相同
-n :順便輸出行號
-v :反向選擇,亦即顯示出沒有 '搜尋字符串' 內容的那一行!
1.搜索特定的字符
grep 'oo' pp.txt 以下僅僅用 pp 代表 pp.txt
查看顯示字符的行數
grep -n 'oo' pp
查看非oo的字符
grep -v 'oo' pp
查看大小寫忽略的字符
grep -i 'oo' p
2.利用[]處理搜索結果
查看 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 // 其實這個等同於 grep -n '[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 這個符號
取得一個空行的方式
grep -n '^$' pp 這里就是取空行了
希望取得所有文檔中非注釋掉得內容的話 那么可如下
grep -v '^$' pp|grep -v ^# 第一個是取非空行的數據 第一個管道是取非#開頭的數據
我像有時候更多的是取 #開頭的行
grep -n '^#' pp
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.限定符 {}
查看g和p之間存在兩個連個o的字符串
grep -n 'go\{2,5\}p'
查找至少兩個的字符創
grep -n 'go\{2,\}p' pp
查找只有兩個的字符串
grep -n 'go\{2\}p' pp
6.重要的特殊字符
^word待搜尋的字符串(word)在行首!
范例:grep -n '^#' pp 搜尋行首為 # 開始的那一行!
word$待搜尋的字符串(word)在行尾!
范例:grep -n '!$' pp 將行尾為 ! 的那一行打印出來!
.代表任意的一個字符
范例; grep -n 'g.' pp 將是g開頭的兩個字符打印出來
\將特殊字符轉義
范例:grep -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
grep -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.查找data.txt文件字符串尾部為a的內容
grep 'a$' data.txt -i -n
$ grep "sort it" * (#或在所有文件中查詢單詞“sort it”)
接下來的所有示例是指在單個文件中進行查詢
行匹配
$ grep -c "48" data.f
$ 4 (#g r e p返回數字4,意義是有4行包含字符串“4 8”。)
$ grep "48" data.f (#顯示包含“4 8”字符串的4行文本)
顯示滿足匹配模式的所有行行數:
[root@mypc oid2000]# grep -n 1234 111.txt
1:1234
3:1234ab
6. 精確匹配
[root@mypc oid2000]# grep "1234\>" 111.txt
1234
7. 查詢空行,查詢以某個條件開頭或者結尾的行。
結合使用^和$可查詢空行。使用- 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