我正在寻找一种正则表达式模式,可以限制基于最大出现次数的匹配。
例如,匹配长度为6-12个字符的字母数字字符串length,包含最少2个,但不超过4个,大写字母,无论它们在字符串中的位置如何。
我尝试过这种模式,但只有在大写字母相邻的情况下才匹配。
^([A-Z]{2,4}).{8,12}$
有效的匹配项为:
HamBurger (2 uppercase, Length = 9)
LeTtUce (3 uppercase, Length = 7)
TACOss (4 uppercase, Length = 6)
但无效的匹配项为:
ABCDE1234 (too many uppercase letters)
aBcDeFgHiJ (too many uppercase letters)
ADBC (length too short)
提前感谢您的帮助。
发布于 2019-04-16 03:37:53
您可以使用基于前视的解决方案,如
^(?=(?:[^A-Z]*[A-Z]){2,4}[^A-Z]*$).{6,12}$
或者,为了使其更流线化,将长度检查移动到开头(进入前视):
^(?=.{6,12}$)(?:[^A-Z]*[A-Z]){2,4}[^A-Z]*$
请参见regex demo (或this one)和Regulex graph
详细信息
^
-字符串的开始-正向先行,要求重复两到四次大写字母以外的0+字符,然后是string.{6,12}
-6到12 chars$
-字符串末尾的除大写字母以外的任何0+字符。https://stackoverflow.com/questions/55696137
复制相似问题