使用正则表达式怎么实现与或非关系

介绍

这篇文章给大家介绍使用正则表达式怎么实现与或非关系,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

1。6到256个字符
2。包括以下四类字符中的至少三类:数字/小写字母/大写字母/其他字符
3。其它无法用正则表达式校验的规则(例如最短密码修改时间)

我们就可以用以下正则表达式来校验密码的合法性(其中蓝色和绿色部分分别为PatternA和PatternB):

(?=^。{6255} $) ((?=. * \ 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])) ^ *

?写一个正则表达式,要求匹配字符串满足条件,但不可满足条件B

我们可以先写两个子表达式PatternA和PatternB,分别校验条件和一条件B,然后结合成一个新的表达式
(? ! PatternB) PatternA

例如,Windows Server的机器名一般要求满足以下要求(比微软官方要求有所简化):

1。2到15个字符。只能包括:数字/小写字母/大写字母/减号
2。不能全部为数字

我们就可以用以下正则表达式来校验机器名的合法性(其中蓝色部分分别为PatternB,绿色部分为PatternA):

^ (? ! ^ \ d * $) ([a-zA-Z0-9 -] {2, 15})

美元?写一个正则表达式,要求匹配字符串或者满足条件一个或者满足条件B

我们可以先写两个子表达式PatternA和PatternB,分别校验条件和一条件B,然后结合成一个新的表达式
(PatternA | PatternB)

例如在非必须填的电话号码域中,用户可以输入一个合法的电话号码,也可以留空

我们就可以用以下正则表达式来校验机器名的合法性(其中蓝色部分分别为PatternB,绿色部分为PatternA):

<代码> (^ $ | \ d{7日16})

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

关于使用正则表达式怎么实现与或非关系就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看的到。

使用正则表达式怎么实现与或非关系