linux grep命令學(xué)習(xí)
linux grep命令學(xué)習(xí)
grep命令是linux下的行過(guò)濾工具,其參數(shù)繁多,那么你知道linux grep命令學(xué)習(xí)么?接下來(lái)是小編為大家收集的linux grep命令學(xué)習(xí),歡迎大家閱讀:
linux grep命令學(xué)習(xí)
-、grep簡(jiǎn)述
grep命令是linux中強(qiáng)大的文本搜索工具,那么grep取名是怎么來(lái)的呢?
grep : g (globally) search for a re (regular expression) and p (print ) the results
從上面的英文解釋中可以看出,grep命令使用正則表達(dá)式搜索文本,并把匹配的行打印出來(lái)
二、grep使用格式
grep [OPTION]... PATTERN [FILE]...
三、OPTION
-i:匹配時(shí)不區(qū)分大小寫(xiě)進(jìn)行匹配。
-w:匹配時(shí)只匹配整個(gè)單詞,而不是字符串的一部分(如PATTERN='she'時(shí)匹配單詞she,而不匹配shell)
-h:輸出時(shí)每行行首不顯示文件名。
-H:輸出時(shí)每行行首顯示文件名。
-n:輸出時(shí)每行顯示行號(hào)。
-c:輸出時(shí)只顯示每個(gè)文件匹配行計(jì)數(shù)。
-L:輸出時(shí)只顯示不包含匹配項(xiàng)的文件名。
-l:輸出時(shí)只顯示包含匹配項(xiàng)的文件名。
-o:輸出時(shí)每行只顯示匹配項(xiàng)內(nèi)容
-s:忽略錯(cuò)誤信息。
-v:逆向匹配,選擇不匹配的行。
-A:After的意思,顯示匹配項(xiàng)后n行的數(shù)據(jù)
-B:before的意思,顯示匹配項(xiàng)前n行的數(shù)據(jù)
-C:顯示匹配字符串前后各n行的數(shù)據(jù)
--color:以特定顏色高亮顯示匹配項(xiàng)內(nèi)容
--color選項(xiàng)是個(gè)非常好的選項(xiàng),可以讓你清楚匹配上哪些字符。
最好在自己的.bashrc文件中加入:
alias grep='grep --color=auto'
再以source .bashrc來(lái)立即生效即可這樣在每次grep搜索之后,自動(dòng)高亮匹配效果了。
grep 'she' test.txt
grep -i 'she' test.txt
grep -c 'she' test.txt
grep -in 'she' test.txt
grep -v 'she' test.txt
grep -w 'she' test.txt
grep -o 'she' test.txt
grep -C 2 'she' test.txt
著重說(shuō)下-o參數(shù)
假如grep 'she' test.txt輸出為
she is beautiful
I like she
則grep -o 'she' test.txt輸出為
she
she
意思就是只顯示匹配項(xiàng)部分,行中其它部分不顯示
另說(shuō)明下,PATTERN是正則表達(dá)式,為了避免shell的元字符對(duì)正則表達(dá)式的影響,請(qǐng)用單引號(hào)('')括起來(lái),不要用雙引號(hào)括起來(lái)("")或者不括起來(lái)。
四、PATTERN
4.1基本正則表達(dá)式
\:轉(zhuǎn)義字符。
^:錨定行的開(kāi)始。如:'^help'匹配以help開(kāi)頭的行
$:錨定行的結(jié)束。如:'help$'匹配以help結(jié)尾的行
.:匹配任意一個(gè)非換行符的字符。如:'he.p'匹配help,heap等,但不能匹配hep
*:前面的字符重復(fù)0到多次。如:'he*p'匹配hp,hep,heep等
[list]:匹配字符集中的一個(gè)字符。如:'[hk]elp'匹配help,kelp
[n1-n2]:匹配字符范圍中的一個(gè)字符。如:'[a-z]elp'匹配aelp,belp,...,zelp
[^list]:匹配字符集以外的一個(gè)字符。如:'[^a-d]elp'不匹配aelp,belp,celp,delp??善ヅ鋏elp,help, elp等
\{n1,n2\}:前面的字符重復(fù)n1-n2次。如:'h\{1,3\}elp'匹配help,hhelp,hhhelp。
\<:錨定單詞的開(kāi)始。如:'\
\>:錨定單詞的結(jié)尾。如:'p\>'匹配以p結(jié)尾的單詞。匹配help,但不匹配person
特別說(shuō)明:^在PATTERN開(kāi)始位置出現(xiàn)才表示錨定行的開(kāi)始,其它位置出現(xiàn)只是作為^字符。
例如:
grep '^help' test.txt 表示匹配以help開(kāi)頭的行
grep 'help^' test.txt 表示匹配包含字符串help^的行
同理,$在PATTERN末尾位置出現(xiàn)才表示錨定行的結(jié)束,其它位置出現(xiàn)只是作為$字符。
PATTERN為'^$'表示空行,因?yàn)橹挥行惺缀托形?/p>
\{n1,n2\}中n2可省略,表示前面字符重復(fù)n1至多次,重復(fù)次數(shù)不設(shè)上限
4.2擴(kuò)展正則表達(dá)式
grep一般情況下支持基本正則表達(dá)式,可以通過(guò)參數(shù)-E支持?jǐn)U展正則表達(dá)式,另外grep單獨(dú)提供了一個(gè)擴(kuò)展命令叫做egrep用來(lái)支持?jǐn)U展正則表達(dá)式,這條命令和grep -E等價(jià)。
+:前面的字符重復(fù)1到多次。如:'he+p'匹配hep,heep,heeep等,但不匹配hp
?:匹配0或1次前面的字符。如:'he?p'匹配hp,hep
|:或的方式匹配多個(gè)字串。如:'help|heap'匹配help,heap
():匹配整個(gè)括號(hào)內(nèi)的字符串。如:'(help)+'匹配help,helphelp等,注意與'help+'的區(qū)別
看了“linux grep命令學(xué)習(xí)”還想看: