正则表达式实现与或非关系【推荐】
2019/6/29 21:01:04
本文主要是介绍正则表达式实现与或非关系【推荐】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
写一个正则表达式,要求匹配字符串同时满足条件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})
注意:行起始符(^),行终止符($)和非贪婪标志(?)在这里的使用非常重要。
这篇关于正则表达式实现与或非关系【推荐】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-11正则表达式学习:入门指南与实践技巧
- 2024-08-15正则表达式入门:基础教程与实践指南
- 2024-01-0939. 干货系列从零用Rust编写负载均衡及代理,正则及格式替换
- 2024-01-08如何编写高效的正则表达式?
- 2023-12-29"Matlab中的正则表达式:强大而灵活的工具"
- 2023-09-30这个正则 为啥同样的单号第二个就提取不出来?
- 2023-06-086.2 re 正则表达式
- 2023-06-06将字符串里的\x01,\x02这些替换掉用正则表达式无效?
- 2023-05-24正则表达式详解
- 2023-05-17我让gpt写了一段正则表达式代码,可是运行报错,可以帮忙看看哪里出了问题?