2014-04-20 19:43:22 +02:00
|
|
|
from string import ascii_lowercase
|
2014-04-08 00:17:34 -03:00
|
|
|
from time import time
|
|
|
|
|
import random
|
|
|
|
|
|
2014-04-20 19:43:22 +02:00
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
class Cipher:
|
2014-04-20 19:43:22 +02:00
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
def __init__(self, k=None):
|
|
|
|
|
if k:
|
2014-04-20 19:43:22 +02:00
|
|
|
self.key = _normalize(k)
|
2014-04-08 00:17:34 -03:00
|
|
|
else:
|
|
|
|
|
random.seed(time())
|
2014-04-20 19:43:22 +02:00
|
|
|
self.key = ''.join(random.choice(ascii_lowercase)
|
|
|
|
|
for i in range(100))
|
|
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
def base_encode(self, s, shift):
|
2014-04-20 19:43:22 +02:00
|
|
|
xkey = self.key * (len(s) // len(self.key) + 1)
|
|
|
|
|
return ''.join(shift(c, k) for c, k in zip(s, xkey))
|
|
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
def encode(self, s):
|
2014-04-20 19:43:22 +02:00
|
|
|
s = _normalize(s)
|
|
|
|
|
shift = lambda c, k: chr(((ord(c) + ord(k) - 2 * ord('a'))
|
|
|
|
|
% len(ascii_lowercase)) + ord('a'))
|
2014-04-08 00:17:34 -03:00
|
|
|
return self.base_encode(s, shift)
|
|
|
|
|
|
|
|
|
|
def decode(self, s):
|
2014-04-20 19:43:22 +02:00
|
|
|
shift = lambda c, k: chr(((ord(c) - ord(k) + len(ascii_lowercase))
|
|
|
|
|
% len(ascii_lowercase)) + ord('a'))
|
2014-04-08 00:17:34 -03:00
|
|
|
return self.base_encode(s, shift)
|
|
|
|
|
|
2014-04-20 19:43:22 +02:00
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
class Caesar(Cipher):
|
2014-04-20 19:43:22 +02:00
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
def __init__(self):
|
|
|
|
|
Cipher.__init__(self, 'd')
|
|
|
|
|
|
2014-04-20 19:43:22 +02:00
|
|
|
|
|
|
|
|
def _normalize(s):
|
|
|
|
|
return ''.join([c for c in s if c.isalpha()]).lower()
|
|
|
|
|
|
|
|
|
|
|
2014-04-08 00:17:34 -03:00
|
|
|
if __name__ == '__main__':
|
|
|
|
|
print(Caesar().encode('venividivici'))
|
2014-04-20 19:43:22 +02:00
|
|
|
print(Caesar().encode('\'Twas the night before Christmas'))
|