正则表达式实现与或非关系

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

注意:行起始符(^),终止符($)和非贪婪标志(?)在这里的使用非常重要。
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值