首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >寻找最大匹配数的正则表达式模式

寻找最大匹配数的正则表达式模式
EN

Stack Overflow用户
提问于 2019-04-16 03:35:24
回答 1查看 29关注 0票数 1

我正在寻找一种正则表达式模式,可以限制基于最大出现次数的匹配。

例如,匹配长度为6-12个字符的字母数字字符串length,包含最少2个,但不超过4个,大写字母,无论它们在字符串中的位置如何。

我尝试过这种模式,但只有在大写字母相邻的情况下才匹配。

代码语言:javascript
复制
^([A-Z]{2,4}).{8,12}$

有效的匹配项为:

代码语言:javascript
复制
HamBurger (2 uppercase, Length = 9)
LeTtUce (3 uppercase, Length = 7)
TACOss (4 uppercase, Length = 6)

但无效的匹配项为:

代码语言:javascript
复制
ABCDE1234 (too many uppercase letters)
aBcDeFgHiJ (too many uppercase letters)
ADBC (length too short)

提前感谢您的帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-16 03:37:53

您可以使用基于前视的解决方案,如

代码语言:javascript
复制
^(?=(?:[^A-Z]*[A-Z]){2,4}[^A-Z]*$).{6,12}$

或者,为了使其更流线化,将长度检查移动到开头(进入前视):

代码语言:javascript
复制
^(?=.{6,12}$)(?:[^A-Z]*[A-Z]){2,4}[^A-Z]*$

请参见regex demo (或this one)和Regulex graph

详细信息

  • ^ -字符串的开始-正向先行,要求重复两到四次大写字母以外的0+字符,然后是string
  • .{6,12} -6到12 chars
  • $ -字符串末尾的除大写字母以外的任何0+字符。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55696137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档