-
-
Notifications
You must be signed in to change notification settings - Fork 46.8k
Porta cipher #1550
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Porta cipher #1550
Changes from 1 commit
b55cb5f
5de2ec0
fec2940
e5e5fba
9ff2f60
691b7e0
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,107 +1,100 @@ | ||
alphabet = { | ||
"A": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]], "B": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]], | ||
"C": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y"]], "D": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y"]], | ||
"E": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X"]], "F": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X"]], | ||
"G": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W"]], "H": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W"]], | ||
"I": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V"]], "J": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U", "V"]], | ||
"K": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U"]], "L": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T", "U"]], | ||
"M": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T"]], "N": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S", "T"]], | ||
"O": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S"]], "P": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R", "S"]], | ||
"Q": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R"]], "R": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q", "R"]], | ||
"S": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q"]], "T": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P", "Q"]], | ||
"U": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P"]], "V": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O", "P"]], | ||
"W": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O"]], "X": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N", "O"]], | ||
"Y": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], | ||
["O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N"]], "Z": [["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M"], ["O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "N"]]} | ||
|
||
|
||
def generateTable(key): | ||
"A": ("ABCDEFGHIJKLM", "NOPQRSTUVWXYZ"), | ||
"B": ("ABCDEFGHIJKLM", "NOPQRSTUVWXYZ"), | ||
"C": ("ABCDEFGHIJKLM", "ZNOPQRSTUVWXY"), | ||
"D": ("ABCDEFGHIJKLM", "ZNOPQRSTUVWXY"), | ||
"E": ("ABCDEFGHIJKLM", "YZNOPQRSTUVWX"), | ||
"F": ("ABCDEFGHIJKLM", "YZNOPQRSTUVWX"), | ||
"G": ("ABCDEFGHIJKLM", "XYZNOPQRSTUVW"), | ||
"H": ("ABCDEFGHIJKLM", "XYZNOPQRSTUVW"), | ||
"I": ("ABCDEFGHIJKLM", "WXYZNOPQRSTUV"), | ||
"J": ("ABCDEFGHIJKLM", "WXYZNOPQRSTUV"), | ||
"K": ("ABCDEFGHIJKLM", "VWXYZNOPQRSTU"), | ||
"L": ("ABCDEFGHIJKLM", "VWXYZNOPQRSTU"), | ||
"M": ("ABCDEFGHIJKLM", "UVWXYZNOPQRST"), | ||
"N": ("ABCDEFGHIJKLM", "UVWXYZNOPQRST"), | ||
"O": ("ABCDEFGHIJKLM", "TUVWXYZNOPQRS"), | ||
"P": ("ABCDEFGHIJKLM", "TUVWXYZNOPQRS"), | ||
"Q": ("ABCDEFGHIJKLM", "STUVWXYZNOPQR"), | ||
"R": ("ABCDEFGHIJKLM", "STUVWXYZNOPQR"), | ||
"S": ("ABCDEFGHIJKLM", "RSTUVWXYZNOPQ"), | ||
"T": ("ABCDEFGHIJKLM", "RSTUVWXYZNOPQ"), | ||
"U": ("ABCDEFGHIJKLM", "QRSTUVWXYZNOP"), | ||
"V": ("ABCDEFGHIJKLM", "QRSTUVWXYZNOP"), | ||
"W": ("ABCDEFGHIJKLM", "PQRSTUVWXYZNO"), | ||
"X": ("ABCDEFGHIJKLM", "PQRSTUVWXYZNO"), | ||
"Y": ("ABCDEFGHIJKLM", "OPQRSTUVWXYZN"), | ||
"Z": ("ABCDEFGHIJKLM", "OPQRSTUVWXYZN"), | ||
} | ||
|
||
|
||
def generate_table(key): | ||
""" | ||
>>> generateTable('marvin') | ||
[[['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']]] | ||
""" | ||
table = [] | ||
for char in key.upper(): | ||
table.append(alphabet[char]) | ||
return table | ||
>>> generate_table('marvin') | ||
[('ABCDEFGHIJKLM', 'UVWXYZNOPQRST'), ('ABCDEFGHIJKLM', 'NOPQRSTUVWXYZ'), ('ABCDEFGHIJKLM', 'STUVWXYZNOPQR'), ('ABCDEFGHIJKLM', 'QRSTUVWXYZNOP'), ('ABCDEFGHIJKLM', 'WXYZNOPQRSTUV'), ('ABCDEFGHIJKLM', 'UVWXYZNOPQRST')] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. These long lines need to be wrapped. |
||
""" | ||
return [alphabet[char] for char in key.upper()] | ||
|
||
|
||
def encrypt(key, words): | ||
""" | ||
>>> encrypt('marvin', 'jessica') | ||
'QRACRWU' | ||
""" | ||
>>> encrypt('marvin', 'jessica') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This indenting is not needed or desirable. |
||
'QRACRWU' | ||
""" | ||
cipher = "" | ||
count = 0 | ||
table = generateTable(key) | ||
table = generate_table(key) | ||
for char in words.upper(): | ||
cipher += getOpponent(table[count], char) | ||
cipher += get_opponent(table[count], char) | ||
count = (count + 1) % len(table) | ||
return cipher | ||
|
||
|
||
def decrypt(key, words): | ||
""" | ||
>>> decrypt('marvin', 'QRACRWU') | ||
'JESSICA' | ||
""" | ||
>>> decrypt('marvin', 'QRACRWU') | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same. |
||
'JESSICA' | ||
""" | ||
return encrypt(key, words) | ||
|
||
|
||
def getPosition(table, char): | ||
""" | ||
>>> table = [[['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']]] | ||
>>> getPosition(table, 'A') | ||
(None, None) | ||
def get_position(table, char): | ||
""" | ||
>>> table = [('ABCDEFGHIJKLM', 'UVWXYZNOPQRST'), ('ABCDEFGHIJKLM', 'NOPQRSTUVWXYZ'), ('ABCDEFGHIJKLM', 'STUVWXYZNOPQR'), ('ABCDEFGHIJKLM', 'QRSTUVWXYZNOP'), ('ABCDEFGHIJKLM', 'WXYZNOPQRSTUV'), ('ABCDEFGHIJKLM', 'UVWXYZNOPQRST')] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same. |
||
>>> get_position(table, 'A') | ||
(None, None) | ||
""" | ||
row = -1 | ||
|
||
if char in table[0]: | ||
row = 0 | ||
elif char in table[1]: | ||
row = 1 | ||
|
||
if row != -1: | ||
return (row, table[row].index(char)) | ||
else: | ||
return (None, None) | ||
return (None, None) if row == -1 else (row, table[row].index(char)) | ||
|
||
|
||
def getOpponent(table, char): | ||
""" | ||
>>> table = [[['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V']], [['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M'], ['U', 'V', 'W', 'X', 'Y', 'Z', 'N', 'O', 'P', 'Q', 'R', 'S', 'T']]] | ||
>>> getOpponent(table, 'A') | ||
'A' | ||
def get_opponent(table, char): | ||
""" | ||
row, col = getPosition(table, char.upper()) | ||
>>> table = [('ABCDEFGHIJKLM', 'UVWXYZNOPQRST'), ('ABCDEFGHIJKLM', 'NOPQRSTUVWXYZ'), ('ABCDEFGHIJKLM', 'STUVWXYZNOPQR'), ('ABCDEFGHIJKLM', 'QRSTUVWXYZNOP'), ('ABCDEFGHIJKLM', 'WXYZNOPQRSTUV'), ('ABCDEFGHIJKLM', 'UVWXYZNOPQRST')] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same. |
||
>>> get_opponent(table, 'A') | ||
'A' | ||
""" | ||
row, col = get_position(table, char.upper()) | ||
|
||
if row == 1: | ||
return table[0][col] | ||
elif row == 0: | ||
return table[1][col] | ||
else: | ||
return char | ||
return table[1][col] if row == 0 else char | ||
|
||
|
||
if __name__ == "__main__": | ||
""" | ||
ENTER KEY: marvin | ||
ENTER TEXT TO ENCRYPT: jessica | ||
ENCRYPTED: QRACRWU | ||
DECRYPTED WITH KEY: JESSICA | ||
""" | ||
ENTER KEY: marvin | ||
ENTER TEXT TO ENCRYPT: jessica | ||
ENCRYPTED: QRACRWU | ||
DECRYPTED WITH KEY: JESSICA | ||
""" | ||
key = input("ENTER KEY: ") | ||
text = input("ENTER TEXT TO ENCRYPT: ") | ||
cipher_text = encrypt(key, text) | ||
|
@@ -110,4 +103,5 @@ def getOpponent(table, char): | |
print("DECRYPTED WITH KEY: " + decrypt(key, cipher_text)) | ||
|
||
import doctest | ||
|
||
doctest.testmod() |
Uh oh!
There was an error while loading. Please reload this page.