Python Challenge level 01

本文介绍了解密一个特定加密字符串的方法,该字符串通过将每个字母向后移动两个位置来加密。文中提供了两种解密手段,一种是通过逐字符处理,另一种是利用Python的string.maketrans()方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

进入第2题显示的图片如下:

图下方给出了一段没有规律的字符:

g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj.

不过通过上面图片信息,可以推测这段没有规律的字符是加密过的,而图片显示的字符规则就是密钥,规则就是字符向后移两位。

字符向后移位,就会想到用这种方法:

original = "g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle \
gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() \
gq pcamkkclbcb. lmu ynnjw ml rfc spj."

newStr = ''

for s in original:
    if s.isalpha():
        tmp = ord(s)+2
        if tmp > ord('z'):
            tmp -= 26          
        newStr += chr(tmp)
    else:
        newStr += s

print newStr

输出结果是:

i hope you didnt translate it by hand. thats what computers are for. doing it in by hand is inefficient and that's why this text is so long. 
using string.maketrans() is recommended. now apply on the url.


上面的提示告诉我们,作者希望你不要手动去翻译,而是推荐使用 string.maketrans() 方法。

maketrans() 方法相当于字典的密码表,它有两个参数,第一个参数是原码,第二个参数是译码,比如上面图片中字符 k -> m, o -> q,k就是原码,q就是译码。有了这个密码,就可以对一个加密的字符串进行解密。除了有这个密码表之外,还要需要translate 方法。这样一样,代码就可以是:

import string

original = "g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle \
gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() \
gq pcamkkclbcb. lmu ynnjw ml rfc spj."

table = string.maketrans("abcdefghijklmnopqrstuvwxyz","cdefghijklmnopqrstuvwxyzab")

print original.translate(table)

现在可以将l http://www.pythonchallenge.com/pc/def/map.html 中map 按上面密码规则转换后,进入下一题:

http://www.pythonchallenge.com/pc/def/ocr.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值