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个或者多个+前面的字符 。