加密解密类

  1. 加密是日常生活中经常用到的保护信息内容的方法,
    比如非常简单的凯撒密码,利用字母移位来加密字母,
    比如让字母移动1位,比如a变成b,b变成c,最后z变成a,
    将内容整体移动一位来加密内容,
    现在要求实现这样的一个加密类,有一个加密的方法,
    也有一个解密到的方法,请实现这样的一个类
class Password:#加密解密类
    li1 = [#小写字母
           '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']
    
    li2 = [#大写字母
          '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']
    
    def decode(self,string):#解码函数
        rs = ''#rs(return_string)返回的字符串
        #加密
        for i in range(len(string)):
            #如果string[i]在列表self.li1中,即字符为小写的加密方式
            if string[i] in self.li1:
                #如果string[i]为列表中li1第一个元素
                if self.li1.index(string[i]) == 0:
                    rs = rs + self.li1[len(self.li1)-1]
                else:
                    rs = rs + self.li1[self.li1.index(string[i])-1]
                    
            elif string[i] in self.li2:
                #如果string[i]为列表中li2第一个元素
                if self.li2.index(string[i]) == 0:
                    rs = rs + self.li2[len(self.li2)-1]
                else:
                    rs = rs + self.li2[self.li2.index(string[i])-1]
                   
            else:#如果string[i]不在列表self.li中
                #如果字符不属于self.li,则返回string[i]对应unicode码+6 所对应的字符
                rs = rs +chr(ord(string[i])-6)
        return rs
    

    def encode(self,string):#编码函数
        rs = ''#rs(return_string)返回的字符串
        #加密
        for i in range(len(string)):
            #如果string[i]在列表self.li1中,即字符为小写字母加密方式
            if string[i] in self.li1:
                #如果string[i]为列表中的最后一个元素
                if self.li1.index(string[i])+1 == len(self.li1):
                    rs = rs + self.li1[0]
                else:
                    rs = rs + self.li1[self.li1.index(string[i])+1]
                    
            #如果string[i]在列表self.li2中,即字符为大写字母加密方式
            elif string[i] in self.li2:
                #如果string[i]为列表中的最后一个元素
                if self.li2.index(string[i])+1 == len(self.li2):
                    rs = rs + self.li2[0]
                else:
                    rs = rs + self.li2[self.li2.index(string[i])+1]    
            else:#如果string[i]不在列表self.li中
                #如果字符不属于self.li,则返回string[i]对应unicode码+6 所对应的字符
                rs = rs +chr(ord(string[i])+6)
        return rs
a = Password()

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sun614

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值