在使用正则表达式时,有时我们需要捕获的内容前后必须是特定内容,但又不捕获这些特定内容的时候,零宽断言就起到作用了。

(?=exp):零宽度正预测先行断言,它断言自身出现的位置的后面能匹配表达式exp。


#匹配后面为_path,结果为product

'product_path'.scan      /(product)(?=_path)/

(?<=exp):零宽度正回顾后发断言,它断言自身出现的位置的前面能匹配表达式exp


#匹配前面为name:,结果为wangfei

'name:wangfei'.scan      /(?<=name:)(wangfei)/ #wangfei

 

(?!exp):零宽度负预测先行断言,断言此位置的后面不能匹配表达式exp。

#匹配后面不是_path

'product_path'.scan     /(product)(?!_path)/ #nil

#匹配后面不是_url

'product_path'.scan      /(product)(?!_url)/ #product

 

(?<!exp):零宽度负回顾后发断言来断言此位置的前面不能匹配表达式exp

#匹配前面不是name:

'name:angelica'.scan     /(?<!name:)(angelica)/ #nil

#匹配前面不是nick_name:

'name:angelica'.scan     /(?<!nick_name:)(angelica)/#angelica