python实现凯撒密码加密解密

python实现凯撒密码加密解密

凯撒加密就是通过将字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移,被替换成密文。例如,当偏移量是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'
今天就讲到这里了呀!!!

你可能感兴趣的:(python)