为了账号安全,请及时绑定邮箱和手机立即绑定

用于在字符串中查找 1 到 3 个字符的正则表达式

用于在字符串中查找 1 到 3 个字符的正则表达式

翻过高山走不出你 2021-06-08 21:57:24
我正在尝试编写一个应该返回 true 的正则表达式,如果 [A-Za-z] 发生在 1 和 3 之间,但我无法做到这一点public static void main(String[] args) {    String regex = "(?:([A-Za-z]*){3}).*";    String regex1 = "(?=((([A-Za-z]){1}){1,3})).*";    Pattern pattern = Pattern.compile(regex);    System.out.println(pattern.matcher("AD1CDD").find());}注意:对于连续的 3 个字符,我可以编写它,但是我想要实现的是,对于整个字符串,出现次数应该在 1 到 3 之间。如果有 4 个字符,则应返回 false。我已经使用前瞻来实现这一目标
查看完整描述

3 回答

?
Smart猫小萌

TA贡献1911条经验 获得超7个赞

请停止使用正则表达式,您不仅会使您自己的生活变得复杂,还会使将来必须处理您的代码的人们的生活变得复杂。选择更简单的方法,找到所有[A-Za-z]+字符串,将它们放入列表中,然后检查每个字符串,如果长度在 1 和 3 之内或超过该值。


查看完整回答
反对 回复 2021-06-17
?
元芳怎么了

TA贡献1798条经验 获得超7个赞

正则表达式

/([A-Za-z])(?=(?:.*\1){3})/s

寻找一个字符并重复 3 次。因此,如果匹配,则存在 4 个或更多相等的字符。


查看完整回答
反对 回复 2021-06-17
  • 3 回答
  • 0 关注
  • 309 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信