詳解Linux命令中的正則表達式
命令中的正則表達式
如果要在命令輸出或文本中篩選內容時使用模糊查找,就需要使用正則表達式。正則表達式是一套由多個元字符組成的模糊查找模式,使用正則表達式可以快速查找和定位文本中指定的內容。
1、單字符匹配符.
正則表達式主要由一些元字符和匹配模式組成
單字符匹配符可以匹配任意單個字符,這個字符的功能和文件名匹配符中的?功能相同
使用正則表達式查找文本,首先需要使用元字符組成一個查找模式
(1)使用查找模式時,通常將其放入兩個斜杠//中,然后再放入命令,例如要在一個文本中查找匹配模式/.i...../,可能選項就有:只要小寫字母沒有出現(xiàn)在行首,或行尾的最后有5個字符都能匹配
2、單字符或字符串重復匹配符*
用來匹配單個字符或者一個字符串序列的一次或者多次重復出現(xiàn)
3、行首匹配符^
用于在匹配中指示行首位置字符串或者模式,使用時需要將行首匹配符放在要匹配的字符串或模式的前面
例如對命令ls -1 使用行首匹配/^1/,結果都是以1開頭的
4、行尾匹配符$
用于在文本的每一行的行尾匹配字符串或模式,使用時將行尾匹配符放在字符串或模式后面
例如在文本中匹配所有行尾是love的行
/love$/
5、反斜杠屏蔽符\
該符用來屏蔽一些特殊字符的特殊含義,常見的特殊字符可能是引用符號,注釋符號,通配符和邏輯運算符等,下面列舉一些特殊的符號
注釋、分隔符號:#、;等
引用符號:$、``、""等
元字符:.、*、^、$、?、[]、\等
邏輯運算符或操作符:||、&&等
在命令中使用這些字符時,都要使用反斜杠將其特殊含義屏蔽
例如使用乘法符號*做乘法運算,就要用反斜杠將其特殊含義屏蔽在做使用
# expr 256 \* 256
6、范圍匹配符[]和排除范圍匹配符[^]
與文件名通配符中的范圍匹配符用法基本相同
(1)匹配單詞love和Love:
/[L]ove/
(2)不匹配所有的字母:
[^a-z]
7、詞首、詞尾匹配符 \< 和 \>
用于在單詞開頭和單詞結尾匹配特定的字符或模式
(1)例如要匹配以disc 為詞首的文本,可以使用
/\<disc/
(2)要匹配以ment為詞尾的文本,可以使用:
/ment\>/
8、重復次數(shù)匹配符"x\{\}"
可以全精確匹配字符或字符串連續(xù)出現(xiàn)的次數(shù)或次數(shù)范圍
(1)要匹配字母m出現(xiàn)次數(shù)為5次的文本,可以使用:
/m\{5\}/
(2)要匹配字母m出現(xiàn)次數(shù)至少5次的文本,可以使用:
/m\{5,\}/
(3)匹配字母m出現(xiàn)次數(shù)在5至10次的文本,可以使用:
/m\{5,10\}/
9、組合并使用正則表達式
(1)在查找和篩選信息時,有時需要去除文本中的空行,由于空行沒有任 何字符,可以使用行首,行尾匹配符匹配空行
/^$/
(2)有時一些文本為了看上去更加美觀,會使用一種字符填充整行,可以使 用以下模式匹配這些行:
/^.*$/
(3)匹配以the或The開頭的所有行
/^[tT]he/
(4)排除以the和The開頭的所有行
/^[^Tt]he/
(5)匹配一個IP地址:
/[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}/
(6)匹配一個6個字母組成的字符串,前兩個字符是字母,中間兩個字符是22 且最后兩個字符是小寫字母:
[a-z]\{2\}22[a-z]\{2\}
(7)要精確匹配單詞love:
/\<love\>/
以上所述是小編給大家介紹的詳解Linux命令中的正則表達式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持
相關文章
linux shell實現(xiàn)隨機數(shù)幾種方法分享(date,random,uuid)
這篇文章主要介紹了linux shell實現(xiàn)隨機數(shù)多種方法(date,random,uuid),需要的朋友可以參考下2015-10-10hi 感恩節(jié)——Linux基礎教程之mysql和php
這篇文章主要介紹了hi 感恩節(jié)——Linux基礎教程之mysql和php的相關資料,需要的朋友可以參考下2015-11-11使用Linux shell腳本實現(xiàn)FTP定時執(zhí)行批量下載指定文件
使用FTP定時批量下載指定文件的shell腳本,具體實例介紹如下所示,需要的朋友參考下吧2017-04-04