grep (global search regular expression(RE) and print out the line,全面搜索正則表達式並把行打印出來)是一種強大的文本搜索工具,它能使用正則表達式搜索文本,並把匹配的行打印出來。java
Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不一樣。egrep是grep的擴展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它們把全部的字母都看做單詞,也就是說,正則表達式中的元字符表示回其自身的字面意義,再也不特殊。linux使用GNU版本的grep。它功能更強,能夠經過-G、-E、-F命令行選項來使用egrep和fgrep的功能。node
grep的工做方式是這樣的,它在一個或多個文件中搜索字符串模板。若是模板包括空格,則必須被引用,模板後的全部字符串被看做文件名。搜索的結果被送到標準輸出,不影響原文件內容。grep可用於shell腳本,由於grep經過返回一個狀態值來講明搜索的狀態,若是模板搜索成功,則返回0,若是搜索不成功,則返回1,若是搜索的文件不存在,則返回2。咱們利用這些返回值就可進行一些自動化的文本處理工做。linux
命令格式:grep [option] pattern filegit
grep的經常使用選項: -V: 打印grep的版本號 -E: 解釋PATTERN做爲擴展正則表達式,也就至關於使用egrep。 或操做 -F : 解釋PATTERN做爲固定字符串的列表,由換行符分隔,其中任何一個都要匹配。也就至關於使用fgrep。 -G: 將範本樣式視爲普通的表示法來使用。這是默認值。加不加都是使用grep。 匹配控制選項: -e : 使用PATTERN做爲模式。這能夠用於指定多個搜索模式,或保護以連字符( - )開頭的圖案。指定字符串作爲查找文件內容的樣式。 -f : 指定規則文件,其內容含有一個或多個規則樣式,讓grep查找符合規則條件的文件內容,格式爲每行一個規則樣式。 -i : 搜索時候忽略大小寫 -v: 反轉匹配,選擇沒有被匹配到的內容。 -w:匹配整詞,精確地單詞,單詞的兩邊必須是非字符符號(即不能是字母數字或下劃線) -x:僅選擇與整行徹底匹配的匹配項。精確匹配整行內容(包括行首行尾那些看不到的空格內容都要徹底匹配) -y:此參數的效果和指定「-i」參數相同。 通常輸出控制選項: -c: 抑制正常輸出;而是爲每一個輸入文件打印匹配線的計數。 --color [= WHEN]:讓關鍵字高亮顯示,如--color=auto -L:列出文件內容不符合指定的範本樣式的文件名稱 -l : 列出文件內容符合指定的範本樣式的文件名稱。 -m num:當匹配內容的行數達到num行後,grep中止搜索,並輸出中止前搜索到的匹配內容 -o: 只輸出匹配的具體字符串,匹配行中其餘內容不會輸出 -q:安靜模式,不會有任何輸出內容,查找到匹配內容會返回0,未查找到匹配內容就返回非0 -s:不會輸出查找過程當中出現的任何錯誤消息,-q和-s選項由於與其餘系統的grep有兼容問題,shell腳本應該避免使用-q和-s,而且應該將標準和錯誤輸出重定向到/dev/null 代替。 輸出線前綴控制: -b:輸出每個匹配行(或匹配的字符串)時在其前附加上偏移量(從文件第一個字符到該匹配內容之間的字節數) -H:在每個匹配行以前加上文件名一塊兒輸出(針對於查找單個文件),當查找多個文件時默認就會輸出文件名 -h:禁止輸出上的文件名的前綴。不管查找幾個文件都不會在匹配內容前輸出文件名 --label = LABEL:顯示實際來自標準輸入的輸入做爲來自文件LABEL的輸入。這是特別在實現zgrep等工具時很是有用,例如gzip -cd foo.gz | grep --label = foo -H的東西。看到 也是-H選項。 -n:輸出匹配內容的同時輸出其所在行號。 -T:初始標籤確保實際行內容的第一個字符位於製表位上,以便對齊標籤看起來很正常。在匹配信息和其前的附加信息之間加入tab以使格式整齊。 上下文線控制選項: -A num:匹配到搜索到的行以及該行下面的num行 -B num:匹配到搜索到的行以及該行上面的num行 -C num:匹配到搜索到的行以及上下各num行 文件和目錄選擇選項: -a: 處理二進制文件,就像它是文本;這至關於--binary-files = text選項。不忽略二進制的數據。 --binary-files = TYPE:若是文件的前幾個字節指示文件包含二進制數據,則假定該文件爲類型TYPE。默認狀況下,TYPE是二進制的,grep一般輸出一行消息二進制文件匹配,或者若是沒有匹配則沒有消息。若是TYPE不匹配,grep假定二進制文件不匹配;這至關於-I選項。若是TYPE是文本,則grep處理a二進制文件,若是它是文本;這至關於-a選項。警告:grep --binary-files = text可能會輸出二進制的垃圾,若是輸出是一個終端和若是可能有討厭的反作用終端驅動程序將其中的一些解釋爲命令。 -D:若是輸入文件是設備,FIFO或套接字,請使用ACTION處理。默認狀況下,讀取ACTION,這意味着設備被讀取,就像它們是普通文件同樣。若是跳過ACTION,設備爲 默默地跳過。 -d: 若是輸入文件是目錄,請使用ACTION處理它。默認狀況下,ACTION是讀的,這意味着目錄被讀取,就像它們是普通文件同樣。若是跳過ACTION,目錄將靜默跳過。若是ACTION是recurse,grep將遞歸讀取每一個目錄下的全部文件;這是至關於-r選項。 --exclude=GLOB:跳過基本名稱與GLOB匹配的文件(使用通配符匹配)。文件名glob可使用*,?和[...]做爲通配符,和\引用通配符或反斜槓字符。搜索其文件名和GLOB通配符相匹配的文件的內容來查找匹配使用方法:grep -H --exclude=c* "old" ./* c*是通配文件名的通配符./* 指定須要先通配文件名的文件的範圍,必需要給*,否則就匹配不出內容,(若是不給*,帶上-r選項也能夠匹配) --exclude-from = FILE:在文件中編寫通配方案,grep將不會到匹配方案中文件名的文件去查找匹配內容 --exclude-dir = DIR:匹配一個目錄下的不少內容同時還要讓一些子目錄不接受匹配,就使用此選項。 --include = GLOB:僅搜索其基本名稱與GLOB匹配的文件(使用--exclude下所述的通配符匹配)。 -R ,-r :以遞歸方式讀取每一個目錄下的全部文件; 這至關於-d recurse選項。 其餘選項: --line-buffered: 在輸出上使用行緩衝。這可能會致使性能損失。 --mmap:啓用mmap系統調用代替read系統調用 -U:將文件視爲二進制。 -z:將輸入視爲一組行,每一行由一個零字節(ASCII NUL字符)而不是a終止新隊。與-Z或--null選項同樣,此選項能夠與排序-z等命令一塊兒使用來處理任意文件名。
簡述正則表達式
-a --text #不要忽略二進制的數據。 將 binary 文件以 text 文件的方式搜尋數據 -A<顯示行數> --after-context=<顯示行數> #除了顯示符合範本樣式的那一列以外,並顯示該行以後的內容。 -b --byte-offset #在顯示符合樣式的那一行以前,標示出該行第一個字符的編號。 -B<顯示行數> --before-context=<顯示行數> #除了顯示符合樣式的那一行以外,並顯示該行以前的內容。 -c --count #計算符合樣式的行數。 -C<顯示行數> --context=<顯示行數>或-<顯示行數> #除了顯示符合樣式的那一行以外,並顯示該行以前後的內容。 -d <動做> --directories=<動做> #當指定要查找的是目錄而非文件時,必須使用這項參數,不然grep指令將回報信息並中止動做。 -e<範本樣式> --regexp=<範本樣式> #指定字符串作爲查找文件內容的樣式。 -E --extended-regexp #將樣式爲延伸的普通表示法來使用。 -f<規則文件> --file=<規則文件> #指定規則文件,其內容含有一個或多個規則樣式,讓grep查找符合規則條件的文件內容,格式爲每行一個規則樣式。 -F --fixed-regexp #將樣式視爲固定字符串的列表。 -G --basic-regexp #將樣式視爲普通的表示法來使用。 -h --no-filename #在顯示符合樣式的那一行以前,不標示該行所屬的文件名稱。 -H --with-filename #在顯示符合樣式的那一行以前,表示該行所屬的文件名稱。 -i --ignore-case #忽略字符大小寫的差異。 -l --file-with-matches #列出文件內容符合指定的樣式的文件名稱。 -L --files-without-match #列出文件內容不符合指定的樣式的文件名稱。 -n --line-number #在顯示符合樣式的那一行以前,標示出該行的列數編號。 -q --quiet或--silent #不顯示任何信息。 -r --recursive #此參數的效果和指定「-d recurse」參數相同。 -s --no-messages #不顯示錯誤信息。 -v --revert-match #顯示不包含匹配文本的全部行。 -V --version #顯示版本信息。 -w --word-regexp #只顯示全字符合的列。 -x --line-regexp #只顯示全列符合的列。 -y #此參數的效果和指定「-i」參數相同。
--color=auto :能夠將找到的關鍵詞部分加上顏色的顯示
grep -i pattern files :不區分大小寫地搜索。默認狀況區分大小寫, grep -l pattern files :只列出匹配的文件名, grep -L pattern files :列出不匹配的文件名, grep -w pattern files :只匹配整個單詞,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’), grep -C number pattern files :匹配的上下文分別顯示[number]行, grep pattern1 | pattern2 files :顯示匹配 pattern1 或 pattern2 的行, grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。
這裏還有些用於搜索的特殊符號: < 和 > 分別標註單詞的開始與結尾。 例如: grep man * 會匹配 ‘Batman’、‘manic’、‘man’等, grep \'<man\' * 匹配‘manic’和‘man’,但不是‘Batman’, grep \'<man>\' 只匹配‘man’,而不是‘Batman’或‘manic’等其餘的字符串。 \'^\':指匹配的字符串在行首, \'$\':指匹配的字符串在行尾, 若是您不習慣命令行參數,能夠試試圖形界面的‘grep’,如 reXgrep 。這個軟件提供 AND、OR、NOT 等語法,還有漂亮的按鈕 :-) 。若是您只是須要更清楚的輸出,不妨試試 fungrep 。 .grep 搜索字符串 命令格式: grep string filename 尋找字串的方法不少,好比說我想找全部以M開頭的行.此時必須引進pattern的觀 念.如下是一些簡單的□例,以及說明: ^M 以M開頭的行,^表示開始的意思 M$ 以M結尾的行,$表示結束的意思 ^[0-9] 以數字開始的行,[]內可列舉字母 ^[124ab] 以1,2,4,a,或b開頭的行 ^b.503 句點表示任一字母 * 星號表示0個以上的字母(能夠沒有) + 加號表示1個以上的字母 . 斜線能夠去掉特殊意義 <eg> cat passwd | grep ^b 列出大學部有申請賬號者名單 cat passwd | grep ^s 列出交換學生申請賬號者名單 cat passwd | grep \'^b.503\' 列出電機系各年級... grep \'^.\' myfile.txt 列出全部以句點開頭的行
一、查找指定進程shell
命令:ps -ef|grep javaexpress
二、查找指定進程個數bash
命令:ps -ef|grep -c javassh
或ps -ef|grep java -ctcp
三、從文件中讀取關鍵詞進行搜索,默認是顯示的是行
命令1:cat test.txt | grep -f test2.txt
命令2(顯示行號):cat test.txt | grep -nf test2.txt
做用:輸出test.txt文件中含有從test2.txt文件中讀取出的關鍵詞的內容行,可用於按指定關鍵詞(放到一個文件中)搜索日誌文件。
另外一種用法:將多個文件之間相同的行輸出來
# cd /etc/sysconfig/network-scripts/
# grep "IPADDR" ifcfg-eth0 ifcfg-lo #默認不加參數指定過濾關鍵字,外加多個文件,只是將多個文件裏面有匹配的行輸出
ifcfg-eth0:IPADDR=192.168.1.108
ifcfg-lo:IPADDR=127.0.0.1
# grep -f ifcfg-eth0 ifcfg-lo #grep -f 文件1 文件2 ,會將多個文件之間相同的行輸出出來
ONBOOT=yes
-o:只顯示被模式匹配到的字符串,而不是整個行
命令:grep -o "you" ab.log
# grep "root" /etc/passwd #先看下正常的過濾,會將整個一行過濾出來
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
# grep -o "root" /etc/passwd #加o以後的操做,只過濾關鍵字出來
root
root
root
root
# grep -o "root:.*0" /etc/passwd #加上正則表達式,這樣纔是正確的用法,不用輸出一整行,只是輸出一小段
root:x:0:0
# grep -o "root" -b /etc/passwd
-b和-o通常是配合使用的,一行中字符串的字符是從該行的第一個字符開始計算,起始值爲0。這裏左邊的數字就是此關鍵字在此文件中的起始位置,第一個root出如今0位置,而後字符字母有一個算一個,你就一個個的向右數吧,下一個root出如今11位置以此類推。
0:root
11:root
17:root
414:root
四、從文件中查找關鍵詞,忽略大小寫,默認狀況區分大小寫
命令1:grep 'linux' test.txt
命令2(從多個文件中查找):grep 'linux' test.txt test2.txt
多文件時,輸出查詢到的信息內容行時,會把文件的命名在行最前面輸出而且加上":"做爲標示符
命令3(忽略大小寫):grep -i 'linux' test.txt
命令:find . -name ".log" | grep -i error | grep -vi "info"
1)使用find -name 來列出全部log文件,重定向給grep
2)使用grep -i 來查找包含error的行
3)使用grep -vi 來查找不包含info的行
五、grep不顯示自己
命令:
ps aux|grep \[s]sh
ps aux | grep ssh | grep -v "grep" #不包含grep ssh這條命令
grep -v root /etc/passwd | grep -v nologin #將/etc/passwd,將沒有出現 root 和nologin的行取出來
六、-r 遞歸查找子目錄
查找當前目錄及其子目錄下面包含匹配字符的文件
# grep ‘ab’ * #在當前目錄搜索帶'ab'行的文件
# grep -r ‘ab’ * #在當前目錄及其子目錄下搜索'ab'行的文件
# grep -l -r ‘ab’ * #在當前目錄及其子目錄下搜索'ab'行的文件,可是不顯示匹配的行,只顯示匹配的文件
# grep -nr BLOG* . # 查找子目錄,匹配後輸出行號,這裏的點表示當前目錄
# grep -lr BLOG* . #查找子目錄,匹配後只輸出文件名
查詢不包含某個目錄
#grep -R --exclude-dir=node_modules 'some pattern' /path/to/search #不包含txt目錄
七、列出關鍵字所在行的前幾行與後幾行也一塊兒顯示
-A -B -C
不少時候,咱們並關心匹配行而是關心匹配行的上下文。這時候-A -B -C就有用了
-A n 後n行,A記憶爲(After)
-B n 前n行,B記憶爲(Before)
-C n 前n行,後n行,C記憶爲(Center)
[root@www ~]# dmesg | grep -n -A3 -B2 --color=auto 'eth' 245-PCI: setting IRQ 10 as level-triggered 246-ACPI: PCI Interrupt 0000:00:0e.0[A] -> Link [LNKB] ... 247:eth0: RealTek RTL8139 at 0xee846000, 00:90:cc:a6:34:84, IRQ 10 248:eth0: Identified 8139 chip type 'RTL-8139C' 249-input: PC Speaker as /class/input/input2 250-ACPI: PCI Interrupt 0000:00:01.4[B] -> Link [LNKB] ... 251-hdb: ATAPI 48X DVD-ROM DVD-R-RAM CD-R/RW drive, 2048kB Cache, UDMA(66) # 如上所示,你會發現關鍵字 247 所在的前兩行及 248 後三行也都被顯示出來!
八、--line-buffered 打開buffering 模式
有一個文件是動態的,它不斷地添加信息到文件的尾部,而你想要輸出包含某些信息的行。即持續的grep一個動態的流
九、e與E區別
grep想同時過濾多個條件或操做
錯誤寫法:
# netstat -an|grep "ESTABLISHED|WAIT" #默認grep不支持多條件匹配
正確寫法:
# netstat -an|grep -E "ESTABLISHED|WAIT" #加上-E 多條件用""包起來,而後多條件之間用|管道符分開
tcp 0 52 192.168.1.108:22 192.168.1.104:54127 ESTABLISHED
# ps -aux|grep -e udevd -e master|awk {'print $(NF-1)'}|sort|uniq #而-e呢不用""包起來,-e 指定一個匹配條件
/sbin/udevd
/usr/bin/salt-master
grep -E '123|abc' filename // 找出文件(filename)中包含123或者包含abc的行
egrep '123|abc' filename // 用egrep一樣能夠實現
awk '/123|abc/' filename // awk 的實現方式
與操做
grep pattern1 files | grep pattern2 :顯示既匹配 pattern1 又匹配 pattern2 的行。
十、-c 統計行數
# grep -i "abc" test.txt|wc -l #不分大小寫。test.txt裏面包含abc過濾條件的爲2行
2
# grep -yc "abc" test.txt #-c呢,就是不顯示行的內容,直接顯示有幾行
2
# cat /etc/passwd|wc -l
55
# grep -c "^.*$" /etc/passwd #那麼咱們除了wc -l用來統一一個文件有多少行之外,又多了一種統計文件多少行的方法
55
十一、 -m的使用
# cat test2.txt #這是測試文件
abc 1
abc 2
abc 3
abc 4
abc 5
# grep -m 3 "abc" test2.txt #只匹配到了第三行就退出了
abc 1
abc 2
abc 3
grep的規則表達式: \ 反義字符:如"\"\""表示匹配"" [ - ] 匹配一個範圍,[0-9a-zA-Z]匹配全部數字和字母 * 全部字符,長度可爲0 + 前面的字符出現了一次或者屢次 ^ #匹配行的開始 如:'^grep'匹配全部以grep開頭的行。 $ #匹配行的結束 如:'grep$'匹配全部以grep結尾的行。 . #匹配一個非換行符的字符 如:'gr.p'匹配gr後接一個任意字符,而後是p。 * #匹配零個或多個先前字符 如:'*grep'匹配全部一個或多個空格後緊跟grep的行。 .* #一塊兒用表明任意字符。 [] #匹配一個指定範圍內的字符,如'[Gg]rep'匹配Grep和grep。 [^] #匹配一個不在指定範圍內的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一個字母開頭,緊跟rep的行。 \(..\) #標記匹配字符,如'\(love\)',love被標記爲1。 \< #到匹配正則表達式的行開始,如:'\<grep'匹配包含以grep開頭的單詞的行。 \> #到匹配正則表達式的行結束,如'grep\>'匹配包含以grep結尾的單詞的行。 x\{m\} #重複字符x,m次,如:'0\{5\}'匹配包含5個o的行。 x\{m,\} #重複字符x,至少m次,如:'o\{5,\}'匹配至少有5個o的行。 x\{m,n\} #重複字符x,至少m次,很少於n次,如:'o\{5,10\}'匹配5--10個o的行。 \w #匹配文字和數字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G後跟零個或多個文字或數字字符,而後是p。 \W #\w的反置形式,匹配一個或多個非單詞字符,如點號句號等。 \b #單詞鎖定符,如: '\bgrep\b'只匹配grep。
POSIX字符: 爲了在不一樣國家的字符編碼中保持一至,POSIX(The Portable Operating System Interface)增長了特殊的字符類,如[:alnum:]是[A-Za-z0-9]的另外一個寫法。要把它們放到[]號內才能成爲正則表達式,如[A- Za-z0-9]或[[:alnum:]]。在linux下的grep除fgrep外,都支持POSIX的字符類。 [:alnum:] #文字數字字符 [:alpha:] #文字字符 [:digit:] #數字字符 [:graph:] #非空字符(非空格、控制字符) [:lower:] #小寫字符 [:cntrl:] #控制字符 [:print:] #非空字符(包括空格) [:punct:] #標點符號 [:space:] #全部空白字符(新行,空格,製表符) [:upper:] #大寫字符 [:xdigit:] #十六進制數字(0-9,a-f,A-F)
例:經過管道過濾ls -l輸出的內容,只顯示以a開頭的行。
首與行尾字節 ^ $,^ 符號,在字符類符號(括號[])以內與以外是不一樣的! 在 [] 內表明『反向選擇』,在 [] 以外則表明定位在行首的意義!
$ ls -l | grep \'^a\'
$ ls -l | grep ^a
$ ls -l | grep ^[^a] #輸出非a開頭的行,反向選擇
$ grep -n '^$' express.txt #找出空白行,由於只有行首跟行尾 (^$)
例:顯示全部以d開頭的文件中包含test的行。
$ grep \'test\' d*
例:輸出以hat結尾的行內容
$ cat test.txt |grep hat$
例:顯示在aa,bb,cc文件中匹配test的行。
$ grep \'test\' aa bb cc
例:顯示全部包含每一個字符串至少有5個連續小寫字符的字符串的行。
在一組集合字節中,若是該字節組是連續的,例如大寫英文/小寫英文/數字等等,就可使用[a-z],[A-Z],[0-9]等方式來書寫,那麼若是咱們的要求字串是數字與英文呢?就將他所有寫在一塊兒,變成:[a-zA-Z0-9]。
$ grep \'[a-z]{5}\' aa
$ grep -n '[0-9]' regular_express.txt #取得有數字的那一行
$ grep -n '^[a-z]' regular_express.txt #只輸出開頭是小寫字母的那一行
$ grep -n '^[^a-zA-Z]' regular_express.txt #不輸出開頭是英文的
$ grep -n '\.$' regular_express.txt #只輸出行尾結束爲小數點 (.) 的那一行
注意:小數點具備其餘意義,因此必需要使用轉義字符(\)來加以解除其特殊意義!
例:顯示包含ed或者at字符的內容行
命令:cat test.txt |grep -E "ed|at"
例:若是west被匹配,則es就被存儲到內存中,並標記爲1,而後搜索任意個字符(.*),這些字符後面緊跟着另一個es(1),找到就顯示該行。若是用egrep或grep -E,就不用""號進行轉義,直接寫成\'w(es)t.*1\'就能夠了。
$ grep \'w(es)t.*1\' aa
例:顯示當前目錄下面以.txt 結尾的文件中的全部包含每一個字符串至少有7個連續小寫字符的字符串的行
命令:grep '[a-z]\{7\}' *.txt
例:查詢IP地址、郵箱、手機號
這裏用到了-o和-P命令
man grep查看
-o, --only-matching:
Show only the part of a matching line that matches PATTERN.
-P, --perl-regexp:
Interpret PATTERN as a Perl regular expression.
也就是說-o,只顯示匹配行中匹配正則表達式的那部分,-P,做爲Perl正則匹配
192.168.0.1
abc@163.com
匹配ABC類IP地址即 1.0.0.1---223.255.255.254
命令(IP):grep -oP "([0-9]{1,3}\.){3}[0-9]{1,3}" file.txt
或grep -E --color "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-1][0-9]|22[0-3])\.([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-4])\>" file.txt
郵箱是任意長度數字字母@任意長度數字字母
命令(郵箱):grep -oP "[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+" file.txt
手機號碼是1[3|4|5|8]後面接9位數字的
命令(手機號):grep -E "\<1[3|4|5|8][0-9]{9}\>" file.txt
例:任意一個字節 . 與重複字節 *
. (小數點):表明『必定有一個任意字節』的意思; * (星號):表明『重複前一個字符, 0 到無窮屢次』的意思,爲組合形態
$ grep -n '[0-9][0-9]*' regular_express.txt #找出『任意數字』的行
$ grep -n 'g.*g' regular_express.txt #找出以g行首與行尾的行,當中的字符無關緊要
這個 .* 的 RE 表示任意字符是很常見的.
例:限定連續 RE 字符範圍 {}
利用 . 與 RE 字符及 * 來配置 0 個到無限多個重複字節
打算找出兩個到五個 o 的連續字串,該如何做?這時候就得要使用到限定範圍的字符 {} 了。 但由於 { 與 } 的符號在 shell 是有特殊意義的,所以, 咱們必需要使用字符 \ 來讓他失去特殊意義才行。
$ grep -n 'o\{2\}' regular_express.txt
$ grep -n 'go\{2,5\}g' regular_express.txt #要找出 g 後面接 2 到 5 個 o ,而後再接一個 g 的字串
$ grep -n 'go\{2,\}g' regular_express.txt #想要的是 2 個 o 以上的 goooo....g 呢?除了能夠是 gooo*g
參考資料:
grep 用法小結:請點擊直接查看大圖