正则表达式之前瞻后顾(look around)
2017-07-14 本文已影响0人
jackPan
文中所说的前后是有方向的,未免产生歧义,在此声明下
如A => B
我们说B在A的前面,A在B的后面
- A(?=B)
前瞻(Look ahead positive): 匹配的是A,限制条件是A前面是B。
想要匹配abc并且abc的前面是123的表达式,应该这样:
![](https://img.haomeiwen.com/i6174751/ed5f01319f168392.png)
- A(?!B)
负前瞻(Look ahead negative): 顾名思义,该正则匹配A,限制条件是A前面不是B
想要匹配abc并且abc的前面不是123的表达式,应该这样:
![](https://img.haomeiwen.com/i6174751/c1185cb59a3d9e41.png)
- (?<=B)A
后顾(Look behind positive ): 匹配表达式A,限制条件A的后面是B
想要匹配abc并且abc的后面是123的表达式, 尴尬的是js不支持后顾,只支持前瞻,所以用js匹配会这样:
![](https://img.haomeiwen.com/i6174751/ef9ed12e8c9454d2.png)
所以我换了sublime
编辑器,因为sublime
是用python
写的,所以会得到这样的结果:
![](https://img.haomeiwen.com/i6174751/5af5f241d83b1af5.png)
- (?<!B)A
负后顾(Look behind negative ): 匹配表达式A,限制条件是A的后面不是B
想要匹配abc并且abc的后面不是123的表达式,应该这样:
![](https://img.haomeiwen.com/i6174751/799a258746e4a23c.png)
当然,在js中也是不支持负后顾的,不过似乎有提案让js支持后顾,相信过几年js就可以支持后顾了。