gpt4 book ai didi

用于数字,字母出现次数的Python正则表达式

转载 作者:太空宇宙 更新时间:2023-11-03 23:52:43 26 4
gpt4 key购买 nike

我正在尝试编写一个正则表达式来验证 token 。

我的 token 具有以下结构:

  • 3 个或更多 [0-9] digits
  • 5 个或更多 [a-z] small alpha
  • 2 个或更多 [#@] 特殊字符
  • 5 个或更多 [A-Z] upper alpha(可选 ?)可能存在或不存在。

注意:可选的 [A-Z] 字符可能存在于某些标记中,也可能不存在,当它存在于标记中时,它应该在 5 或更多 之间。

  • token 长度从最小 6 到最大 30

few examples of valid/invalid matches:

token1 : t4xa@ui13p#o6
breakdown : there are 7 [a-z] , 2 special chracter[@#] , 4 digits [0-9]
VALID MATCH: True

token2: 3@piy13Qx9#13@z1337
breakdown: there are 5 [a-z] , 3 special character [@#] , 10 digits [0-9] and 1 [A-Z](which is optional)
VALID MATCH: False (because `[A-Z]` exist in token but it exist for `1` time, it should exist atleast of 5 or more.)

token3: 3@piy1ABC3Qx9#13@DEGFz1337
breakdown: there are 5[a-z], 7 [A-Z] , 10 digits [0-9]
VALID MATCH: True
  • 到目前为止,我设法编写了一个正则表达式来验证至少一位数字、一个大写字母、至少一个小写字母、至少一个特殊字符。
^(?=.*[\d])(?=.*[A-Z])(?=.*[a-z])(?=.*[@#])[\w\d@#]{6,30}$

最佳答案

如果还有 0 个或 5 个以上的大写字符,那么您可以使用正向先行断言没有大写字符或至少 5 次。

(?=(?:[^A-Z\s]*$|(?:[^A-Z\s]*[A-Z]){5})

您可以使用取反的字符类和量词来检查最少出现次数。

^(?=(?:[^\d\s]*\d){3})(?=(?:[^a-z\s]*[a-z]){5})(?=(?:[^@#\s]*[@#]){2})(?=(?:[^A-Z\s]*$|(?:[^A-Z\s]*[A-Z]){5}))[\w\d@#]{6,30}$

Regex demo

关于用于数字,字母出现次数的Python正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58779831/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com