【发布时间】:2023-03-11 19:30:02
【问题描述】:
我的 Vigenere 密码非常适合加密,但我只需要解决这个问题以进行解密,在运行程序后,我被告知字符串索引超出范围。有人可以让我知道我需要将其更改为什么,如果可以的话,我将不胜感激。
编辑:我已经更改了导致字符串索引问题的代码部分,但现在,在处理解密时,输出是一个空白行,其下方为“无”且没有错误。
编辑:ord(_key_text[letters%len(_key_text)]) 我需要在解密的等式这一边用 _key_phrase 替换 _key_text。
#encryption
def encrypt():
crypt = ''
key_phrase = raw_input("Please enter a key phrase to encrypt by: ")
key_phrase = key_phrase.upper()
key_text = raw_input("Please enter a piece of text to encrypt: ")
key_text = key_text.upper()
if len(key_text) == 0:
print("Key must be of length 1 or more."); exit()
if not key_text.isalpha() or not key_phrase.isalpha():
print("Both text and key must be composed of letters only."); exit()
for letters in range(0, len(key_text)):
new = ord(key_text[letters]) + ord(key_text[letters%len(key_text)]) - 65
if new > 90:
new -= 26
crypt += chr(new)
print crypt
#decryption
def decrypt():
decrypt = ''
_key_phrase = raw_input("Please enter a key phrase to encrypt by: ")
_key_phrase = _key_phrase.upper()
_key_text = raw_input("Please enter a piece of text to encrypt: ")
_key_text = _key_text.upper()
if len(_key_text) == 0:
print("Key must be of length 1 or more."); exit()
if not _key_text.isalpha() or not _key_phrase.isalpha():
print("Both text and key must be composed of letters only."); exit()
for letters in range(0, len(_key_text)):
new = ord(_key_text[letters]) - ord(_key_text[letters%len(_key_text)]) + 65
if new < 65:
new += 26
decrypt == chr(new)
print decrypt
#asking the user to enter a or b for en/decryption and whether they wish to continue
choice = raw_input("Please enter either 'a' for encryption or 'b' for decryption: ")
if choice == 'a':
print encrypt()
else:
print decrypt()
【问题讨论】:
-
发布回溯会有帮助
-
顺便说一句,
range()中的起始值不需要显式设置为 0。0 是默认值,在这种情况下您可以省略它。 -
进一步考虑: 1. 在
print encrypt()和print decrypt()中不能有print。 2. 您要求在decrypt函数中输入加密密钥和文本。 3. 你的函数只加密和解密没有空格的文本。 4. 加密文本比原始文本短。我认为 Vigenere 密码不正确。
标签: python python-2.7 encryption vigenere