一,grep命令有什么用
个人觉得grep命令就是一个对文本或输出进行匹配并控制输出的一个工具,看一下下面的参数,部分翻译了,有不对的地方,还请指正;
1. grep --help
2. 匹配模式选择:
3. -E, --extended-regexp 扩展正则表达式egrep
4. -F, --fixed-strings 一个换行符分隔的字符串的集合fgrep
5. -G, --basic-regexp 基本正则
6. -P, --perl-regexp 调用的perl正则
7. -e, --regexp=PATTERN 后面根正则模式,默认无
8. -f, --file=FILE 从文件中获得匹配模式
9. case 不区分大小写
10. -w, --word-regexp 匹配整个单词
11. -x, --line-regexp 匹配整行
12. -z, --null-data a data line ends in 0 byte, not newline
13.
14. 杂项:
15. -s, --no-messages 不显示错误信息
16. -v, --invert-match 显示不匹配的行
17. -V, --version 显示版本号
18. --help 显示帮助信息
19. use memory-mapped input if possible
20.
21. 输入控制:
22. count=NUM 匹配的最大数
23. -b, --byte-offset 打印匹配行前面打印该行所在的块号码。
24. -n, --line-number 显示的加上匹配所在的行号
25. --line-buffered 刷新输出每一行
26. -H, --with-filename 当搜索多个文件时,显示匹配文件名前缀
27. -h, --no-filename 当搜索多个文件时,不显示匹配文件名前缀
28. as filename for standard input
29. -o, --only-matching show only the part of a line matching PATTERN
30. -q, --quiet, --silent 不显示任何东西
31. --binary-files=TYPE assume that binary files are TYPE
32. 'binary', 'text', or 'without-match'
33. -a, --text 匹配二进制的东西
34. -I 不匹配二进制的东西
35. -d, --directories=ACTION 目录操作,读取,递归,跳过
36. 'read', 'recurse', or 'skip'
37. -D, --devices=ACTION 设置对设备,FIFO,管道的操作,读取,跳过
38. 'read' or 'skip'
39. -R, -r, --recursive 递归调用
40. include=PATTERN files that match PATTERN will be examined
41. --exclude=PATTERN files that match PATTERN will be skipped.
42. --exclude-from=FILE files that match PATTERN in FILE will be skipped.
43. -L, --files-without-match 匹配多个文件时,显示不匹配的文件名
44. -l, --files-with-matches 匹配多个文件时,显示匹配的文件名
45. count 显示匹配了多少次
46. -Z, --null print 0 byte after FILE name
47.
48. 文件控制:
49. -B, --before-context=NUM 打印匹配本身以及前面的几个行由NUM控制
50. -A, --after-context=NUM 打印匹配本身以及随后的几个行由NUM控制
51. -C, --context=NUM 打印匹配本身以及随后,前面的几个行由NUM控制
52. -NUM 根-C的用法一样的
53. --color[=WHEN],
54. use markers to distinguish the matching string
55. ', `never' or `auto'.
56. do not strip CR characters at EOL (MSDOS)
57. as if CRs were not there (MSDOS)
二,准备测试文件test
1. root:x:0:0:root:/root:/bin/bash
2. bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa
3. DADddd:x:2:2:daemon:/sbin:/bin/false
4. mail:x:8:12:mail:/var/spool/mail:/bin/false
5. ftp:x:14:11:ftp:/home/ftp:/bin/false
6. &nobody:$:99:99:nobody:/:/bin/false
7. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
8. http:x:33:33::/srv/http:/bin/false
9. dbus:x:81:81:System message bus:/:/bin/false
10. hal:x:82:82:HAL daemon:/:/bin/false
11. mysql:x:89:89::/var/lib/mysql:/bin/false
12. aaa:x:1001:1001::/home/aaa:/bin/bash
13. ba:x:1002:1002::/home/zhangy:/bin/bash
14. test:x:1003:1003::/home/test:/bin/bash
15. @zhangying:*:1004:1004::/home/test:/bin/bash
16. policykit:x:102:1005:Po
这个测试文件,根介绍sed和awk命令时用的一样的,是个密码文件。
三,应用举例
1. [root@krlcgcms01 test]# grep root test
2. root:x:0:0:root:/root:/bin/bash
匹配含有root的行
1. [root@krlcgcms01 test]# cat test |grep '^\(root\|zhang\)'
2. root:x:0:0:root:/root:/bin/bash
3. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
匹配以root开头或者以zhang开头的行,注意反斜杠
1. [root@krlcgcms01 test]# cat test |grep -e '^\(root\|zhang\)'
2. root:x:0:0:root:/root:/bin/bash
3. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
匹配以root开头或者以zhang开头的行,注意反斜杠,根上面一个例子一样,-e默认是省去的
1. [root@krlcgcms01 test]# echo 'zhangying' |grep '^zhang[a-z]*$'
2. zhangying
匹配以zhang开头,只含有字母
1. [root@krlcgcms01 test]# cat test |grep -E '^bin'
2. bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa
匹配以bin开头的行,用的egrep,在这里可以换成-F,-G
1. [root@krlcgcms01 test]# cat test|grep -n zhangy
2. 7:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
3. 13:ba:x:1002:1002::/home/zhangy:/bin/bash
4. 15:@zhangying:*:1004:1004::/home/test:/bin/bash
在匹配的行前面加上该行在文件中,或者输出中所在的行号
1. [root@krlcgcms01 test]# cat test|grep -nv bin
2. 16:policykit:x:102:1005:Po
不匹配以bin开头的行,并显示行号
1. [root@krlcgcms01 test]# cat test|grep -c zhang
2. 3
显示匹配的个数,不显示内容
1. [root@krlcgcms01 test]# grep system test
2. [root@krlcgcms01 test]# grep -ni system test
3. 9:dbus:x:81:81:System message bus:/:/bin/false
匹配system,没有加-i没有匹配到东西。
1. [root@krlcgcms01 test]# cat test|grep -w zhan
2. [root@krlcgcms01 test]# cat test|grep -w zhangy
3. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
4. ba:x:1002:1002::/home/zhangy:/bin/bash
匹配zhan没有匹配到东西,匹配zhangy能匹配到,因为在test文件中,有zhangy这个单词
1. [root@krlcgcms01 test]# echo "aaaaaa" |grep -x aaa
2. [root@krlcgcms01 test]# echo "aaaa" |grep -x aaaa
3. aaaa
在这里-x后面东西,和输出中的整行相同时,才会输出
1. [root@krlcgcms01 test]# cat test |grep -m 1 zhang
2. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
最多只匹配一次,如果把-m 1去掉的话,会有三个
1. [apacheuser@krlcgcms01 test]$ cat test |grep -b zha
2. 241:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
3. 480:ba:x:1002:1002::/home/zhangy:/bin/bash
4. 558:@zhangying:*:1004:1004::/home/test:/bin/bash
匹配行的前面显示块号,这个块号是干什么的,不知道,有谁知道可否告诉我一下
1. [apacheuser@krlcgcms01 test]$ grep -H 'root' test test2 testbak
2. test:root:x:0:0:root:/root:/bin/bash
3. test2:root
4. testbak:root:x:0:0:root:/root:/bin/bash
多文件匹配时,在匹配的行前面加上文件名
1. [apacheuser@krlcgcms01 test]$ grep -h 'root' test test2 testbak
2. root:x:0:0:root:/root:/bin/bash
3. root
4. root:x:0:0:root:/root:/bin/bash
多文件匹配时,在匹配的行前面不加上文件名
1. [apacheuser@krlcgcms01 test]$ grep -l 'root' test test2 testbak DAta
2. test
3. test2
4. testbak
多文件匹配时,显示匹配文件的文件名
1. [apacheuser@krlcgcms01 test]$ grep -L 'root' test test2 testbak DAta
2. DAta
多文件匹配时,在匹配的行前面不加上文件名
1. [apacheuser@krlcgcms01 test]$ grep 'root' test
2. root:x:0:0:root:/root:/bin/bash
3. [apacheuser@krlcgcms01 test]$ grep -o 'root' test
4. root
5. root
6. root
没有-o时,有一行匹配,这一行里面有3个root,加上-o后,这个3个root就出来了
1. [apacheuser@krlcgcms01 test]$ grep -V
2. grep (GNU grep) 2.5.1
3.
4. Copyright 1988, 1992-1999, 2000, 2001 Free Software Foundation, Inc.
显示版本
1. [apacheuser@krlcgcms01 test]$ grep -q 'root' test
不显示任何内容
1. [root@krlcgcms01 test]# grep test -R /tmp/test/mytest
2. /tmp/test/mytest/test:test:x:1003:1003::/home/test:/bin/bash
3. /tmp/test/mytest/test:@zhangying:*:1004:1004::/home/test:/bin/bash
递归显示匹配的内容,在test目录下面建个mytest目录,copy test目录下面的test文件到mytest下面,能看到上面的结果
1. [root@krlcgcms01 test]# cat test |grep -A 3 root
2. root:x:0:0:root:/root:/bin/bash
3. bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa
4. daemon:x:2:2:daemon:/sbin:/bin/false
5. mail:x:8:12:mail:/var/spool/mail:/bin/false
显示匹配root后面的3行
1. [root@krlcgcms01 test]# cat test |grep -B 2 ftp
2. daemon:x:2:2:daemon:/sbin:/bin/false
3. mail:x:8:12:mail:/var/spool/mail:/bin/false
4. ftp:x:14:11:ftp:/home/ftp:/bin/false
显示匹配ftp前面的2行
1. [root@krlcgcms01 test]# cat test |grep -C 2 ftp
2. daemon:x:2:2:daemon:/sbin:/bin/false
3. mail:x:8:12:mail:/var/spool/mail:/bin/false
4. ftp:x:14:11:ftp:/home/ftp:/bin/false
5. &nobody:$:99:99:nobody:/:/bin/false
6. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
显示匹配ftp前面的2行,后面的2行,以及本身
1. [root@krlcgcms01 test]# cat test |grep -2 ftp
2. daemon:x:2:2:daemon:/sbin:/bin/false
3. mail:x:8:12:mail:/var/spool/mail:/bin/false
4. ftp:x:14:11:ftp:/home/ftp:/bin/false
5. &nobody:$:99:99:nobody:/:/bin/false
6. zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
显示匹配ftp前面的2行,后面的2行,以及本身,和-C用法一样