欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

正则表达式实现与或非关系【推荐】

程序员文章站 2022-06-15 17:13:39
写一个正则表达式,要求匹配字符串同时满足条件a和条件b 我们可以先写两个子表达式patterna和patternb,分别校验条件a和条件b。然后结合成一个新的表达式 (...

写一个正则表达式,要求匹配字符串同时满足条件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})

注意:行起始符(^),行终止符($)和非贪婪标志(?)在这里的使用非常重要。