zoukankan      html  css  js  c++  java
  • js正则:零宽断言

    JavaScript正则表达式零宽断言

    var str="abnsdfZL1234nvcncZL123456kjlvjkl"
    var reg=/ZL(d{4}|d{6})(?!d)/ig
    alert(str.match(reg))

    说白了,就是(?!d)代表后面不接数字 

    <script>
    var str="aaa1986-192aaaaaa55555-aaaaaa1986aaaa51515aaa"
    var reg=/(d{4,6})(?!d*-)/ig;
    alert(str.match(reg))
    </script>

    下面这个:通过零宽断言(?!-)来匹配所有后面不接“-”的4到6位数字。
    发现一个问题,这样他不会剔除55555而是匹配出了5555,
    后面这个进行修改后返回为:4444,666666,51515。而不把55555也返回。

    字 符

    说 明

    (pattern)

    匹配 pattern 并捕获该匹配的子表达式。可以使用 $0...$9 属性从结果“匹配”集合中检索捕获的匹配。若要匹配括号字符 ( ),请使用“(”或者“)”

    (?:pattern)  //~~~非捕获匹配 通常捕捉小括号(如: /a(bc)/ ) 捕捉的值会保存到 RegExp.$1,RexExp.$2...中,非捕获小括号的匹配不会被保存

    匹 配 pattern 但不捕获该匹配的子表达式,即它是一个非捕获匹配,不存储供以后使用的匹配。这对于用“或”字符 (|) 组合模式部件的情况很有用。例如,与“industry|industries”相比,“industr(?:y| ies)”是一个更加经济的表达式

    (?=pattern) //~~正向肯定零宽断言 

    执 行正向预测先行搜索的子表达式,该表达式匹配处于匹配 pattern 的字符串的起始点的字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,“Windows (?=95| 98| NT| 2000)”与“Windows 2000”中的“Windows”匹配,但不与“Windows 3.1”中的“Windows”匹配。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后

    (?!pattern) //~~~正向否定零宽断言 名字真不好记 自己发明了这样一个好理解一点的名词

    执 行反向预测先行搜索的子表达式,该表达式匹配不处于匹配 pattern 的字符串的起始点的搜索字符串。它是一个非捕获匹配,即不能捕获供以后使用的匹配。例如,“Windows (?!95| 98| NT| 2000)”与“Windows 3.1”中的“Windows”匹配,但不与“Windows 2000”中的“Windows”匹配。预测先行不占用字符,即发生匹配后,下一匹配的搜索紧随上一匹配之后,而不是在组成预测先行的字符后

     ---------------------------------------------------------

    ~~这个总结得比较好!

     零宽断言的意思是(匹配宽度为零,满足一定的条件/断言) 我也不知道这个词语是那个王八蛋发明的,简直是太拗口了。 


    零宽断言用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言),因此它们也被称为零宽断言。 

    断言用来声明一个应该为真的事实。正则表达式中只有当断言为真时才会继续进行匹配。 

    其中零宽断言又分四种 

    先行断言   也叫零宽度正预测先行断言(?=表达式)          表示匹配表达式前面的位置 

    例如 [a-z]*(?=ing) 可以匹配cooking singing 中的cook与sing 

    注意:先行断言的执行步骤是这样的先从要匹配的字符串中的最右端找到第一个ing(也就是先行断言中的表达式)然后 再匹配其前面的表达式,若无法匹配则继续查找第二个ing 再匹配第二个 ing前面的字符串,若能匹配 则匹配

    例如:.*(?=ing) 可以匹配cooking singing 中的cooking sing 而不是 cook 

    后发断言        也叫零宽度正回顾后发断言        (?<=表达式)   表示匹配表达式后面的位置 

    例如(?<=abc).* 可以匹配abcdefg中的defg        

    注意:后发断言跟先行断言恰恰相反 它的执行步骤是这样的:先从要匹配的字符串中的最左端找到第一个abc(也就是先行断言中的表达式)然后 再匹配其后面的表达式,若无法匹配则继续查找第二个abc 再匹配第二个abc后面的字符串,若能匹配 则匹配 

    例如(?<=abc).* 可以匹配abcdefgabc中的defgabc 而不是abcdefg 

    负向零宽断言 

    负向零宽断言 (?!表达式) 也是匹配一个零宽度的位置,不过这个位置的“断言”取表达式的反值,例如 (?!表达式) 表示 表达式 前面的位置,如果 表达式 不成立 ,匹配这个位置;如果 表达式 成立,则不匹配:同样,负向零宽断言也有“先行”和“后发”两种,负向零宽后发断言为 (?<!表达式) 

    负向零宽后发断言(?<!表达式) 

    负向零宽先行断言 (?!表达式) 

    负向零宽断言要注意的跟正向的一样

  • 相关阅读:
    053-146
    053-659
    053-658
    053-657
    053-656
    053-654
    053-655
    053-652
    053-651
    053-650
  • 原文地址:https://www.cnblogs.com/stephenykk/p/3457438.html
Copyright © 2011-2022 走看看