python - BruteForce while 循环中的计数器; yield 内存不足?

标签 python

我开始学习使用 python 进行基本编程,当我遇到排列时,我想看看我是否可以(为了好玩)暴力破解用户输入..

它似乎适用于空头 PW,但我的计数器似乎有缺陷,或者我是否遗漏了一些关于排列性质的信息? ...计数器每次显示相同的数字,对于相同长度的任何 PW...

此外,较长的 PW 存在内存错误,但我想我通过使用生成器( yield )而不是列表来排除了这一点。或者我不是吗?

感谢您的帮助

import string
from itertools import permutations

characters = string.ascii_letters
user_pw = input('Set your PW')
attempts = 0
done = False

while True:
    def Generator():
        guess_storage = [''.join(p) for p in permutations(characters, len(user_pw))]
        for current in guess_storage:
            yield current


    for guess in Generator():
        attempts += 1
        if guess == user_pw:
            print('SUCESS: ')
            print('Password: ', guess)
        done = True

    if done == True:
        break

print('Attempts: ', attempts)

最佳答案

我将从内存错误开始。通过这样做:

guess_storage = [''.join(p) for p in permutations(characters, len(user_pw))]

在迭代该列表之前,您将所有生成的排列“粘合”回单个列表。这是你内存不足的地方。相反,尝试使生成器被迭代:

guess_storage = (''.join(p) for p in permutations(characters, len(user_pw)))

或者不使用生成器,只加入每个排列,因为它产生(见下文)。

接下来,您将在一个 while 循环(包括生成器)中执行所有这些操作,但这是不必要且效率低下的。只需构建一次生成器,然后当您循环遍历生成器的每个猜测时,只要找到匹配项就退出。

我认为您想要的一种(更短的)写法是:

def Generator():
    for current in permutations(characters, len(user_pw)):
        yield ''.join(current)

for guess in Generator():
    print("Guessing", guess)  # To show the guesses in action
    attempts += 1
    if guess == user_pw:
        print('SUCCESS: ')
        print('Password: ', guess)
        print('Attempts: ', attempts)
        break

您还可以使用以下方法避免手动跟踪尝试计数器:

for attempts, guess in enumerate(Generator()):

关于python - BruteForce while 循环中的计数器; yield 内存不足?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48262991/

相关文章:

python - “int”对象不可迭代 : When I try to insert data in Cassandra using Python

python - 计算嵌套列表中的字符串

Python 动态函数名称

python - 如何在 SQLAlchemy 中创建分区 Oracle 表?

python - 在组合多行的Python数据框中查找最大值

python - 如何获取第一个span标签?

python - matplotlib add_subplot 奇数个地 block

python - 对深度嵌套的元组进行排序

适合创建游戏的 Python Web 框架

python - 类型错误 :unsupported operand type[s] for -: 'list' and 'int'