14、自学——Linux的学习进度与任务【正则表达式】

正则表达式

文本处理工具之grep、egrep和fgrep

1、基本正则表达式

      grep:(global search regular expression(RE)and print out the line)
      文本搜索工具,根据用户指定的文本模式对目标文件进行逐行搜索,并显示匹配的行

        # grep [options] 'PATTERF(模式)' file,默认只支持基本正则表达式,要匹配额外功能的字符用-E
            --color=auto 指定颜色
            -v:反向匹配,显示不能被模式匹配到的行
            -o:仅匹配被模式匹配到的字串,而非整行
            -i:不区分大小写,ignore-case
            -E:支持扩展
            -A #:还显示模式下面的一行
            -B #:还显示模式上面的一行
            -C #:前后各显示一行


    正则表达式:是一类字符所书写出的模式(pattern)
    元字符:类似通配符,不表示字符本身的意义,用于额外功能性的描述

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


        字符匹配:
            .:任意单个字符
            []:指定范围内的任意单个字符
                [0-9],[[:digit:]]
                [a-z],[[:lower:]]
                [A-Z],[[:upper:]]
                所有的字母:[[:alpha:]]
                字母+数字:[[:alnum:]]
                空格:[[:space:]]
                标点符号:[[:putct:]]
            [^]: 指定范围外的任意单个字符



        次数匹配:用来指定匹配其前面的字符的次数
            *:任意次
              例子:x*y xxy xy y 都能匹配
              .*:匹配任意长度的任意字符
            \?:前面字符出现0次或者1次的
            \{m\}:匹配前面的字符m次
            \{m,n\}:至少m次,至多n次
            \{m,\}:至少m次
            \{0,n}:至多n次
            做变量换算需要使用”“


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

 

        位置锚定:用于指定字符出现的位置
            ^:锚定行首
              ^Char
            $:锚定行尾
              grepchar$
            ^$:空白行



        单词的位置锚定:

            \<char :锚定词首,\bchar
            char\> : 锚定词尾,char\b



        分组:
            \(\)
              \(ab\)*xy



        引用:
            \1:后向引用,引用前面的第一个左括号以及与之对应的右括号中的模式匹配到的内容,意思是说前面出现一次,在\1这也要出现一次
            \2
            ...
                \(a.b)xy\1: a6bxya6b

 

2、扩展正则表达式

    egrep:使用扩展正则表达式来构建模式,相当于 grep -E
      元字符:
        字符匹配:
            .:任意单个字符
             []:指定范围内的任意单个字符
            [^]:指定范围外的任意单个字符

           次数匹配:
            *:匹配器前面的字符任意次
            ?:匹配器前面的字符0或1次
            +:匹配其前面字符至少一次
           {m}:匹配其前面字符m次
           {m,n}:至少m次,至多n次
           {m,}:至少m次
           {0,n}:至多n次


         位置锚定:用于指定字符出现的位置
          ^:锚定行首
            ^Char
          $:锚定行尾
            grepchar$
          ^$:空白行


        单词的位置锚定:
          \<char :锚定词首,\bchar
          char\> : 锚定词尾,char\b


       分组:
          ():分组
           |:或者,ac|bc ac或者bc

 

 

   fgrep:不解析正则表达式

 

posted @   樱桃挚爱丸子  阅读(163)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
阅读排行:
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· .NET Core GC压缩(compact_phase)底层原理浅谈
· Winform-耗时操作导致界面渲染滞后
· Phi小模型开发教程:C#使用本地模型Phi视觉模型分析图像,实现图片分类、搜索等功能
· 语音处理 开源项目 EchoSharp
点击右上角即可分享
微信分享提示