grep詳解

一.簡介

  Global Regular Expression Print,是一種強大的文本搜索工具,能使用正則表達式。正則表達式

二.語法

grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
若是用-E/-e,則pattern就不須要轉義。tomcat

2.1 [options]主要參數

選項 備註
-c 只輸出匹配行的計數。
-o 只輸出匹配的部分。
-i 不區分大小寫(只適用於單字符)。
-h 查詢多文件時不顯示文件名。
-l 查詢多文件時只輸出包含匹配字符的文件名。
-L 列出不匹配的文件名
-n 顯示匹配行及行號。
-s 不顯示不存在或無匹配文本的錯誤信息。
-v 顯示不包含匹配文本的全部行(反向)。
-r 搜索子目錄
-d 略過子目錄
-A n 匹配行上下文向後追加n行
-B n 匹配行上下文向前追加n行
-C n 匹配行上下文向前/向後都追加n行
-E 等價於egrep,正則義
-F 等價於fgrep,轉義

2.2 pattern正則表達式主要參數(用\轉義)工具

選項 備註
\ 忽略正則表達式中特殊字符的原有含義。
^ 匹配正則表達式的開始行。
$ 匹配正則表達式的結束行。
\< 從匹配正則表達 式的行開始。
\> 到匹配正則表達式的行結束。
[ ] 單個字符,如[A]即A符合要求 。
[ - ] 範圍,如[A-Z],即A、B、C一直到Z都符合要求 。
. 全部的單個字符。
? 至多1次
* 零次以上。
1次以上。
{n} 嚴格匹配n次
{n,} n次以上
{n,m} [n,m]次

三.簡例spa

• $ grep ‘test’ *.txt
顯示全部以d開頭的文件中包含 test的行。

• $ grep ‘test’ aa bb cc
顯示在aa,bb,cc文件中匹配test的行。

• grep -o -E 'id=[0-9]+' data.doc      
只輸出行中"id=xxx"的部分。內存

• grep -o -E '\bword\b' test.txt|wc -l字符串

統計word單詞的個數io


• grep -Ev '^$|^#' test.txt
匹配非空行和註釋行

• ps -aux|grep tomcat | grep -v grep
排除自身

• $ grep ‘[a-z]\{5\}’ aa
• $ grep ‘[a-z]\+’ aa
顯示全部包含每一個字符串至少有5個連續小寫字符的字符串的行。

• $ grep ‘w\(es\)t.*\1′ aa
若是west被匹配,則es就被存儲到內存中,並標記爲1,而後搜索任意個字符(.*),這些字符後面緊跟着 另一個es(\1),找到就顯示該行。若是用egrep或grep -E,就不用」\」號進行轉義,直接寫成’w(es)t.*\1′就能夠了。


• $ grep pattern1 | pattern2 files 


• $ grep pattern1 files | grep pattern2 


• $ grep 'aa' a.txt | wc -l
統計行數

• $ grep '\$' a.txt
忽略正則表達式中特殊字符的原有含義

• grep '^[^48]' data.doc      
不匹配行首是48的行

• grep '[^a-zA-Z]oo' pp 
匹配oo以前沒字符的行

• egrep '219|216' data.doc
使用擴展模式匹配

• egrep 'g(o|pp)d' pp
匹配含有god或gppd的行table

endclass

相關文章
相關標籤/搜索