zoukankan      html  css  js  c++  java
  • Linux 中的 grep 命令

    一,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.  -i, --ignore-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.  --mmap                use memory-mapped input if possible  
    20.   
    21. 输入控制:  
    22.  -m, --max-count=NUM       匹配的最大数  
    23.  -b, --byte-offset         打印匹配行前面打印该行所在的块号码。  
    24.  -n, --line-number         显示的加上匹配所在的行号  
    25.  --line-buffered           刷新输出每一行  
    26.  -H, --with-filename       当搜索多个文件时,显示匹配文件名前缀  
    27.  -h, --no-filename         当搜索多个文件时,不显示匹配文件名前缀  
    28.  --label=LABEL            print LABEL 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.  TYPE is 'binary''text'or 'without-match'  
    33.  -a, --text                匹配二进制的东西  
    34.  -I                        不匹配二进制的东西  
    35.  -d, --directories=ACTION  目录操作,读取,递归,跳过  
    36.  ACTION is 'read''recurse'or 'skip'  
    37.  -D, --devices=ACTION      设置对设备,FIFO,管道的操作,读取,跳过  
    38.  ACTION is '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.  -c, --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.  --colour[=WHEN]       use markers to distinguish the matching string  
    55.  WHEN may be `always', `never' or `auto'.  
    56.  -U, --binary              do not strip CR characters at EOL (MSDOS)  
    57.  -u, --unix-byte-offsets   report offsets 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用法一样

      更多详情,参考:http://blog.csdn.net/gaoyingju/article/details/7737651

  • 相关阅读:
    显示等待WebDriverWait+EC
    mac 上查看python3的各种安装路径
    layui弹窗全屏显示
    Mysql 一些细节方面解析(一)--MyISAM和InnoDB的主要区别和应用场景
    命令关闭tomcat
    xml 写sql语句文件头
    mysql update 修改多个字段and的语法问题
    zookeeper安装
    Java 基础--移位运算符
    SQL mybatis动态查询小结
  • 原文地址:https://www.cnblogs.com/jan5/p/3360180.html
Copyright © 2011-2022 走看看