“全局查找正則表達(dá)式(RE)并且打印..."/>
您好,登錄后才能下訂單哦!
前言
grep怎么出來(lái)的?
這就需要我們庖丁解牛了,“g/RE/p”看到?jīng)],就是這樣“global Regular Expression print”==>“全局查找正則表達(dá)式(RE)并且打印結(jié)果行。”
grep家族由命令grep,egrep和fgrep組成。后兩者是前者的變體。一個(gè)胖了,一個(gè)瘦了而已。
使用grep的好處就在于,不需要啟動(dòng)編輯器就可以執(zhí)行查找操作,也用不著把pattern放在“//”里,使用grep要比vi快的多,并且還多了許多命令行選項(xiàng)。
格式
grep -option 'pattern' filename 或者
|grep -option 'pattern'
grep的正則表達(dá)式元字符
見(jiàn)上文shell之正則表達(dá)式:
http://1076546426.blog.51cto.com/9959876/1702784
grep選項(xiàng)
選項(xiàng) | 功能 |
-b | 在每行前面加上其所在的塊號(hào),根據(jù)上下文定位磁盤塊時(shí)可能會(huì)用到 |
-c | 顯示匹配到的行的數(shù)目,而不顯示行的內(nèi)容 |
-h | 不顯示文件名 |
-i | 匹配字符時(shí)忽略大小寫 |
-l | 只列出匹配行所在文件的文件名(每個(gè)文件名只列一次),文件名之間用換行符分隔 |
-n | 在每一行的前面加上它在文件中的相對(duì)行號(hào) |
-s | 無(wú)聲操作,即只顯示報(bào)錯(cuò)信息,以檢查退出狀態(tài) |
-v | 反向查找,只顯示不匹配的行 |
-w | 把表達(dá)式作為詞來(lái)查找,只適用于grep。=====\<\> |
注:更多選項(xiàng)請(qǐng)查看:grep -h 或者 man grep
egrep新增元字符
元字符 | 功能 |
+ | 匹配一個(gè)或多個(gè)+號(hào)以前的字符 |
? | 匹配1個(gè)或0個(gè)前導(dǎo)字符 |
a|b | 匹配a或b |
() | 字符組 |
思路拓展:
示例 | 注解 |
'[a-z]+ove' | 匹配1個(gè)或多個(gè)字母后跟ove的字符串 |
'lo?ve' | 匹配l后跟ove或ve的字符串 |
'love|hate' | 匹配love和hate這兩個(gè)字符串之一 |
'love(able|ly)' | 匹配loveable或lovely |
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。