天天看點

linux筆記(26)grep

正則是一串有規律的字元串

grep/egrep egrep是grep的拓展

sed

awk

學好三個指令,對編寫shell腳本有很多大幫助

grep 過濾指定關鍵詞

grep +參數 'word' filename 

-c 顯示關鍵詞有多少行

[root@localhost grep]# grep -c 'nologin' passwd 

19

-n 顯示關鍵詞所在的行号

[root@localhost grep]# grep -n 'nologin' passwd 

2:bin:x:1:1:bin:/bin:/sbin/nologin

3:daemon:x:2:2:daemon:/sbin:/sbin/nologin

4:adm:x:3:4:adm:/var/adm:/sbin/nologin

5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

10:operator:x:11:0:operator:/root:/sbin/nologin

11:games:x:12:100:games:/usr/games:/sbin/nologin

12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

13:nobody:x:99:99:Nobody:/:/sbin/nologin

14:systemd-bus-proxy:x:999:997:systemd Bus Proxy:/:/sbin/nologin

15:systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin

16:dbus:x:81:81:System message bus:/:/sbin/nologin

17:polkitd:x:998:996:User for polkitd:/:/sbin/nologin

18:tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin

19:postfix:x:89:89::/var/spool/postfix:/sbin/nologin

20:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin

21:chrony:x:997:995::/var/lib/chrony:/sbin/nologin

24:user1:x:1111:1000::/home/user222:/sbin/nologin

25:user3:x:1010:1000::/home/user111:/sbin/nologin

-i 不區分大小寫的過濾關鍵詞

-v 過濾出來沒有關鍵詞的行号

-r 周遊所有子目錄

operator:x:11:0:operator:/root:/sbin/nologin

games:x:12:100:games:/usr/games:/sbin/nologin

ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

halt:x:7:0:halt:/sbin:/sbin/halt

mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nolog

grep/egrep 示列

grep '[0-9]' passwd 把0-9的數字過濾出來

grep -v '[0-9]' passwd 沒有0-9的行過濾出來

grep -v '^#' /etc/inittab 把不是以#開頭的行列出來

[root@localhost grep]# grep -vn '^#' inittab 

7:dadasdasd

13:dadasda

^放到[]外面 表示以***開頭,放[^]裡面,表示非[]裡的字元

grep 'r.o' passwd .表示任意的一個字元 

grep 'ro' passwd 左邊的字元重複0-n次,0次就是沒有,則可以比對到一個o

.* 可以比對到任意的字元

grep 'o{2}' passwd 

[root@localhost grep]# grep 'o{2}' passwd 過濾2個o的字元,4個o是由2個o組成的,是以也可以匹到

root:x:0:0:root:/root:/bin/bash

lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

postfix:x:89:89::/var/spool/postfix:/sbin/nologin

lty:x:1000:1000::/hoooome/lty:/bin/bash

如果不想輸入脫義符\,也可以用

egrep 'o{2}' passwd

[root@localhost grep]# egrep 'o+o' passwd +号表示左側的字元重複1次或多次,和*的差別是沒有0次,是以一個o比對不到

[root@localhost grep]# egrep 'o?1o' passwd ?表示左側字元重複0次或1次

bin:x:1o:1:bin:/bin:/sbin/nologin

mail:x:8:o1o2:mail:/var/spool/mail:/sbin/nologin

|

[root@localhost grep]# egrep 'root|user' passwd |表示或者的意思

tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin

user1:x:1111:1000::/home/user222:/sbin/nologin

user3:x:1010:1000::/home/user111:/sbin/nologin

本文轉自 小新銳 51CTO部落格,原文連結:http://blog.51cto.com/13407306/2044083,如需轉載請自行聯系原作者

繼續閱讀