正则表达式实现与或⾮关系【推荐】
写⼀个正则表达式,要求匹配字符串同时满⾜条件A和条件B
我们可以先写两个⼦表达式PatternA和PatternB,分别校验条件A和条件B。然后结合成⼀个新的表达式
(?=PatternA)PatternB
例如,当在Windows Server上修改⽤户密码时,⼀般要求满⾜以下要求:
1. 6到256个字符
正则匹配空字符串2. 包括以下四类字符中的⾄少三类:数字/⼩写字母/⼤写字母/其他字符
3. 其它⽆法⽤正则表达式校验的规则(例如最短密码修改时间)
我们就可以⽤以下正则表达式来校验密码的合法性(其中蓝⾊和绿⾊部分分别为PatternA和PatternB):
(?=^.{6,255}$)((?=.*\d)(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[^A-Za-z0-9])(?=.*[a-z])|(?=.*[^A-Za-z0-9])(?=.*[A-Z])(?=.*[a-z])|(?=.*\d)(?=.*[A-Z])(?=.*[^A-Za-z0-9]))^.*•写⼀个正则表达式,要求匹配字符串满⾜条件A,但不可满⾜条件B
我们可以先写两个⼦表达式PatternA和PatternB,分别校验条件A和条件B。然后结合成⼀个新的表达式
(?!PatternB)PatternA
例如,Windows Server的机器名⼀般要求满⾜以下要求(⽐微软官⽅要求有所简化):
1. 2到15个字符。只能包括:数字/⼩写字母/⼤写字母/减号
2. 不能全部为数字
我们就可以⽤以下正则表达式来校验机器名的合法性(其中蓝⾊部分分别为PatternB,绿⾊部分为PatternA):
^(?!^\d*$)([a-zA-Z0-9-]{2,15})$
•写⼀个正则表达式,要求匹配字符串或者满⾜条件A或者满⾜条件B
我们可以先写两个⼦表达式PatternA和PatternB,分别校验条件A和条件B。然后结合成⼀个新的表达式
(PatternA|PatternB)
例如在⾮必须填的电话号码域中,⽤户可以输⼊⼀个合法的电话号码,也可以留空
我们就可以⽤以下正则表达式来校验机器名的合法性(其中蓝⾊部分分别为PatternB,绿⾊部分为PatternA):
(^$|\d{7,16})
注意:⾏起始符(^),⾏终⽌符($)和⾮贪婪标志(?)在这⾥的使⽤⾮常重要。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论