1. 程式人生 > 程式設計 >linux grep與正則表示式使用介紹

linux grep與正則表示式使用介紹

grep (縮寫來自Globally search a Regular Expression and Print)是一種強大的文字搜尋工具,它能使用特定模式匹配(包括正則表示式)搜尋文字,並預設輸出匹配行。Unix的grep家族包括grep、egrep和fgrep。Windows系統下類似命令FINDSTR。
grep egrep fgrep(不支援正則表示式)
grep需要標準輸入 因此常常位於管道右側

命令引數:

--color=auto: 對匹配到的文字著色顯示
-v: 顯示不被pattern匹配到的行
-i: 忽略字元大小寫
-n:顯示匹配的行號
-c: 統計匹配的行數
-o: 僅顯示匹配到的字串

-q: 靜默模式,不輸出任何資訊
-A #: after,後#行
-B #: before,前#行
-C #:context,前後各#行
-e:實現多個選項間的邏輯or關係
grep –e ‘cat ' -e ‘dog' file
-w:匹配整個單詞 數字加字母下劃線全都算單詞的一部分,其他的都是單詞的分隔符
-E:相當於egrep
-F:相當於fgrep,不支援正則表示式
-f: 跟一個檔案(寫有不同字元)進行內容檢索是邏輯or關係

練習題:

1、顯示三個使用者root、centos、arch的UID和預設shell (使用者需要自己建立)

grep與正則表示式

2、找出/etc/rc.d/init.d/functions檔案中行首為某單詞(包括下劃線)後面跟一 個小括號的行

grep與正則表示式

3、使用egrep取出/etc/rc.d/init.d/functions中其基名

grep與正則表示式

4、使用egrep取出上面路徑的目錄名

grep與正則表示式

5、統計last命令中以root登入的每個主機IP地址登入次數

grep與正則表示式

6、利用擴充套件正則表示式分別表示0-9、10-99、100-199、200-249、250-255

0-9: [0-9]
10-99: [1-9][0-9]
100-199: 1[0-9][0-9]
200-249: 2[0-5][0-9]
250-255: 25[0-5]

7、顯示ifconfig命令結果中所有IPv4地址

grep與正則表示式

8、將此字串:welcome to centos linux 中的每個字元排序,重複 次數多的排到前面

grep與正則表示式

正則表示式:

REGEXP:由一類特殊字元及文字字元所編寫的模式,其中有些字元(元字元) 不表示字元字面意義,而表示控制或通配的功能
程式支援:grep,sed,awk,vim,less,nginx,varnish等
分兩類:
基本正則表示式:BRE
擴充套件正則表示式:ERE
grep -E,egrep
正則表示式引擎:
採用不同演算法,檢查處理正則表示式的軟體模組
PCRE(Perl Compatible Regular Expressions)
元字元分類:字元匹配、匹配次數、位置錨定、分組
man 7 regex

字元匹配:
. 匹配任意單個字元 預設是貪婪匹配
[] 匹配指定範圍內的任意單個字元 .在裡面也是點不需要轉義
[^] 匹配指定範圍外的任意單個字元
[:alnum:] 字母和數字
[:alpha:] 代表任何英文大小寫字元,亦即 A-Z,a-z
[:lower:] 小寫字母
[:upper:] 大寫字母
[:blank:] 空白字元(空格和製表符)
[:space:] 水平和垂直的空白字元(比[:blank:]包含的範圍廣)
[:cntrl:] 不可列印的控制字元(退格、刪除、警鈴...)
[:digit:] 十進位制數字
[:xdigit:]十六進位制數字
[:graph:] 可列印的非空白字元
[:print:] 可列印字元
[:punct:] 標點符號

匹配次數:用在要指定次數的字元後面,用於指定前面的字元要出現的次數
* 匹配前面的字元任意次,包括0次
貪婪模式:儘可能的匹配符合條件的字元
.* 任意長度的任意字元
\? 匹配其前面的字元0或1次
\+ 匹配其前面的字元至少1次
\{n\} 匹配前面的字元n次
\{m,n\} 匹配前面的字元至少m次,至多n次
\{,n\} 匹配前面的字元至多n次
\{n,\} 匹配前面的字元至少n

位置錨定:定位出現的位置
^ 行首錨定,用於模式的最左側
$ 行尾錨定,用於模式的最右側
^PATTERN$ 用於模式匹配整行
^$ 空行
^[[:space:]]*$ 空白行
\< 或 \b 詞首錨定,用於單詞模式的左側
\> 或 \b 詞尾錨定;用於單詞模式的右側
\<PATTERN\> 匹配整個單詞

