上篇文章讲述了凯撒密码的基本原理。如下代码所示,实现一个简单的凯撒加密算法。
import string def alphabet1(): \"\"\" 生成字母表的方法1 \"\"\" letter_list = [\'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\'] return letter_list def alphabet2(): \"\"\" 生成字母表的方法2 \"\"\" letter_list_2 = [chr(letter+ord(\'a\')) for letter in range(26)] return letter_list_2 def alphabet3(): \"\"\" 生成字母表的方法3 \"\"\" letter_list_3 = [chr(letter).lower() for letter in range(65, 91)] return letter_list_3 def alphabet4(): \"\"\" 生成字母表的方法4 \"\"\" return list(string.ascii_lowercase) def shift(arr: list, n: int) -> list: \"\"\" 移动字母表 Args: arr (list): 字母表 n (int): 移动的位数 Returns: list: 移动后的字母表 \"\"\" if n: return arr[n:] + arr[:n] else: n = -1*n return arr[:n] + arr[n:] def encoder(plaintext,key=3): \"\"\" 对明文进行编码 Args: plaintext (str): 要加密的明文 key (int): 偏移的位数据 \"\"\" normal_alphabet = alphabet2() caesor_alphabet = shift(normal_alphabet,key) crypt = [caesor_alphabet[normal_alphabet.index(ch)] for ch in plaintext] return \'\'.join(crypt) def test(): \"\"\" 加密的演示 \"\"\" # 多种字母表生成的方法 print(alphabet1()) print(alphabet2()) print(alphabet3()) print(alphabet4()) # 随便挑一个方法 alphabet = alphabet1() caesar_alphabet = shift(alphabet,3) print(caesar_alphabet) print(encoder(\'iamchinese\')) if __name__ == \'__main__\': test()本系列文章不讲解python的基本语法,本着实用主义的角度来解决问题。如前文所述,首先要建立一个字母表,接着实现一个对字母表的移位。
- alphabet1/2/3/4是不同的生成字母表的小函数。从通用的角度来看,alphabet4直接使用python内置的模块,就可以将小写的英文字母获得。但需要注意的是,string.ascii_lowercase返回的是一个字符串,而不是一个列表,所以要用list函数再做一次切割,从而形成字母列表。
- shift函数是一个通用的对列表进行循环移位的函数。使用python的切片方法完成一个漂亮而容易理解的实现,但不是效率最高的。这个函数可以列表左移,也可以右移。右移时key为负数。
- encoder函数是真正的加密算法,输入字符串后,使用列表推导式,先找出在正常字母表中字符的位置索引,然后在平移后的字母表中找到对应的字符,最后再将所有的字符通过join()函数合成一个字符串返回。
- 由于现有的字母表没有空格的存在,所以加密的字符串只能够是连续的无打印符的字母组合。如果想要对空格加密,可以将空格加入到alphabet中,再形成对应的平移表。再进一步讲,如果把汉字也放到字母表中,理论上也可以对中文信息进行加密,原理是一样的,大家可以自行实现。
- 代码中没有实现解密,实现起来非常容易。
