zoukankan      html  css  js  c++  java
  • linux shell 正则表达式详解

    正则
    1. 普通正则表达式
    2. 扩展正则表达式


    普通正则表达式

    正则表达式

    位置相关的正则
    ^: 表示锚定行首,此字符后面的任意内容必需出现在行首,可能匹配。
    $:表示锚定行尾,此字符前面的任意内容必须出现在行尾,才能匹配。
    ^$:表示匹配空行,这里所描述的空行表示"回车",而"空格"或"tab"等都不能算作此处所描述的空行。
    ^abc$:表示abc独占一行时,会被匹配到。
    <或者 :匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现。
    >或者 :匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
    B:匹配非单词边界,与正好相反。

    次数相关的正则
    * 表示前面的字符连续出现任意次,包括0次
    . 表示任意单个字符。
    .* 表示任意长度的任意字符,与通配符中的*的意思相同
    ? 表示匹配其前面的字符0或1次
    + 表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
    {n} 表示前面的字符连续出现n次,将要被匹配
    {x,y} 表示之前的字符至少连续出现x次,最多连续出现y次,都能被匹配到,换句话说,只要之前的字符连续出现的次数在x与y之间,即可被匹配到
    {,n} 表示之前的字符连续出现至多n次,最少0次,都会被匹配到
    {n,} 表示之前的字符连续出现至少n次,才会被匹配到


    常用字符匹配

    .  表示匹配任意单个字符
    * 表示匹配前面的字符任意次,包括0次

    [  ] 表示匹配指定范围内的任意单个字符
    [^  ] 表示匹配指定范围外的任意单个字符
     
    [[:alpha:]]  表示任意大小写字母
    [[:lower:]]  表示任意小写字母
    [[:upper:]]  表示任意大写字母
    [[:digit:]]  表示0到9之间的任意单个数字(包括0和9)
    [[:alnum:]]  表示任意数字或字母
    [[:space:]]  表示任意空白字符,包括"空格"、"tab键"等。
    [[:punct:]]  表示任意标点符号
     
    [0-9]与[[:digit:]]等效
    [a-z]与[[:lower:]]等效
    [A-Z]与[[:upper:]]等效
    [a-zA-Z]与[[:alpha:]]等效
    [a-zA-Z0-9]与[[:alnum:]]等效
     
    [^0-9]与[^[:digit:]]等效
    [^a-z]与[^[:lower:]]等效
    [^A-Z]与[^[:upper:]]等效
    [^a-zA-Z]与[^[:alpha:]]等效
    [^a-zA-Z0-9]与[^[:alnum:]]等效
     
    #简短格式并非所有正则表达式解析器都可以识别
    d 表示任意单个0到9的数字
    D 表示任意单个非数字字符
     表示匹配单个横向制表符(相当于一个tab键)
    s表示匹配单个空白字符,包括"空格","tab制表符"等
    S表示匹配单个非空白字符


    分组和嵌套
    ( ) 表示分组,我们可以将其中的内容当做一个整体,分组可以嵌套。
    (ab) 表示将ab当做一个整体去处理。
    1 表示引用整个表达式中第1个分组中的正则匹配到的结果。
    2 表示引用整个表达式中第2个分组中的正则匹配到的结果。


    转义符-反斜杠

    扩展正则表达式,在普通正则符号再进行扩展,其实更加简单

    常用符号

    .   表示任意单个字符。
    *  表示前面的字符连续出现任意次,包括0次。
    .* 表示任意长度的任意字符,与通配符中的*的意思相同。
      表示转义符,当与正则表达式中的符号结合时表示符号本身。
    | 表示"或者"之意
    [  ]表示匹配指定范围内的任意单个字符。
    [^  ]表示匹配指定范围外的任意单个字符。
     
    单个字符匹配相关
    [[:alpha:]]  表示任意大小写字母。
    [[:lower:]]  表示任意小写字母。
    [[:upper:]]  表示任意大写字母。
    [[:digit:]]  表示0到9之间的任意单个数字(包括0和9)。
    [[:alnum:]]  表示任意数字或字母。
    [[:space:]]  表示任意空白字符,包括"空格"、"tab键"等。
    [[:punct:]]  表示任意标点符号。
    [^[:alpha:]]  表示单个非字母字符。
    [^[:lower:]]  表示单个非小写字母字符。
    [^[:upper:]]  表示单个非大写字母字符。
    [^[:digit:]]  表示单个非数字字符。
    [^[:alnum:]]  表示单个非数字非字母字符。
    [^[:space:]]  表示单个非空白字符。
    [^[:punct:]]  表示单个非标点符号字符。
    [0-9]与[[:digit:]]等效。
    [a-z]与[[:lower:]]等效。
    [A-Z]与[[:upper:]]等效。
    [a-zA-Z]与[[:alpha:]]等效。
    [a-zA-Z0-9]与[[:alnum:]]等效。
    [^0-9]与[^[:digit:]]等效。
    [^a-z]与[^[:lower:]]等效。
    [^A-Z]与[^[:upper:]]等效
    [^a-zA-Z]与[^[:alpha:]]等效
    [^a-zA-Z0-9]与[^[:alnum:]]等效
     
    次数匹配相关
    ?  表示匹配其前面的字符0或1次
    +  表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
    {n} 表示前面的字符连续出现n次,将会被匹配到。
    {x,y} 表示之前的字符至少连续出现x次,最多连续出现y次,都能被匹配到,换句话说,只要之前的字符连续出现的次数在x与y之间,即可被匹配到。
    {,n} 表示之前的字符连续出现至多n次,最少0次,都会陪匹配到。
    {n,}表示之前的字符连续出现至少n次,才会被匹配到。
     
    位置边界匹配相关
    ^:表示锚定行首,此字符后面的任意内容必须出现在行首,才能匹配。
    $:表示锚定行尾,此字符前面的任意内容必须出现在行尾,才能匹配。
    ^$:表示匹配空行,这里所描述的空行表示"回车",而"空格"或"tab"等都不能算作此处所描述的空行。
    ^abc$:表示abc独占一行时,会被匹配到。
    <或者 :匹配单词边界,表示锚定词首,其后面的字符必须作为单词首部出现。
    >或者 :匹配单词边界,表示锚定词尾,其前面的字符必须作为单词尾部出现。
    B:匹配非单词边界,与正好相反。
     
    分组与后向引用
    ( ) 表示分组,我们可以将其中的内容当做一个整体,分组可以嵌套。
    (ab) 表示将ab当做一个整体去处理。
    1 表示引用整个表达式中第1个分组中的正则匹配到的结果。
    2 表示引用整个表达式中第2个分组中的正则匹配到的结果。

  • 相关阅读:
    storcli64 查看raid
    初学者路径规划 | 人生苦短我用Python
    Vue.js组件的重要选项
    三个Bootstrap免费字体和图标库
    前端实时消息提示的效果-websocket长轮询
    前端实时消息提示的效果-websocket长轮询
    带分页的标签
    带分页的标签
    VMware-workstation安装
    VMware-workstation安装
  • 原文地址:https://www.cnblogs.com/faberbeta/p/linux-shell008.html
Copyright © 2011-2022 走看看