查找字符串中三个 ASCII 家族的重复项

Finding a recurrance of three ASCII families in a string

我正在尝试为密码生成器创建一个 'check' 系统,该系统将建议是否在生成的密码中连续找到三个相同类型的字符系列,即

如果密码是

y8kpBD8zcZLKRSh1j7vwCMDQ5orR8VEP

它将找到 'ZLK' 等

我最初以为 lowercase_repeat = re.compile("[a-z]{3}") 会找到三个小写字母重复,但我似乎无法理解这是如何工作的。

密码生成器如下:

import random
import re
generator = random.SystemRandom()
password_characters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ123456789!@#$%^&*()'
password = ''.join(generator.choice(password_characters) for _ in range(32))
print password

如果您只是想检查特定的字符集;例如:全部大写、全部小写、数字和非字母 - 您可以为每个集合创建一个非捕获组。例如:

import re

pattern  = '(?:[a-z]{3}|[A-Z]{3}|\d{3}|[\x20-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]{3})'
password = 'y8kpBD8zcZLKRSh1j7vwCMDQ5orR8VEP!'
matches  =  re.search(pattern, password)

变量matchesreturnsNone如果没有匹配,说明密码通过

模式 [\x20-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E] 是一种(可能非常粗糙)捕获一组所有非 alnum ascii 字符(十六进制代码)的方法。它代表以下集合:

[space] ! " # $ % & ' ( ) * + , - . / : ; < = > ? @ [ \ ] ^ _ ` { | } ~

我把它从一个旧项目中拉出来了,所以 YMMV。我确信可能有更简洁的方式来表达它——事实上,您可能更愿意明确指定一个集合;例如:[!?#]

快速完整性检查:

import re

def check_password(password):
    pattern = '(?:[a-z]{3}|[A-Z]{3}|\d{3}|[\x20-\x2F\x3A-\x40\x5B-\x60\x7B-\x7E]{3})'
    return re.search(pattern, password)

passwords = ['a', 'abc', 'ABC', 'aBc', '1bc', '123']

for password in passwords:
    if check_password(password):
        print 'password failed: ', password
    else:
        print 'password passed: ', password

产量:

password passed:  a
password failed:  abc
password failed:  ABC
password passed:  aBc
password passed:  1bc
password failed:  123

希望这对您有所帮助:)