三分钟搞懂正则之反向引用和零宽断言
反向引用
上一期讲到了反向引用,那什么是反向引用,我们先来看一个demo
其中1, 2的语法就叫做反向引用,他们分别表示捕获到的第一个,第二个内容,最多可以使用到9,表示捕获到的第9个内容。
注意引用的,是捕获到的内容,而不是捕获规则。所以(\w)(\w)\1\2
表示的就是一个xyxy
的结构,因此匹配到了"cdcd"
。
下面举几个小栗子:
- 判断字符串中有没有连续重复字符
- 缩写16进制颜色值
零宽断言
断言又有很多中叫法,比如环视,巡视。断言一共又分4种:
- x(?=y) 匹配‘x’仅仅当‘x’后面跟着‘y’.这种叫做先行肯定断言。
- (?<=y)x 匹配‘x’仅仅当‘x’前面是‘y’.这种叫做后行肯定断言。
- x(?!y) 仅仅当‘x’后面不跟着‘y’时匹配‘x’,这被称为正向否定断言。
- (?<!y)x 仅仅当‘x’前面不是‘y’时匹配‘x’,这被称为反向否定断言。
不同语言叫法不同,先行后行,正向反向都是一个意思。
零宽可以理解位它表示的是一个位置,而不是内容。
正则中表示位置的元字符有\b ^ $
等等,它们也都是零宽的。
上面的两个demo,如果不用零宽断言,则会将整个字符串给替换掉。
下面也举几个零宽断言的例子:
- 密码规则:大写,小写,数字,特殊字符必须有一个,长度8到12位
这段正则可以看到,先行断言前面的匹配项是^
,几个断言分别表示,从头开始,不管中间经历了啥,始终有一个小写英文字母/大写英文字母/数字,特殊字符。
后面的[^\s]{8,12}
表示长度8到12的非空字符。要注意的是,这里的断言,匹配的不是后面的8到12位字符,而是满足断言条件的开头^
,
- 金额千分位分隔符
正则只能从前往后匹配,这里表示如果一个数字后面跟着的数字,每三个一组,到小数点刚好分完,则需要加入分隔符。
以上就是正则的反向引用和零宽断言了,是不是很简单?
相关推荐
杨德龙 2020-11-11
不要皱眉 2020-10-14
满地星辰 2020-09-16
梦的天空 2020-08-25
lrjnlp 2020-07-19
qidu 2020-07-05
flyingssky 2020-07-05
flyingssky 2020-06-27
RuoShangM 2020-06-17
天高任鸟飞 2020-06-13
Darklovy 2020-06-11
qidu 2020-06-08
Darklovy 2020-06-07
jyj00 2020-06-06
flyingssky 2020-06-04
山水沐光 2020-05-26
山水沐光 2020-05-25