Linux命令之文本搜索工具grep、egrep、fgrep

Linux命令之文本搜索工具grep、egrep、fgrep


     grep即global search regular expression_r(RE) and print out the line,是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。

     grep家族包括grep、egrep和fgrep:egrep是grep的扩展;fgrep查找一个或多个与给出的字符串或词组相匹配文件中的行,不支持规则表达式


     语法:grep [OPTIONS] PATTERN [FILE...]

     常用参数选项

         --color=auto:对匹配到的串做高亮显示

         -c:只输出匹配的行数

     -i:不区分大小写

         -o: 仅显示能够被模式匹配到的串本行

     -v:显示不匹配的所有行

     -E:允许使用扩展模式匹配

     

      元字符集模式匹配,常用基本元字符有以下:

          .:匹配一个字符

          *:匹配任意字符

         []:匹配一个指定范围内的字符

        [^]:匹配一个不在指定范围内的字符

    [[:upper:]]:[A-Z]

    [[:lower:]]:[a-z]

    [[:digit:]]:[0-9]

    [[:alnum:]]:[0-9a-zA-Z]

    [[:space:]]:空格或tab键

    [[:alpha:]]:[a-zA-Z]

        \(..\):标记匹配字符

            ^:锚定行首

            $:锚定行尾 

           \<:锚定词首

           \>:锚定词尾

       x\{m\}:重复字符x,m次

      x\{m,\}:重复字符x,至少m次

     x\{m,n\}:重复字符x,至少m次,不多于n次

         \(\):分组

       后向引用

       \1: 引用第一个左括号以及与之对应的右括号所包括的所有内容

       \2:

       \3:

     

     示例:显示/tmp/log/目录下abc.log文件中ab字符串后面的任意单个字符或任意字符的行

wKiom1XhR_WDzQwJAAKGmwR_YiU591.jpg

wKioL1XhShvwUyGNAAJwup7C0DY442.jpg

           显示/tmp/log/目录下abc.log文件中ab后出现字母x的行,并且不区分大小写

wKiom1XhSCPDFRgtAAJVFIuQnKU157.jpg

           显示/tmp/log/目录下abc.log文件中行首出现任意字母的行,并且不区分大小写

wKioL1XhSl3RFFCdAAHxnbRpB1Q925.jpg

           显示/etc/passwd文件中以bash结尾的行

wKiom1XhSFvR6b6lAAHW5W7iQwA469.jpg

           显示/etc/passwd文件中的两位数或三位数

     第一种方法

wKiom1XhSI7SbBjAAAbivcoVVm0543.jpg

     第二种方法:注意,图中红色边框

wKioL1XhS1-i6YSaAAac9NNuTF0856.jpg

          显示`netstat -tan`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行

wKioL1XhS4Ljf1boAAGQx9VL524077.jpg

          添加用户bash、testbash、basher以及nologin用户(nologin用户的shell为/sbin/nologin);而后找出/etc/passwd文件中用户名与其shell名相同的行

wKiom1XhSZHjGBXnAAPQr3lnY6s301.jpg

          显示当前系统上root、centos或者user1用户的默认shell和UID (请事先创建这些用户,若不存在)

wKiom1XhSbjjRvCCAAID4YT9xZA913.jpg

          找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行

wKioL1XhTC2gRqH0AAJVBh5vNE8684.jpg

     

      egrep命令执行效果与grep -E相似,使用的语法及参数可参照上面grep指令,与grep的不同点在于解读字符串的方法,以下元字符集合

     语法:egrep [OPTIONS] PATTERN [FILE...]

     常用参数选项

         --color=auto:对匹配到的串做高亮显示

         -c:只输出匹配的行数

     -i:不区分大小写

         -o: 仅显示能够被模式匹配到的串本行

     -v:显示不匹配的所有行

     -E:允许使用扩展模式匹配

     常用基本元字符有以下:

          .:匹配一个字符

          *:匹配任意字符

         []:匹配一个指定范围内的字符

        [^]:匹配一个不在指定范围内的字符

    [[:upper:]]:[A-Z]

    [[:lower:]]:[a-z]

    [[:digit:]]:[0-9]

    [[:alnum:]]:[0-9a-zA-Z]

    [[:space:]]:空格或tab键

    [[:alpha:]]:[a-zA-Z]

        \(..\):标记匹配字符

            ^:锚定行首

            $:锚定行尾 

           \<:锚定词首

           \>:锚定词尾

       x{m}:重复字符x,m次

      x{m,}:重复字符x,至少m次

     x{m,n}:重复字符x,至少m次,不多于n次

         ():分组

       后向引用

       \1: 引用第一个左括号以及与之对应的右括号所包括的所有内容

       \2:

       \3:     

   注意:某些字符略有不同

示例:与上面列出的示例进行对比

     显示/etc/passwd文件中的两位数或三位数

     第一种方法

wKioL1XhTPKzc3rfAAZvPX4zybY296.jpg

     第二种方法

wKiom1XhS0SS8OGkAAZDScv7kGI123.jpg

          显示`netstat -tan`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行

wKiom1XhS4OgLPACAAF0U3sHjaE750.jpg

          添加用户bash、testbash、basher以及nologin用户(nologin用户的shell为/sbin/nologin);而后找出/etc/passwd文件中用户名与其shell名相同的行

wKioL1XhTf3wyBFmAAGWCG_j_mY256.jpg

          显示当前系统上root、centos或者user1用户的默认shell和UID (请事先创建这些用户,若不存在)

wKiom1XhTAHg_Z1sAAEDZp_SVNo261.jpg

          找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行

wKioL1XhTjOR9DdfAAJSyJGvvTE739.jpg

          使用echo输出一个路径,而后egrep找出其路径基名;进一步的使用egrep取出其目录名

wKiom1XhThXBtLlkAAFT7sywND8149.jpg

          找出ifconfig命令执行结果中1-255之间的数字

wKioL1XhUGHBqod9AAM1VdPbBMI906.jpg


     fgrep命令:检索固定字符串,它不识别正则表达式,是快速搜索命令。

     语法:fgrep [选项]PATTERN [FILE]...

     常见的参数选项参照grep或egrep

     示例:搜索/tmp/log/abc.log 下包含xy字符的行,包含大小写

wKiom1XhTmOBHp2eAAHAl-HzBgU769.jpg


你可能感兴趣的:(grep,egrep,fgrep)