?一个超有意思的 Python 综合能力测试网站

这一期的话题是:一个学习的趣味网站 。
最近在网上看到一个非常有意思的游戏通关网站,一共有 33 关,每一关都需要利用知识解题找到答案,然后进入下一关 。很考验对的综合掌握能力,比如有的闯关需要用到正则表达式,有的要用到爬虫 。
我们平常学都是按章节顺序、包或者模块来学,容易前学后忘 。正好可以拿这个网站来综合测试一下对的掌握情况,以便查缺补漏 。
来说说这个网站怎么玩 。
mark
这是网站主页面,很有历史感对吧,诞生了已有十几年了 。但千万不要因为看着像老古董而小瞧它 。
mark
我们来玩玩看,点击「get 」开始挑战 。
第 0 关是up 热身环节:
这一关要求是修改 URL 链接,给的提示是电脑上的数学表达式:2 的 38 次方,所以大概就是需要计算出数值,然后修改url 进入下一关 。
所以这关就是考的基本数值运算,你知道怎么算么?
打开自带终端,一行代码就能计算出结果:
mark
把原链接中的0替换为回车就会进入下一关:
mark
游戏这就正式开始了 。图片中的笔记本给了三组字母,很容易发现规律:前面的字母往后移动两位就是后面的字母 。
那么需要做的就是根据这个规律把下面的提示字符串,做位移解密得到真正的句子含义:
这道题考察字符串编码和 for 循环相关知识,代码实现如下:
1text = '''g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq2ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q3ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq()4gq pcamkkclbcb. lmu ynnjw ml rfc spj.'''56text_translate = ''7for i in text:8if str.isalpha(i):9n = ord(i)10if i >= 'y':11n = ord(i) + 2 - 2612else:13n = ord(i) + 214text_translate += chr(n)15else:16text_translate += i17print(text_translate)
得到结果:
1i hope you didnt translate it by hand. 2thats what computers are for. 3doing it in by hand is inefficient and that's why this text is so long. 4using string.maketrans()is recommended. now apply on the url.
作者很风趣,当然不能手动去一个推算了,推荐用 .() 这个方法解决,我们上面采取的是比较直接的方法,官方给出了更为精简的方法:
1import string2l = string.lowercase3t = string.maketrans(l, l[2:] + l[:2])4print (text.translate(t))
然后把 url 中的map改为ocr回车就来到了第 2 关:
mark
作者接着说过关的提示可能在书里(当然不可能了)也可能在网页源代码里 。那就右键查看源代码往下拉看到绿色区域,果然找到了问题:
mark
意思就是:要在下面这一大串字符里找到出现次数最少的几个字符
考察了这么几个知识点:
如果是你,你会怎么做?
来看下,十行代码快速实现:
1import requests2url = 'http://www.pythonchallenge.com/pc/def/ocr.html'3res = requests.get(url).text4text = re.findall('.*?.*',res,re.S)5# list转为str便于遍历字符6str = ''.join(text)78lst = []9key=[]10#遍历字符11for i in str:12#将字符存到list中13lst.append(i)14#如果字符是唯一的,则添加进key15if i not in key:16key.append(i)17# 将list列表中的字符出现字数统计出来18for items in key:19print(items,lst.count(items))
首先,用请求网页然后用正则提取出字符串,接着 for 循环计算每个字符出现的次数 。
1% 61042$ 60463@ 61574_ 61125^ 60306# 61157) 61868& 60439! 607910+ 606611] 615212* 603413} 610514[ 610815( 615416{ 60461718e 119q 120u 121a 122l 123i 124t 125y 1
可以看到出现次数最少的就是最后几个字符,合起来是「」,替换 url 字符就闯过过了第 2 关进入下一关继续挑战 。是不是有点意思?