zoukankan      html  css  js  c++  java
  • Linux命令:grep命令 | egrep命令

    grep:文本搜素工具,根据用户指定的文本模式对目标文件进行逐行搜索,显示能被模式所匹配到的行

    包含三个命令:grep、egrep(相当于grep -E 扩展的正则表达式)和fgrep(相当于grep -F 只能字符串匹配)

    格式:

      grep [options] PATTEN filename

    options

    grep -v (--invert-match):反向匹配,显示不能被表达式匹配的行

    grep -o (--only-matching):仅显示被模式匹配到的字串,而非整行,将匹配到的字符串一行一个显示

    grep -n :打印行号

    grep -q:静默模式,不输出任何信息,用于写脚本时的判断,和&>/dev/null一样

    grep -c :计算找到匹配项的行数,1行算1次。只显示行数,不显示匹配到的行内容

    grep -i :不区分字符大小写

    grep -B 数字:before显示匹配行,和其上面n行

    grep -A 数字:after显示匹配行,和其下面n行

    grep -C 数字:显示匹配行,和上下n行

    grep -e :实现多个选项间的逻辑or关系,例如grep -e 'cat' -e 'dog' filename

    grep -w :匹配整个词,用空格、特殊符号隔开的都算一个词

    grep -f 后面跟文件,文件中写正则表达式,各个表达式相当于或关系

    grep -f f1 f2   #两个文件取交集

    grep -E 使用egrep

    grep -F 使用fgrep

    PATTEN正则表达式:是一类字符所书写出的模式(pattern)

        元字符:不表示字符本身的意义,用于额外功能性的描述

            基本正则表达式(grep)的元字符:

            字符匹配:

                .:元字符,代表任意一个字符,包括空格

                .:表示.本身,""斜杆是逃逸符后面可接, ! ` [ .

                [ ]:指定范围内的任意单个字符

                [^]:指定范围外的任意单个字符

                [A-Z],[[:upper:]]所有大写字母

                [a-z],[[:lower:]]所有小写字母,和通配符匹配文件名有区别

                [[:alpha:]]所有字母,大小写

                [0-9],[[:digit:]]所有数字

                [[:alnum:]]所有数字+字母

                [[:blank:]]空白字符(空格和制表符)

                [[:space:]]水平和垂直的空白字符(比[:blank:]包含的范围广)

                [^[:space:]]非空白字符

                [[:graph:]]可打印的非空白字符

                [[:print:]]可打印字符

                [[:punct:]]标点符号

                [[:cntrl:]]不可打印的控制字符(退格、删除、警铃)

           

            次数匹配:用来指定匹配其前面的字符的次数

                *:任意次

                    例如:x*y,xxy,xy,y,指的是x可以出现0,1或者多次

                        .*:匹配任意长度的任意字符

                ?:0次或1次

                    例如:x?y,xy,y,xxy

                    贪婪模式:尽可能的长的去匹配字符

                +:至少1次

                {m}:匹配m次,此处的两个\是转义字符

                {m,n}:匹配至少M次,至多n次

                {m,}:匹配至少M次

                {0,n}:匹配至多n次

                  例如:x{2,6}y匹配xxy,xxxy,xxxxy,xxxxxy,xxxxxxy

            位置锚定:用于指定字符出现的位置

                ^:锚定行首

                $:锚定行尾

                    例如:^[[:space:]]+$  空白组成的行

                <char:锚定词首,char  数字、字母、下划线连起来的都算单词,其他符号都算分隔符

                char>:锚定词尾,char

                 例如: <h..o>,以h开头,o结尾中间跟任意两个字符的单词

            分组:

                ()

                    (ab)*xy    xy,abxy,ababxy

            引用:

                1:后向引用,引用前面的第一个左括号以及与之对应的右括号中的模式的结果字符串

                2

                    (a.b)xy1  a6bxya6b

            或者:

                |  a|bcd     a或者bcd,整个字符串或者

    举例:

    1、显示/proc/meminfo文件中以大小写s开头的行
    # grep "^[Ss]" /proc/meminfo
    # grep -i "^s" /proc/meminfo
    
    2、取出默认shell为非bash的用户
    # grep -v "bash$" /etc/passwd | cut -d: -f 1
    
    3、取出默认shell为bash的且ID号最大的用户
    # grep "bash$" /etc/passwd | sort -t: -k3 -rn|head -1|cut -d: -f1
    
    4、显示/etc/rc.d/rc.sysinit文件中,以#开头,后面至少一个空白字符,而后至少一个非空白字符的行
    # grep "^#[[:space:]]{1,}[^[:space:]]{1,}" /etc/rc.d/rc.sysinit
    
    5、显示/boot/grub/grub.conf中至少一个非空白字符开头的行
    # grep "^[^[:space:]]{1,}" /boot/grub/grub.conf
    
    6、找出/etc/passwd文件中一位数或两位数
    # grep "<[0-9]{1,2}>" /etc/passwd
    
    7、查看当前系统上root用户的所有信息
    # grep "^root>" /etc/passwd
    
    8、添加用户bash和testbash、basher,而后找出当前系统上其用户名和默认shell相同的用户
    # grep "^([[:alnum:]]{1,})>.*1$" /etc/passwd
    
    9、匹配所有非空白行
    #grep "." a.txt  
    
    10、取目录名
    # grep -Eo ".*<"  
    # grep -Eo ".*[^/]" | grep -Eo ".*/"
    
    11、取基名 
    # grep -Eo "[^/]+/?$"
    
    12、匹配空行
    # grep ^$ file
    
    13、匹配非空行   
    # grep -v ^$  filegrep .+ file   
    
    14、匹配0.0.0.0~255.255.255.255  
    grep --color=auto -o "(<([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])>.){3}<([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])>"
    
    15、匹配实际IP地址1.0.0.0-223.255.255.255
    grep --color=auto -o "<([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-1][0-9]|22[0-3])>(.<([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])>){3}"

    egrep:使用扩展正则表达式来创建模式,相当于 grep -E

        元字符:

            字符匹配:

                .:任意单个字符

                [ ]:指定范围内的任意单个字符

                [^ ]:指定范围外的任意单个字符

            次数匹配:

                *:匹配其前面的字符任意次

                ?:匹配前面的字符0或1次

                +:匹配前面的字符至少1次

                {m}:匹配前面的字符m次   区别于普通正则表达式

                {m,n}:至少m,至多n次

                {m,}:至少m次

                {0,n}:至多n次

            锚定

                ^:行首

                $:行尾

                <,  :词首

                >,  :词尾

            分组:

                ():分组

  • 相关阅读:
    GeoServer 2.2 正式版发布,GIS 服务器
    Spring Shell 1.0.0.RC1 发布
    微软发布支持Windows Desktop和F#的Visual Studio Express版本
    XINS 3.0 正式版发布,远程 API 调用规范
    YUI 3.7.2 补丁版发布
    HTML5 Boilerplate 4:改进了Apache配置和图片替换技术,并采用MIT许可证
    解决Windows Phone平台上不能枚举工程自带资源的问题
    截短 UTF8 字符串
    Spring Data Neo4j 2.1.0 RC4 发布
    GTK+ 3.5.18 发布,GUI 开发工具包
  • 原文地址:https://www.cnblogs.com/ysuwangqiang/p/11443785.html
Copyright © 2011-2022 走看看