美文网首页
正则匹配1

正则匹配1

作者: 栗子daisy | 来源:发表于2021-02-17 17:52 被阅读0次

    正则: 一种字符串匹配的模式
    元字符:[][^]?*+{min,max} ^ $ () \1\2 |
    普通字符: 包括没有显式指定为元字符的所有可打印和不可打印字符。这包括所有大写和小写字母、所有数字、所有标点符号和一些其他符号。

    字符组[]

    /a/.test('a')
    /[abc]/.test('a') 分组[]
    /[a-z]/.test('a') 分组范围-
    /[^a-z]/.test('a') 范围取反^

    简写 {m,n}等效形式 描述
    \d [0-9] 代表一个数字
    \D [^0-9] 代表非数字
    \s 代表换行符、Tab制表符等空白字符。
    \S 代表非空白字符。
    \w [0-9A-Za-z_] 匹配字母或数字或下划线或汉字,即能组成单词的字符。
    \W [^\w] 或 [^0-9A-Za-z_] 非\w

    量词{}

    /\d{6}/.test('565532') true
    /\d{6}/.exec('565532') 0:565532
    范围浮动(不要加空格) {min,max} {min,}
    /\d{2,6}/.exec('565532')

    简写 {m,n}等效形式 描述 贪婪模式 非贪婪模式?
    + {1,} 出现次数大于等于1 /a+/.exec('aaaaaaaa') //aaaaaaaa /a+?/.exec('aaaaaaaa') //a
    * {0,} 出现次数大于等于0 /a*/.exec('aaaaaaaa') //aaaaaaaa /a*?/.exec('aaaaaaaa') //""
    {0,1} 出现次数为0或者1 /a?/.exec('aaaaaaaa') //a /.exec('aaaaaaaa') //""

    贪婪模式:能多就多
    非贪婪模式:能少就少 ,在量词+ ? * {1,} {0,} {0,1} 后面加 ?

    分组 ()

    1.分组,也叫子表达式

    1. 引用, 可以捕获子表达式
      /(ab){2}/.exec('abab')

    /(\d{4}-\d{1,2}-\d{1,2}/.exec('2021-2-17')
    /(\d{4})-(\d{1,2})-(\d{1,2})/.exec('2021-2-17')[1]
    RegExp.$1

    正则mdn

    1. 反向引用 先括起来 ,再用\1
      /([a-z])\1/.exec('bb') 匹配相同两个字符
      /<([^<>]+)>[\w\W]?</\1>/.exec('<h1><h1>123</h1></h1>')
      /<([^<>]+)>[\w\W]
      </\1>/.exec('<h1><h1>123</h1></h1>') 匹配标签 <h1>
    2. 非捕获 ?: 不补获子表达式
    /(abc){2}/.exec('abcabc'); RegExp.$1   //abc
    /(?:abc){2}/.exec('abcabc');  RegExp.$1   //""
    

    分支 |

    选择或者关系; 单独整体,自左向右,一旦匹配上不回头

    /12|23|56/.exec('1') //null
    /12|23|56/.exec('12') //12
    eg. ip 192.168.1.1
    //0-255
    个 \d[0-9]
    十 [1-9]\d 10-99
    百 1\d\d 100-199
    2[0-4]\d 200-249
    25[0-5] 250-255
    \d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5] // 250->2 一旦匹配上不回
    25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d[0-9] //反过来就可以
    /25[0-5]|2[0-4]\d|1\d\d|[1-9]\d|\d[0-9]/.exec('255')

    月1-12 [1-9]|1[0-2]
    日1-31 [1-9]|2\d|3[01]
    时 0-24 \d|1\d|2[0-4]
    分 0-60 \d|[1-5]\d|60
    秒 0-60 \d|[1-5]\d|60

    断言

    文本是否在文字边界 \b \B
    /\ban\b/.test('an apple') //true
    /\ban\b/.test('anapple') //false
    /^an/.test('anapple') //以an开头
    /le$/.test('anapple') //以le结尾

    环视

    紧跟b的a
    /a(?=b)/.exec('ab') //a
    /a(?!b)/.exec('ab') //null
    /a(?!b)/.exec('ac') //a

    匹配模式

    全局匹配 g 忽略大小写 i 多行匹配 m
    /a/g.exec('anaple')
    'anaple'.replace(/a/,'b') //bnaple
    'anaple'.replace(/a/g,'b') //bnbple

    /a/i.exec('Ab') //A
    /a/m.exec('c\nab') //a
    /world$/m.test('hello world\n')

    优先级

    运算符 描述
    \ 转义符
    (), (?:), (?=), [] 圆括号和方括号
    *, +, ?, {n}, {n,}, {n,m} 限定符
    ^, $, \ 任何元字符、任何字符 定位点和序列(即:位置和顺序)
    替换,"或"操作字符具有高于替换运算符的优先级,使得"m|food"匹配"m"或"food"。若要匹配"mood"或"food",请使用括号创建子表达式,从而产生"(m|f)ood"。

    相关文章

      网友评论

          本文标题:正则匹配1

          本文链接:https://www.haomeiwen.com/subject/hcgixltx.html