gpt4 book ai didi

python - 查找字符串中三个 ASCII 系列的重复出现

转载 作者:太空宇宙 更新时间:2023-11-03 17:29:03 25 4
gpt4 key购买 nike

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

如果密码是

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)

如果没有匹配,变量matches返回None,表明密码通过。

模式[\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

希望这有帮助:)

关于python - 查找字符串中三个 ASCII 系列的重复出现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32165881/

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