晴明的博客园 GitHub      CodePen      CodeWars     

[regex] 正则 零宽断言

捕获

(?:exp) 匹配exp,不捕获匹配的文本,也不给此分组分配组号。

  • 零宽断言不占用位置,也就是说,匹配结果里是不会返回它的。

零宽度正预测先行断言

(?=exp):断言自身出现的位置的后面能匹配表达式exp。

  • 匹配后面为_path,结果为product
/(product)(?=_path)/.test('product_path') //true
  • 会匹配除字符除末尾所有的位置
(?=[^$]) 
  • 会匹配连续的三个数字,并且这三个数字不能在字符串的末尾
/(\d{3})(?=[^$])/
  • 至少出现一次 p r o
/^(?=.*p)(?=.*r)(?=.*o)\w+$/.test('product_path')

零宽度负预测先行断言

(?!exp):断言此位置的后面不能匹配表达式exp。

  • 匹配后面不是_path
/(product)(?!_path)/.test('product_path')  //false
  • 匹配后面不是_url
/(product)(?!_url)/.test('product_path')  //true
  • 一个例子

这里匹配的是,[后面不能为a或b

    let t = /\[(?!a)(?!b)[a-z]3\]/;
    console.info(t.test('[3a]'))//false
    console.info(t.test('[a3]'))//false
    console.info(t.test('[b3]'))//false
    console.info(t.test('[c3]'))//true
    console.info(t.test('[33]'))//false

零宽度正回顾后发断言(ES2018开始才支持)

(?<=exp):断言自身出现的位置的前面能匹配表达式exp

`'Benjamin Franklin is on the $100 €90 bill'.match(/(?<=\$)\d+/g) `
//["100"]
  • 匹配前面为name: 结果为wangfei
/(?<=name:)(wangfei)/

零宽度负回顾后发断言(ES2018开始才支持)

(?<!exp):断言此位置的前面不能匹配表达式exp

`'it’s is worth about €90 $100'.match(/(?<!\$)\d+/g)`
//["90", "00"]
  • 匹配前面不是name:
/(?<!name:)(angelica)/
  • 匹配前面不是nick_name:
/(?<!nick_name:)(angelica)/
posted @ 2017-03-07 11:44  晴明桑  阅读(220)  评论(0编辑  收藏  举报