亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來到思海網絡,我們將竭誠為您提供優質的服務! 誠征網絡推廣 | 網站備案 | 幫助中心 | 軟件下載 | 購買流程 | 付款方式 | 聯系我們 [ 會員登錄/注冊 ]
促銷推廣
客服中心
業務咨詢
有事點擊這里…  531199185
有事點擊這里…  61352289
點擊這里給我發消息  81721488
有事點擊這里…  376585780
有事點擊這里…  872642803
有事點擊這里…  459248018
有事點擊這里…  61352288
有事點擊這里…  380791050
技術支持
有事點擊這里…  714236853
有事點擊這里…  719304487
有事點擊這里…  1208894568
有事點擊這里…  61352289
在線客服
有事點擊這里…  531199185
有事點擊這里…  61352288
有事點擊這里…  983054746
有事點擊這里…  893984210
當前位置:首頁 >> 技術文章 >> 文章瀏覽
技術文章

Linux的grep命令中正則表達式的用法

添加時間:2016-2-16 19:30:17  添加: 思海網絡 
Linux 附帶有 GNU grep 命令工具,它支持擴展正則表達式extended regular expressions,而且 GNU grep 在所有的 Linux 系統中都是默認有的。Grep 命令被用于搜索定位存儲在您服務器或工作站上的任何信息。


正則表達式
正則表達式就是用于匹配每行輸入的一種模式,模式是指一串字符序列。下面是范例:



代碼如下:
^w1
w1|w2
[^ ]

grep 正則表達式示例
在 /etc/passswd 目錄中搜索 'vivek'



代碼如下:
grep vivek /etc/passwd

輸出例子:


代碼如下:
vivek:x:1000:1000:Vivek Gite,,,:/home/vivek:/bin/bash
vivekgite:x:1001:1001::/home/vivekgite:/bin/sh
gitevivek:x:1002:1002::/home/gitevivek:/bin/sh

搜索大小寫任意的 vivek(即不區分大小寫的搜索)


代碼如下:
grep -i -w vivek /etc/passwd

搜索大小寫任意的 vivek 或 raj


代碼如下:
grep -E -i -w 'vivek|raj' /etc/passwd

上面最后的例子顯示的,就是一個擴展的正則表達式的模式。

錨點
你可以分別使用 ^ 和 $ 符號來正則匹配輸入行的開始或結尾。下面的例子搜索顯示僅僅以 vivek 開始的輸入行:



代碼如下:
grep ^vivek /etc/passwd

輸出例子:


代碼如下:
vivek:x:1000:1000:Vivek Gite,,,:/home/vivek:/bin/bash
vivekgite:x:1001:1001::/home/vivekgite:/bin/sh

你可以僅僅只搜索出以單詞 vivek 開始的行,即不顯示 vivekgit、vivekg 等(LCTT 譯注:即該單詞后面是空格、符號等英文的單詞分隔符。)


代碼如下:
grep -w ^vivek /etc/passwd

找出以單詞 word 結尾的行:


代碼如下:
grep 'foo$' 文件名

匹配僅僅只包含 foo 的行:


代碼如下:
grep '^foo$' 文件名

如下所示的例子可以搜索空行:


代碼如下:
grep '^$' 文件名

字符類
匹配 Vivek 或 vivek:



代碼如下:
grep '[vV]ivek' 文件名

或者


代碼如下:
grep '[vV][iI][Vv][Ee][kK]' 文件名

也可以匹配數字 (即匹配 vivek1 或 Vivek2 等等):


代碼如下:
grep -w '[vV]ivek[0-9]' 文件名

可以匹配兩個數字字符(即 foo11、foo12 等):


代碼如下:
grep 'foo[0-9][0-9]' 文件名

不僅僅局限于數字,也能匹配至少一個字母的:


代碼如下:
grep '[A-Za-z]' 文件名

顯示含有 "w" 或 "n" 字符的所有行:


代碼如下:
grep [wn] 文件名

放在括號內的表達式,即包在 "[:" 和 ":]" 之間的字符類的名字,它表示的是屬于此類的所有字符列表。標準的字符類名稱如下:
[:alnum:] - 字母數字字符
[:alpha:] - 字母字符
[:blank:] - 空字符: 空格鍵符 和 制表符
[:digit:] - 數字: '0 1 2 3 4 5 6 7 8 9'
[:lower:] - 小寫字母: 'a b c d e f g h i j k l m n o p q r s t u v w x y z'
[:space:] - 空格字符: 制表符、換行符、垂直制表符、換頁符、回車符和空格鍵符
[:upper:] - 大寫字母: 'A B C D E F G H I J K L M N O P Q R S T U V W X Y Z'
在這個例子所示的是匹配所有大寫字母:


代碼如下:
grep '[:upper:]' 文件名

通配符
你可以使用 "." 來匹配單個字符。例子中匹配以 "b" 開頭以 "t" 結尾的3個字符的單詞:



代碼如下:
grep '\<b.t\>' 文件名

