python 凯撒密码
半夏微光1117 人气:0凯撒加密就是通过将字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移,被替换成密文。例如,当偏移量是2的时候,所有的字母B将被替换成D,C变成E,以此类推Y将变成A,Z变成B。由此可见,偏移量就是凯撒密码加密和解密的密钥。
下面使用python代码来实现凯瑟密码的加密解密。
import string def kaisa_jiami(s,k): lower=string.ascii_lowercase#小写英文字母 upper=string.ascii_uppercase#大写英文字母 before=string.ascii_letters#全部英文字母字母 after=lower[k:]+lower[:k]+upper[k:]+upper[:k]#建立循环字母 table=''.maketrans(before,after)#创建映射表 return s.translate(table) def kaisa_jiemi(s,k): lower=string.ascii_lowercase upper=string.ascii_uppercase before=string.ascii_letters after=lower[k:]+lower[:k]+upper[k:]+upper[:k] table=''.maketrans(after,before) return s.translate(table) def main(): s=input("请输入要加密的字符串:") k=int(input("请输入一个整数密钥:"))#将k转换为整数,默认输入为字符 print('需要加密的字符串为:',s) a=kaisa_jiami(s,k) print("加密后为:",a) b= kaisa_jiemi(a,k) print("解密后为:",b) if __name__=='__main__': main()
运行结果
请输入要加密的字符串:HELLO world
请输入一个整数密钥:3
需要加密的字符串为: HELLO world
加密后为: KHOOR zruog
解密后为: HELLO world
上述程序中主要用到了maketrans()和translate()两个方法。下面让我们来详细看一下这两个方法的使用方法。
translate() 方法根据 maketrans() 方法给出的字符映射转换表转换字符串中的字符。
比如
import string map = ''.maketrans('ABC123', 'abcDEF')#形成一个映射,将ABC123分别映射为abcDEF s = "123ABC" s.translate(map)#按照map中的映射关系进行字符的替换。
运行结果
'DEFabc'
加载全部内容