Global Regular Expression Print,是一種強大的文本搜索工具,能使用正則表達式。正則表達式
grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
若是用-E/-e,則pattern就不須要轉義。tomcat
選項 | 備註 |
-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