grep [-cnivrABC--color] 'word' filename

--color可以把匹配到的内容字体换成彩色。
-n :显示输出内容的行号
-c :打印出符合要求的行数
-v :打印不符合要求的行,取反。
-A:后面跟一个数字,如 -A 2表示打印出符合条件的要求行以及下面两行
-B:后跟一个数字,打印出搜索行以及上面两行。
-C:后面跟一个数字,打印出搜索行的上下各两行。
-r:会遍历一个目录,把指定目录下面所有文件全部匹配出来。
-hr:会去掉搜索内容前的文件名。


实例:

1.--color

[root@one ~]# grep --color 'root' 1.txt

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

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

2. -n

[root@one ~]# grep -n 'root' 1.txt
1:root:x:0:0:root:/root:/bin/bash
11:operator:x:11:0:operator:/root:/sbin/nologin

3:-c

[root@one ~]# grep -c 'root' 1.txt
2

4 :-v

[root@one ~]# grep -v 'root' 1.txt
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin

5:-An  (n是数字,这里是2)

[root@one ~]# grep -A2 'root' 1.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin

6:-Bn (n是数字,这里是2)

[root@one ~]# grep -B2 'root' 1.txt
root:x:0:0:root:/root:/bin/bash
--
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin

7:-Cn (n是数字,这里是2)

[root@one ~]# grep -C2 'root' 1.txt
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin

8:

过滤出带有某个关键词的行并输出行数
# grep -n 'root' 1.txt 


过滤出不带有某个关键词的行当输出行号
#grep -n -v 'root' 1.txt 


过滤出所有包含数字的行
grep ‘[0-9]’ 1.txt 


过滤出所有不包含数字的行
grep -v ‘[0-9]’ 1.txt 


去除所有以#开头的符号
grep -v ‘^#' 1.txt 


过滤出以英文字符开头的行
grep ‘^[a-zA-Z]’ 1.txt 


过滤出非数字开头的行
grep ‘^0-9’ 1.txt 


去除所有空行
grep -v '^$' 1.txt 


过滤任意一个或多个字符
grep ‘r.o’ 1.txt   小数点代替中间的任意一个字符。


grep ‘r*o’ 1.txt  *前面的字符可以是重复的多个,但*后的字符必须有一个。以下例子可以看出r后必须有o,在可以匹配。而o不需要前面有r就可以匹配。

[root@one ~]# grep --color 'r*o' 1.txt

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

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

daemrooooxon:x:2:2:userrrrrr:/sbin:/sbin/nologin


gerp ‘r.*o’ 1.txt 贪婪匹配。以r开头 o结尾的。

[root@one ~]# grep --color 'r.*o' 1.txt

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

daemrooooxon:x:2:2:daemon:/sbin:/sbin/nologin

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

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

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


9.

egrep 是grep工具的扩展。grep -E 等价与 egrep 。
匹配一个或者一个以上+前面的字符 # egrep ‘o+’ 1.txt 。
匹配零个或者1个?前面字符 # egrep ‘o?’ 1.txt 。
匹配 word1或者word2 
#egrep ‘word1|word2’ 1.txt 。

小数点”.“表示任意一个字符,包括特殊字符,空格,星号等。
”*“表示零个或者多个 *前面的字符 。
.*表示任意任意字符 。


前面的grep都可以使用,但是“?”和“+”只能egrep使用,grep要使用需要加上"- E",

"?"表示0个或多个“?”前面的字符
+表示1个或者多个+前面的字符 。