grep命令筆記和練習題


grep,egrep,fgrep

grep: 根據模式搜索文本,並將符合模式的文本行顯示出來。

pattern: 文本字符和正則表達式的元字符組合而成匹配條件


grep [options] PATTERN [FILE...]

-i

--color

-v 顯示沒有被模式匹配的行

-o 只顯示被模式匹配到的字符串


*: 任意長度的任意字符

?: 任意單個字符

[]: 

[^]:

正則表達式:Regular Expression, REGEXP

. 匹配單個任意字符

[] 匹配指定範圍內的任意單個字符

[^]匹配指定範圍外的任意單個字符

字符集和 :[:digit:],[:lower:],[:upper:],[:punct:];[:space:],[:alpha:],[:alnum:]   調用要使用兩個[[]]


匹配次數(貪婪模式):

* 匹配其前面的字符任意次數

a,b,ab,aab,acb,adb,amnb

a*b a?b

a.*b


.* 任意長度的任意字符

\? 匹配其前面的字符1次或0次

\{m,n\} 匹配其前面的字符至少m次,至多n次

eg: a\{1,3\}b, 表示ab之間可以有最多3個a,最少能有一個a

eg: a.\{1,3\}b, 表示ab之間可以用任意字符,最多3個,最少1個


位置錨定:

^ 錨定行首, 此字符後面的任意內容必須出現在行首

eg: grep ^'r..t' /etc/passwd

$ 錨定行尾, 次字符前面的任意內容必須出現在行尾

^$ 空白行

eg: grep '^$' /etc/inittab| wc -l, 查看此文件中的空白行並統計個數

\< 或者 \b 錨定詞首,其後面的任意字符必須作爲單詞首部出現 

\> 或者 \b 錨定詞尾,其前面的任意字符必須作爲單詞尾部出現

eg: "\<root\>" /etc/passwd , 意爲查找單詞爲root的

eg: "\broot\b" /etc/passwd ,  意義同上

分組:

\(\)

\(ab\) *

後向引用: 前面匹配到什麼,後面就引用什麼,以下面的方式引用後面的匹配

eg1:

[richie@localhost ~]$ grep '\(l..e\).*\1' test.txt

He love his lover

he like his liker.

eg2:

[richie@localhost ~]$ grep '\([0-9]\).*\1' /etc/inittab 

#   以特定數字開頭的,同時以這個數字結尾的行

l0:0:wait:/etc/rc.d/rc 0

l1:1:wait:/etc/rc.d/rc 1

l2:2:wait:/etc/rc.d/rc 2   #

l3:3:wait:/etc/rc.d/rc 3

l4:4:wait:/etc/rc.d/rc 4

l5:5:wait:/etc/rc.d/rc 5

l6:6:wait:/etc/rc.d/rc 6

\1: 第一個左括號以及與之對應的右括號所包括的所有內容 ,eg: grep '\(l..e\).*\1' test.txt

\2: 第二個左括號。。

\3: 第三個左括號。。。

練習:

1、顯示/proc/meminfo文件中以不區分大小的s開頭的行;

grep -i '^s' /proc/meminfo

grep -i '^[sS]' /proc/meminfo

2、顯示/etc/passwd中以nologin結尾的行; 

grep 'nologin$' /etc/passwd


取出默認shell爲/sbin/nologin的用戶列表

grep "nologin$" /etc/passwd |cut -d: -f1  注意cut用法,-d後面不需要加""


取出默認shell爲bash,且其用戶ID號最小的用戶的用戶名

grep 'bash$' /etc/passwd| sort -n -t ":" -k3 |head -1| cut -d: -f1


3、顯示/etc/inittab中以#開頭,且後面跟一個或多個空白字符,而後又跟了任意非空白字符的行;

grep '^#[[:space:]]*[^[:space:]]' /etc/inittab  我寫的錯誤答案

grep '^#[[:space:]]\{1,\}[^[:space:]]' /etc/inittab


4、顯示/etc/inittab中包含了:一個數字:(即兩個冒號中間一個數字)的行;

grep ':[[:digit:]]:' /etc/inittab 

grep '[0-9]' /etc/inittab


5、顯示/boot/grub/grub.conf文件中以一個或多個空白字符開頭的行;

grep '^[[:space:]*]' /boot/grub/grub.conf 我寫的錯誤答案

grep '^[[:space:]]\{1\}' /boot/grub/grub


6、顯示/etc/inittab文件中以一個數字開頭並以一個與開頭數字相同的數字結尾的行;

grep '\([[:digit:]].*\)\1$' /boot/grub/grub.conf   #我忘記了\1後面的$



練習:

1、找出某文件中的,1位數,或2位數;

grep '[[:digit:]]\{1,2\}' #忘記了<>的用法

grep '\<[0-9]\{1,2\}\>' /proc\cpuinfo

2、找出ifconfig命令結果中的1-255之間的整數;

思路: 拆分匹配 個位、十位、百位(100-199和249-255)分段:

   '\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>'

3、查找當前系統上名字爲student(必須出現在行首)的用戶的帳號的相關信息, 文件爲/etc/passwd

grep '^student\>' /etc/passwd | cut -d: -f3


練習:分析/etc/inittab文件中如下文本中前兩行的特徵(每一行中出現在數字必須相同),請寫出可以精確找到類似兩行的模式:

l1:1:wait:/etc/rc.d/rc 1

l3:3:wait:/etc/rc.d/rc 3


grep '^1\([0-9]\):\1.*\1$'


正則表達式:

Basic REGXP

Extended REGEXP

基本正則表達式:

. 任意單個字符

[] 指定範圍內的任意字符

[^]


次數匹配:

* 其前的字符任意次數

? 其前字符0或1次

\{m,n\} 至少m次,至多n次

.*  任意長度任意字符


錨定匹配:

^

$

\<, \b  錨定詞首

\>, \b 錨定詞尾


\(\) 分組,後向引用

\1,\2,\3, ... 

grep: 使用基本正則表達式 定義的模式來過濾文本的命令

-i 忽略大小寫

-v 顯示不匹配的內容

-o 

--color

-E 使用擴展正則表達式

-A n 顯示匹配行及其後面相鄰的n行 

-B n 顯示匹配行及其前面相鄰的n行

-C n 顯示匹配行及前後相鄰的n行




擴展正則表達式:


字符匹配:

.

[]

[^]


次數匹配:

*

?

+ 匹配其前字符至少一次 eg: grep -E '^[[:space:]]+' 至少一個空白字符開頭

{m,n} 至少m次,最多n次。不需要在加反斜線\


位置錨定:

^

$

\<

\>


分組:

() 分組  不用加反斜線\

\1, \2, \3, ...


或者:

| or

a|b  a或者b

eg: grep -E '(C|c)at'



簡易IP匹配:

'(\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>\.){3}\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>'



IPv4

5類: A B C D E

A: 1-127

B: 128-191

C: 192-223


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章