講解Linux下grep命令的使用技巧
講解Linux下grep命令的使用技巧
grep命令的使用是Linux入門學(xué)習(xí)中的基礎(chǔ)知識(shí),接下來是小編為大家收集的講解Linux下grep命令的使用技巧,希望能幫到大家。
講解Linux下grep命令的使用技巧
grep 命令用來搜索文本,或從給定的文件中搜索行內(nèi)包含了給定字符串或單詞的文件。通常來說,grep 顯示匹配到的行。使用 grep 來搜索包括一個(gè)或多個(gè)正則表達(dá)式匹配到的文本行,然后只顯示匹配到的行。grep 被視作在 Linux/ Unix 系統(tǒng)中最有用的命令之一。
grep 這個(gè)名字,來源于一個(gè) Unix/Linux 中的古老的行編輯器 ed 中執(zhí)行相似操作的命令:
復(fù)制代碼
代碼如下:
g/re/p
grep 命令的語法
語法如下所示:
grep 'word' 文件名
grep 'word' 文件1 文件2 文件3
grep '字符串1 字符串2' 文件名
cat 某個(gè)文件 | grep '某個(gè)東西'
command | grep '某個(gè)東西'
command 選項(xiàng)1 | grep '數(shù)據(jù)'
grep --color '數(shù)據(jù)' 文件名
怎么樣使用 grep 來搜索一個(gè)文件
搜索 /etc/passwd 文件下的 boo 用戶,輸入:
復(fù)制代碼
代碼如下:
$ grep boo /etc/passwd
輸出內(nèi)容:
復(fù)制代碼
代碼如下:
foo:x:1000:1000:foo,,,:/home/foo:/bin/ksh
可以使用 grep 去強(qiáng)制忽略大小寫。例如,使用 -i 選項(xiàng)可以匹配 boo, Boo, BOO 和其他組合:
復(fù)制代碼
代碼如下:
$ grep -i "boo" /etc/passwd
遞歸使用 grep
你可以遞歸地使用 grep 進(jìn)行搜索。例如,在文件目錄下面搜索所有包含字符串“192.168.1.5”的文件
復(fù)制代碼
代碼如下:
$ grep -r "192.168.1.5" /etc/
或者是:
復(fù)制代碼
代碼如下:
$ grep -R "192.168.1.5" /etc/
示例輸出:
復(fù)制代碼
代碼如下:
/etc/ppp/options:# ms-wins 192.168.1.50
/etc/ppp/options:# ms-wins 192.168.1.51
/etc/NetworkManager/system-connections/Wired connection 1:addresses1=192.168.1.5;24;192.168.1.2;
你會(huì)看到搜索到 192.168.1.5 的結(jié)果每一行都前綴以找到匹配的文件名(例如:/etc/ppp/options)。輸出之中包含的文件名可以加 -h 選項(xiàng)來禁止輸出:
復(fù)制代碼
代碼如下:
$ grep -h -R "192.168.1.5" /etc/
或者
復(fù)制代碼
代碼如下:
$ grep -hR "192.168.1.5" /etc/
示例輸出:
復(fù)制代碼
代碼如下:
# ms-wins 192.168.1.50
# ms-wins 192.168.1.51
addresses1=192.168.1.5;24;192.168.1.2;
使用 grep 去搜索文本
當(dāng)你搜索 boo 時(shí),grep 命令將會(huì)匹配 fooboo,boo123, barfoo35 和其他所有包含 boo 的字符串,你可以使用 -w 選項(xiàng)去強(qiáng)制只輸出那些僅僅包含那個(gè)整個(gè)單詞的行(LCTT譯注:即該字符串兩側(cè)是英文單詞分隔符,如空格,標(biāo)點(diǎn)符號(hào),和末端等,因此對(duì)中文這種沒有斷字符號(hào)的語言并不適用。)。
復(fù)制代碼
代碼如下:
$ grep -w "boo" file
使用 grep 命令去搜索兩個(gè)不同的單詞
使用 egrep 命令如下:
復(fù)制代碼
代碼如下:
$ egrep -w 'word1|word2' /path/to/file
(注:這里使用到了正則表達(dá)式,因此使用的是 egrep 命令,即擴(kuò)展的 grep 命令。)
統(tǒng)計(jì)文本匹配到的行數(shù)
grep 命令可以通過加 -c 參數(shù)顯示每個(gè)文件中匹配到的次數(shù):
復(fù)制代碼
代碼如下:
$ grep -c 'word' /path/to/file
傳遞 -n 選項(xiàng)可以輸出的行前加入匹配到的行的行號(hào):
復(fù)制代碼
代碼如下:
$ grep -n 'root' /etc/passwd
示例輸出:
復(fù)制代碼
代碼如下:
1:root:x:0:0:root:/root:/bin/bash
1042:rootdoor:x:0:0:rootdoor:/home/rootdoor:/bin/csh
3319:initrootapp:x:0:0:initrootapp:/home/initroot:/bin/ksh
反轉(zhuǎn)匹配(不匹配)
可以使用 -v 選項(xiàng)來輸出不包含匹配項(xiàng)的內(nèi)容,輸出內(nèi)容僅僅包含那些不含給定單詞的行,例如輸出所有不包含 bar 單詞的行:
復(fù)制代碼
代碼如下:
$ grep -v bar /path/to/file
UNIX/Linux 管道與 grep 命令
grep 常常與管道一起使用,在這個(gè)例子中,顯示硬盤設(shè)備的名字:
復(fù)制代碼
代碼如下:
# dmesg | egrep '(s|h)d[a-z]'
顯示 CPU 型號(hào):
復(fù)制代碼
代碼如下:
# cat /proc/cpuinfo | grep -i 'Model'
然而,以上命令也可以按照以下方法使用,不使用管道:
復(fù)制代碼
代碼如下:
# grep -i 'Model' /proc/cpuinfo
示例輸出:
復(fù)制代碼
代碼如下:
model : 30
model name : Intel(R) Core(TM) i7 CPU Q 820 @ 1.73GHz
model : 30
model name : Intel(R) Core(TM) i7 CPU Q 820 @ 1.73GHz
如何僅僅顯示匹配到內(nèi)容的文件名字?
使用 -l 選項(xiàng)去顯示那些文件內(nèi)容中包含 main() 的文件名:
復(fù)制代碼
代碼如下:
$ grep -l 'main' *.c
最后,你可以強(qiáng)制 grep 以彩色輸出:
復(fù)制代碼
代碼如下:
$ grep --color vivek /etc/passwd
示例輸出:
看了“講解Linux下grep命令的使用技巧”還想看: