-3

我们将为 26 个可能的密钥中的每一个生成解密字母。

我完成了那部分,但我无法打印出字典中的单词。例如:我只想打印 'ebv' 嘿

我如何将它与字典中的单词匹配,而不是打印出所有 26 个可能的键。

这是字典: http: //www.ics.uci.edu/~kay/wordlist.txt

Alphabet = 'abcdefghijklmnopqrstuvwxyz'  

def rotated_alphabet(key:int) -> str:
    '''produces a rotated alphabet based on key and adds those letters to the end of alphabet'''
    if key > 26:
        key = key % 26
    new_alphabet = ''
    w = Alphabet[0:key]
    x = Alphabet.replace(Alphabet[0:key], new_alphabet)
    return (x + w)

def Caesar_break(cipher:str) ->str:
    infile = open('wordlist.txt', 'r')
    wordlist = []
    possible = []
    decode = []
    words = []
    for str in infile:
        t = str
    for i in range(0, 26):
        p = rotated_alphabet(i).split()
        possible+=p
    for y in possible:
        decrypt = str.maketrans(y, Alphabet)
        decode.append(cipher.translate(decrypt))
    for str in decode:
        s = str
        words.append(s)
    print(words)

Caesar_break('eby')

它打印出来:

['ebv', 'dau', 'czt', 'bys', 'axr', 'zwq', 'yvp', 'xuo', 'wtn', 'vsm', 'url', 'tqk', 'spj', 'roi', 'qnh', 'pmg', 'olf', 'nke', 'mjd', 'lic', 'khb', 'jga', 'ifz', 'hey', 'gdx', 'fcw']
4

1 回答 1

1

解决这个问题的规范方法是:

  1. 从单词列表中读取所有行并将它们插入字典dict
  2. 通过以下方式尝试各种凯撒旋转translate
  3. 如果旋转从字典 ( decrypt in dictionary) 中产生一个单词,则输出它

对于较长的文本,您可能需要检查是否在字典中找到了至少一半的单词。注意小写/大写问题和换行符等!- 尝试使用strip

更高级的方法是进行字符统计,并根据该统计信息猜测适当的旋转。

于 2012-11-21T17:29:23.047 回答