Python基础编程入门实例:恺撒密码

本文详细介绍了Python中的恺撒密码,包括加密和解密原理,以及通过实际代码实现的实例。通过Python编程实现字母替换,展示了如何使用恺撒密码进行信息加密和解密的过程。
摘要由CSDN通过智能技术生成
文章目录
  • Python基础编程入门实例:恺撒密码
  • 一、什么是恺撒密码
  • 二、程序运行环境
  • 三、恺撒密码:加密
    • 3.1、恺撒密码加密实例程序
    • 3.2、恺撒密码加密实例程序运行结果
  • 四、恺撒密码:解密
    • 4.1、恺撒密码解密实例程序
    • 4.2、恺撒密码解密实例程序运行结果
  • 五、完整程序
  • 六、总结

Python基础编程入门实例:恺撒密码

一、什么是恺撒密码

  • 恺撒撒密码是古罗马恺撒大帝用来对军事情报进行加密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列该字符后面第三个字符:

原文: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
密文: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

在这里插入图片描述

  • 原文字符P,其密文字符C满足如下条件:

C = ( P + 3 ) mod 26

  • 解密方法反之,满足:

P = ( C – 3 ) mod 26

二、程序运行环境

程序运行环境是:pycharm2021
在这里插入图片描述

三、恺撒密码:加密

  • 恺撒密码的加密算法程序首先接收用户输入的文本
  • 然后对字母a-z和字母A-Z按照密码算法进行转换

3.1、恺撒密码加密实例程序

在这里插入图片描述

# 恺撒密码加密
def Caesar_PW_Encryption():
    inputText = input("请输入明文文本: ")
    for index in inputText:
        if "a" <= index <= "z":
            print(chr(ord("a") + (ord(index) - ord("a") + 3) % 26), end='')
        elif "A" <= index <= "Z":
            print(chr(ord("A") + (ord(index) - ord("A") + 3) % 26), end='')
        else:
            print(index, end='')

  • 在主函数中调用这个Caesar_PW_Encryption恺撒密码加密函数,如下所示
if __name__ == '__main__':
    # 恺撒密码加密
    Caesar_PW_Encryption()

3.2、恺撒密码加密实例程序运行结果

在这里插入图片描述

四、恺撒密码:解密

  • 恺撒密码的解密算法程序首先接收用户输入的加密文本
  • 然后对字母a-z和字 母A-Z按照密 码算法进行反向转换

4.1、恺撒密码解密实例程序

在这里插入图片描述

# 恺撒密码解密
def Ceasar_PW_Decryption():
    inputText = input("请输入加密后文本: ")
    for index in inputText:
        if "a" <= index <= "z":
            print(chr(ord("a") + (ord(index) - ord("a") - 3) % 26), end='')
        elif "A" <= index <= "Z":
            print(chr(ord("A") + (ord(index) - ord("A") - 3) % 26), end='')
        else:
            print(index, end='')


  • 在主函数中调用这个Caesar_PW_Encryption恺撒密码加密函数,如下所示
if __name__ == '__main__':
    # 恺撒密码加密
    Caesar_PW_Encryption()

    # 恺撒密码解密
    Ceasar_PW_Decryption()


4.2、恺撒密码解密实例程序运行结果

在这里插入图片描述

五、完整程序

# 恺撒密码加密
def Caesar_PW_Encryption():
    inputText = input("请输入明文文本: ")
    for index in inputText:
        if "a" <= index <= "z":
            print(chr(ord("a") + (ord(index) - ord("a") + 3) % 26), end='')
        elif "A" <= index <= "Z":
            print(chr(ord("A") + (ord(index) - ord("A") + 3) % 26), end='')
        else:
            print(index, end='')

# 恺撒密码解密
def Ceasar_PW_Decryption():
    inputText = input("请输入加密后文本: ")
    for index in inputText:
        if "a" <= index <= "z":
            print(chr(ord("a") + (ord(index) - ord("a") - 3) % 26), end='')
        elif "A" <= index <= "Z":
            print(chr(ord("A") + (ord(index) - ord("A") - 3) % 26), end='')
        else:
            print(index, end='')

if __name__ == '__main__':
    # 恺撒密码加密
    Caesar_PW_Encryption()

    # 恺撒密码解密
    Ceasar_PW_Decryption()

    


六、总结

本文主要讲解了恺撒密码:采用了替换方法对信息中的每一个英文字符循环替换为字母表序列该字符后面第三个字符。并通过一个实例程序来进一步加强对恺撒密码的理解与运用。

关于Python技术储备

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

包括:Python激活码+安装包、Python web开发,Python爬虫,Python数据分析,Python自动化测试学习等教程。带你从零基础系统性的学好Python!

👉[[CSDN大礼包:《python安装包&全套学习资料》免费分享]]安全链接,放心点击

一、Python学习大纲

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
在这里插入图片描述

二、Python必备开发工具

在这里插入图片描述

三、入门学习视频

四、实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。在这里插入图片描述

五、python副业兼职与全职路线

在这里插入图片描述

上述这份完整版的Python全套学习资料已经上传CSDN官方,如果需要可以微信扫描下方CSDN官方认证二维码 即可领取

  • 26
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
凯撒密码是一种简单的加密算法,通过将字母按照一定的偏移量进行替换来实现加密和解密。在Python中实现凯撒密码可以通过定义一个字母表,并利用其索引进行偏移计算。根据引用中的代码示例,我们可以给出以下Python代码来实现凯撒密码的加密和解密功能: ```python import string upper_list = string.ascii_uppercase lower_list = string.ascii_lowercase def encryption(source): offset = 5 result = '' for c in source: if c in lower_list: index = (lower_list.index(c) + offset) % len(lower_list) result += lower_list[index] elif c in upper_list: index = (upper_list.index(c) + offset) % len(lower_list) result += upper_list[index] return result def decryption(result): offset = 5 source = '' for c in result: if c in lower_list: index = (lower_list.index(c) - offset) % len(lower_list) source += lower_list[index] elif c in upper_list: index = (upper_list.index(c) - offset) % len(lower_list) source += upper_list[index] return source if __name__ == '__main__': source = "JiaYou" encrypted_result = encryption(source) decrypted_result = decryption(encrypted_result) print(encrypted_result) print(decrypted_result) ``` 以上代码中,`encryption`函数用于将源字符串进行加密,`decryption`函数用于将加密结果进行解密。在`if __name__ == '__main__'`部分,我们可以看到使用示例,输入"JiaYou"字符串进行加密后得到"OnfDtz",再对加密结果进行解密得到原始字符串"JiaYou"。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值