我正在嘗試創建一個用於讀取消息,假消息和整數密鑰的輸入的培根式密碼加密程序,然後輸出通過凱撒密碼加密程序移位的假消息,但輸入的空格和符號代表粗體和正常字體的培根式密碼,或者我用作'A'和'B'的。如何獲取函數來遍歷字符串並替換字符串的第一個字符,第二個等?
這是我到目前爲止。它大部分已經完成,但我無法讓輸出遍歷使用凱撒密碼加密的字符串中的字符,而只是使用第一個字符。我非常積極的這是一個愚蠢的東西,但我似乎無法得到它的工作。有什麼建議麼? :
def main():
myBaconianMessage = input('Please input Bacon cipher message.')
myBaconianMessage = myBaconianMessage.split()
myCaesarMessage = input('Please input fake message to be encrypted.')
myCaesarKey = int(input('Please input integer key.'))
clues_A = {'A':'AAAAA'}
clues_B = {'B':'AAAAB'}
clues = {'a':'AAAAA', 'b':'AAAAB', 'c':'AAABA', 'd':'AAABB', 'e':'AABAA',
'f':'AABAB', 'g':'AABBA', 'h':'AABBB', 'i':'ABAAA', 'j':'ABAAA',
'k':'ABAAB', 'l':'ABABA', 'm':'ABABB', 'n':'ABBAA', 'o':'ABBAB',
'p':'ABBBA', 'q':'ABBBB', 'r':'BAAAA', 's':'BAAAB', 't':'BAABA',
'u':'BAABB', 'v':'BAABB', 'w':'BABAA', 'x':'BABAB', 'y':'BABBA',
'z':'BABBB', 'C':'AAABA', 'D':'AAABB', 'E':'AABAA', 'F':'AABAB',
'G':'AABBA', 'H':'AABBB', 'I':'ABAAA', 'J':'ABAAA', 'K':'ABAAB',
'L':'ABABA', 'M':'ABABB', 'N':'ABBAA', 'O':'ABBAB', 'P':'ABBBA',
'Q':'ABBBB', 'R':'BAAAA', 'S':'BAAAB', 'T':'BAABA', 'U':'BAABB',
'V':'BAABB', 'W':'BABAA', 'X':'BABAB', 'Y':'BABBA', 'Z':'BABBB'}
def decrypter():
translated = myBaconianMessage[:]
for i, word in enumerate(translated):
for key in clues_A:
translated[i] = translated[i].replace(key, clues_A.get(key))
for key in clues_B:
translated[i] = translated[i].replace(key, clues_B.get(key))
for key in clues:
translated[i] = translated[i].replace(key, clues.get(key))
encryptedMessage = ''.join(translated)
return encryptedMessage
def caesarPortion():
myCaesarMode = 'encrypt'
alphabet = 'abcdefghijklmnopqrstuvwxyz'
caesarMessage = ''
newCaesarMessage = myCaesarMessage.lower()
for symbol in newCaesarMessage:
if symbol in alphabet:
num = alphabet.find(symbol)
if myCaesarMode == 'encrypt':
num = num + myCaesarKey
elif myCaesarMode == 'decrypt':
num = num - myCaesarKey
if num >= len(alphabet):
num = num - len(alphabet)
elif num < 0:
num = num + len(alphabet)
caesarMessage = caesarMessage + alphabet[num]
else:
caesarMessage = caesarMessage + symbol
thisCaesarMessage = ''.join(caesarMessage)
return thisCaesarMessage
def doubleEncrypted():
caesar = caesarPortion()
listCaesar = list(caesar)
translate = decrypter()
listTranslate = translate.split()
for char in range(len(listCaesar) - 1):
i = 0
while i <= len(listCaesar):
i += 1
set = {'A':listCaesar[i], 'B':' '}
for symbol in listTranslate:
for x, word in enumerate(listTranslate):
for key in set:
listTranslate[x] = listTranslate[x].replace(key, ''.join(str(set.get(key))))
return listTranslate
if len(myBaconianMessage) >= 1:
print(''.join(doubleEncrypted()))
if __name__ == '__main__':
main()
我知道這是什麼東西在doubleEncrypted()這就是問題所在,可能是while循環或集或範圍,我知道代碼真的是不優雅可言,但我是一個的n00b和我只是想弄清楚事情是如何運作的。我真的非常感謝任何建議。
嗨,你的代碼片段縮進是否正確,所有的函數都在main裏面?或者如果是的話,爲什麼你這樣寫。 –
是的,它似乎是獲得main()繼續執行caesarPortion()的唯一方法... ...很確定有一個不同的,正確的方法來做到這一點,但我不知道它是什麼。 – Elliot