Python Caesar Cipher项目,输出不正确

时间:2017-02-20 19:19:20

标签: python encryption cryptography caesar-cipher

我似乎无法获得这个程序我应该为项目输出正确的输出,即使我已经尝试让它多次工作。该项目是:

  

您的程序需要解码名为“encrypted.txt”的加密文本文件。编写它的人使用了“key.txt”中指定的密码。此密钥文件类似于以下内容:

A    B 
B    C 
C    D 
D    E 
E    F 
F    G 
G    H 
H    I 
I    J 
J    K 
K    L 
L    M 
M    N 
N    O 
O    P 
P    Q 
Q    R 
R    S 
S    T 
T    U 
U    V 
V    W 
W    X 
X    Y 
Y    Z 
Z    A 
     

左列表示明文字母,右列表示相应的密文。   您的程序应使用“key.txt”解码“encrypted.txt”文件,并将明文写入“decrypted.txt”。   您的程序应该处理加密的大写和小写字母,而不必有两个密钥文件(或复制密钥)。您可以使用全部大写的解密文本。   您应该能够处理加密文本中不在密钥文件中的字符。在这种情况下,只需让解密重复该字符。这将允许您在加密文本中有空格,在解密时保留空格。   虽然您可以编写程序来创建密钥文件 - 但不要在提交中包含该文件。您可以手动创建加密和密钥文本文件。使用Python Shell中的“新文件”选项(不要忘记保存为txt)或编辑器(如记事本)。不要用词。

这是我的代码:

keyFile = open("key.txt", "r")
keylist1= []
keylist2 = []

for line in keyFile:
  keylist1.append(line.split()[0])
  keylist2.append(line.split()[1])
keyFile.close()
encryptedfile = open("encrypted.txt", "r")
lines = encryptedfile.readlines()
currentline = ""
decrypt = ""
for line in lines: 
  currentline = line
  letter = list(currentline)
  for i in range(len(letter)):
    currentletter = letter[i]
    if not letter[i].isalpha():
      decrypt += letter[i]
    else:
      for o in range(len(keylist1)):
        if currentletter == keylist1[o]:
          decrypt += keylist2[o]
print(decrypt)

我得到的唯一输出是:

  

,?

这是不正确的。

1 个答案:

答案 0 :(得分:0)

你忘了处理小写字母。使用upper()将所有内容转换为常见情况。

使用字典而不是一对列表也会更好。

mapping = {}
with open("key.txt", "r") as keyFile:
    for line in keyFile:
        l1, l2 = line.split()
        mapping[upper(l1)] = upper(l2)
decrypt = ""
with open("encrypted.txt", "r") as encryptedFile:
    for line in encryptedFile:
        for char in line:
            char = upper(char)
            if char in mapping:
                decrypt += mapping[char]
            else:
                decrypt += char
print(decrypt)
相关问题