分組:\(\) 將一個或多個字元捆綁在一起,當作一個整體進行處理,如: \(root\)\+
分組括號中的模式匹配到的內容會被正則表示式引擎記錄於內部的變數中,
這些變數的命名方式為: \1,\2,\3,...
\1 表示從左側起第一個左括號以及與之匹配右括號之間的模式所匹配到的字元
示例: \(string1\+\(string2\)*\)
\1 :string1\+\(string2\)*
\2 :string2

後向引用:引用前面的分組括號中的模式所匹配字元,而非模式本身
或者:\|
示例:a\|b: a或b C\|cat: C或cat \(C\|c\)at:Cat或cat

擴充套件的正則表示式:
egrep = grep -E
egrep [OPTIONS] PATTERN [FILE...]
擴充套件正則表示式的元字元:

字元匹配:
. 任意單個字元
[] 指定範圍的字元
[^] 不在指定範圍的字元

次數匹配:
*:匹配前面字元任意次
?: 0或1次
+:1次或多次
{m}:匹配m次
{m,n}:至少m,至多n次

位置錨定:
^ :行首
$ :行尾
\<,\b :語首
\>,\b :語尾

分組:
() 後向引用:\1,...
或者:
a|b: a或b C|cat: C或cat (C|c)at:Cat或cat

練習題:

1、顯示/proc/meminfo檔案中以大小s開頭的行(要求:使用兩種方法)

grep與正則表示式

2、顯示/etc/passwd檔案中不以/bin/bash結尾的行

grep與正則表示式

3、顯示使用者rpc預設的shell程式

grep與正則表示式

4、找出/etc/passwd中的兩位或三位數 (只要數字的話可以加-o選項僅僅顯示數字)

grep與正則表示式

5、顯示CentOS7的/etc/grub2.cfg檔案中,至少以一個空白字元開頭的且後面有非 空白字元的行

grep與正則表示式

6、找出“netstat -tan”命令結果中以LISTEN後跟任意多個空白字元結尾的行

grep與正則表示式

7、顯示CentOS7上所有系統使用者的使用者名稱和UID

grep與正則表示式

8、新增使用者bash、testbash、basher、sh、nologin(其shell為/sbin/nologin),找 出/etc/passwd使用者名稱和shell同名的行

grep與正則表示式

9、利用df和grep,取出磁碟各分割槽利用率,並從大到小排序

grep與正則表示式

grep和正則表示式引數

一:grep引數

1,-n :顯示行號

linux grep與正則表示式使用介紹

2,-o :只顯示匹配的內容

linux grep與正則表示式使用介紹

3,-q :靜默模式,沒有任何輸出,得用$?來判斷執行成功沒有,即有沒有過濾到想要的內容

4,-l :如果匹配成功,則只將檔名打印出來,失敗則不列印,通常-rl一起用,grep -rl 'root' /etc

linux grep與正則表示式使用介紹,

5,-A :如果匹配成功,則將匹配行及其後n行一起打印出來

linux grep與正則表示式使用介紹

6,-B:如果匹配成功,則將匹配行及其前n行一起打印出來

linux grep與正則表示式使用介紹

7,-C:如果匹配成功,則將匹配行及其前後n行一起打印出來

linux grep與正則表示式使用介紹

8,-c:如果匹配成功,則將匹配到的行數打印出來

linux grep與正則表示式使用介紹

9,-E :等於egrep,擴充套件
10,-i :忽略大小寫

11,-v :取反,不匹配
12,-w:匹配單詞

二:正則介紹

首先建a.txt。在進行驗證

linux grep與正則表示式使用介紹

1,^ 行首

linux grep與正則表示式使用介紹

2,$行尾

linux grep與正則表示式使用介紹

3,.除了換行符以外的任意單個字元

linux grep與正則表示式使用介紹

4,*前導字元的零個或多個

linux grep與正則表示式使用介紹

5, .*所有字

6, []字元組內的任一字元

linux grep與正則表示式使用介紹

7,[^]對字元組內的每個字元取反(不匹配字元組內的每個字元)

linux grep與正則表示式使用介紹

8, ^[^]非字元組內的字元開頭的行

linux grep與正則表示式使用介紹

9,[a-z] 小寫字母

linux grep與正則表示式使用介紹

10,[A-Z] 大寫字母

linux grep與正則表示式使用介紹

11,[a-Z] 小寫和大寫字母

linux grep與正則表示式使用介紹

12,[0-9] 數字

linux grep與正則表示式使用介紹

13,\<單詞頭 單詞一般以空格或特殊字元做分隔,連續的字串被當做單詞
\>單詞尾

linux grep與正則表示式使用介紹

linux grep與正則表示式使用介紹

以上就是linux grep與正則表示式使用介紹的詳細內容,更多關於grep和正則表示式引數的資料請關注我們其它相關文章!