在這兒,
\< 匹配單詞前面的空字符串
\> 匹配單詞后面的空字符串
打印出只有兩個字符的所有行:


代碼如下:
grep '^..$' 文件名

顯示以一個點和一個數字開頭的行:


代碼如下:
grep '^\.[0-9]' 文件名

點字符轉義
下面要匹配到 IP 地址為 192.168.1.254 的正則式是不正確的:(LCTT 譯注:可以匹配到該 IP 地址,但是也有可能匹配到間隔符號不是點的類似格式)



代碼如下:
grep '192.168.1.254' /etc/hosts

三個點字符都需要轉義:


代碼如下:
grep '192\.168\.1\.254' /etc/hosts

下面的例子只能匹配出 IP 地址:(LCTT 譯注:實際上由于 IP 地址中數字的取值范圍,該正則表達式并不精確)


代碼如下:
egrep '[[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}' 文件名

怎么樣搜索以“-” 符號開頭的匹配模式?
要使用 -e 選項來搜索匹配 '--test--' 字符串,如果不使用 -e 選項,grep 命令會試圖把 '--test--' 當作自己的選項參數來解析:


代碼如下:
grep -e '--test--' 文件名

怎么使用 grep 的“或”匹配?
使用如下的語法:



代碼如下:
grep -E 'word1|word2' 文件名



代碼如下:
egrep 'word1|word2' 文件名

或者是


代碼如下:
grep 'word1\|word2' 文件名

怎么使用 grep 的“和”匹配?
使用下面的語法來顯示既包含 'word1' 又包含 'word2' 的所有行


代碼如下:
grep 'word1' 文件名 | grep 'word2'

怎么樣使用序列檢測?
使用如下的語法,您可以檢測一個字符在序列中重復出現次數:


代碼如下:
{N}
{N,}
{min,max}

要匹配字符 “v" 出現兩次:


代碼如下:
egrep "v{2}" 文件名

下面的命令能匹配到 "col" 和 "cool" :


代碼如下:
egrep 'co{1,2}l' 文件名

下面的命令將會匹配出至少有三個 'c' 字符的所有行。


代碼如下:
egrep 'c{3,}' 文件名

下面的例子會匹配 91-1234567890(即二個數字-十個數字) 這種格式的手機號。


代碼如下:
grep "[[:digit:]]\{2\}[ -]\?[[:digit:]]\{10\}" 文件名

怎么樣使 grep 命令高亮顯示?
使用如下的語法:



代碼如下:
grep --color 正則表達式 文件名

怎么樣僅僅只顯示匹配出的字符,而不是匹配出的行?
使用如下語法:


代碼如下:
grep -o 正則表達式 文件名

正則表達式限定符


限定符 描述 
. 匹配任意的一個字符。 
? 匹配前面的子表達式,最多一次。 
* 匹配前面的子表達式零次或多次。 
+ 匹配前面的子表達式一次或多次。 
{N} 匹配前面的子表達式 N 次。 
{N,} 匹配前面的子表達式 N 次到多次。 
{N,M} 匹配前面的子表達式 N 到 M 次,至少 N 次至多 M 次。 
- 只要不是在序列開始、結尾或者序列的結束點上,表示序列范圍。 
^ 匹配一行開始的空字符串;也表示字符不在要匹配的列表中。 
$ 匹配一行末尾的空字符串。 
\b 匹配一個單詞前后的空字符串。 
\B 匹配一個單詞中間的空字符串。 
\< 匹配單詞前面的空字符串。 
\> 匹配單詞后面的空字符串。 


grep 和 egrep
egrep 等同于 grep -E 。它會以擴展的正則表達式的模式來解釋模式。下面來自 grep 的幫助頁:
基本的正則表達式元字符 ?、+、 {、 |、 ( 和 ) 已經失去了它們原來的意義,要使用的話用反斜線的版本 \?、\+、\{、\|、\( 和 \) 來代替。 傳統的 egrep 并不支持 { 元字符,一些 egrep 的實現是以 \{ 替代的,所以一個可移植的腳本應該避免在 grep -E 使用 { 符號,要匹配字面的 { 應該使用 [}]。
GNU grep -E 試圖支持傳統的用法,如果 { 出在在無效的間隔規范字符串這前,它就會假定 { 不是特殊字符。
例如,grep -E '{1' 命令搜索包含 {1 兩個字符的串,而不會報出正則表達式語法錯誤。
POSIX.2 標準允許這種操作的擴展,但在可移植腳本文件里應該避免這樣使用。

關鍵字:Linux、grep、命令、服務器
分享到:

頂部 】 【 關閉
版權所有:佛山思海電腦網絡有限公司 ©1998-2024 All Rights Reserved.
聯系電話:(0757)22630313、22633833
中華人民共和國增值電信業務經營許可證: 粵B1.B2-20030321 備案號:粵B2-20030321-1
網站公安備案編號:44060602000007 交互式欄目專項備案編號:200303DD003  
察察 工商 網安 舉報有獎  警警  手機打開網站