您的当前位置:玉林芙暴百货零售有限公司 > 常见问题 > 正文

来闯关吗?一个有趣的 Python 解谜网站

  • 作者:admin    最后更新:2020-04-07 19:10    点击数:
  • 原标题:来闯关吗?一个有趣的 Python 解谜网站

    来源:高级农民工

    克东县圩渺美食有限公司

    来源:高级农民工

    这一期的话题是: 一个学习 Python 的趣味网站 。

    最近在网上看到一个非常有意思的 Python 游戏通关网站,一共有 33 关,每一关都需要利用 Python 知识解题找到答案,然后进入下一关。很考验对 Python 的综合掌握能力,比如有的闯关需要用到正则表达式,有的要用到爬虫。

    我们平常学 Python 都是按章节顺序、包或者模块来学,容易前学后忘。正好可以拿这个网站来综合测试一下对 Python 的掌握情况,以便查缺补漏。

    来说说这个网站怎么玩。

    mark

    这是网站主页面,很有历史感对吧,诞生了已有十几年了。但千万不要因为看着像老古董而小瞧它。

    mark

    我们来玩玩看,点击「get challenged」开始挑战。

    第 0 关是 Warming up 热身环节:

    这一关要求是修改 URL 链接,给的提示是电脑上的数学表达式:2 的 38 次方,所以大概就是需要计算出数值,然后修改url 进入下一关。

    所以这关就是考 Python 的基本数值运算,你知道怎么算么?

    打开 Python 自带终端,一行代码就能计算出结果:

    mark

    mark

    游戏这就正式开始了。图片中的笔记本给了三组字母,很容易发现规律:前面的字母往后移动两位就是后面的字母。

    那么需要做的就是根据这个规律把下面的提示字符串,做位移解密得到真正的句子含义:

    这道题考察字符串编码和 for 循环相关知识,代码实现如下:

    1text = '''g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq

    2ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q

    3ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq

    4gq pcamkkclbcb. lmu ynnjw ml rfc spj.'''

    5

    6text_translate = ''

    7fori intext:

    8ifstr.isalpha(i):

    9n = ord(i)

    10ifi >= 'y':

    11n = ord(i) 2- 26

    12else:

    13n = ord(i) 2

    14text_translate = chr(n)

    15else:

    16text_translate = i

    17print(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.maketransis recommended. now apply on the url.

    作者很风趣,当然不能手动去一个推算了,推荐用 string.maketrans 这个方法解决,我们上面采取的是比较直接的方法,官方给出了更为精简的方法:

    1importstring

    2l = string.lowercase

    3t = string.maketrans(l, l[ 2:] l[: 2])

    4print(text.translate(t))

    然后把 url 中的 map 改为 ocr 回车就来到了第 2 关:

    mark

    作者接着说过关的提示可能在书里(当然不可能了)也可能在网页源代码里。那就右键查看源代码往下拉看到绿色区域,果然找到了问题:

    mark

    意思就是: 要在下面这一大串字符里找到出现次数最少的几个字符

    考察了这么几个知识点:

    如果是你,你会怎么做?

    来看下,十行代码快速实现:

    1importrequests

    2url = 'http://www.pythonchallenge.com/pc/def/ocr.html'

    3res = requests.get(url).text

    4text = re.findall( '.*?<!--.*-->.*<!--(.*)-->',res,re.S)

    5# list转为str便于遍历字符

    6str = ''.join(text)

    7

    8lst = []

    9key=[]

    10#遍历字符

    11fori instr:

    12#将字符存到list中

    13lst.append(i)

    14#如果字符是唯一的,则添加进key

    15ifi notinkey:

    16key.append(i)

    17# 将list列表中的字符出现字数统计出来

    18foritems inkey:

    19print(items,lst.count(items))

    首先,用 Requests 请求网页然后用正则提取出字符串,接着 for 循环计算每个字符出现的次数。

    1% 6104

    2$ 6046

    3@ 6157

    4_ 6112

    5^ 6030

    6# 6115

    7) 6186

    8& 6043

    9! 6079

    10 6066

    11] 6152

    12* 6034

    13} 6105

    14[ 6108

    15( 6154

    16{ 6046

    17

    18e 1

    19q 1

    20u 1

    21a 1

    22l 1

    23i 1

    24t 1

    25y 1

    可以看到出现次数最少的就是最后几个字符,合起来是「equality」,替换 url 字符就闯过过了第 2 关进入下一关继续挑战。是不是有点意思?

    后面每一关都需要用到相关的 Python 技巧解决,荣誉资质比如第 4 关:

    mark

    这一关作者弄了个小恶作剧,需要手动输入数值到 url 中然后回车,你以为这样就完了么?并没有它有会不断重复弹出新的数值让你输入,貌似无穷尽。

    所以,这一关肯定不能采取手动输入的方法闯关,自然要用到 Python 了。要实现自动填充修改 url 回车跳转到新 url,循环直到网页再也无法跳转为止这一功能。

    如果是你,你会怎么做?

    其实,一段简单的爬虫加正则就能搞定。思路很简单,把每次网页中的数值提取出来替换成新的 url 再请求网页,循环下去,代码实现如下:

    1importrequests

    2importre

    3importos

    4

    5# 首页url

    6resp = requests.get(

    7'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing=12345').text

    8url = 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing='

    9# 计数器

    10count = 0

    11whileTrue:

    12try:

    13# 提取下一页动态数值

    14nextid = re.search( 'd ', resp).group

    15count = count 1

    16nextid = int(nextid)

    17except:

    18print( '最后一个url为:%s'% nexturl)

    19break

    20

    21# 获取下一页url

    22nexturl = url str(nextid)

    23print( 'url %s:%s'% (count, nexturl))

    24# 重复请求

    25resp = requests.get(nexturl).text

    输出结果如下:

    可以看到,最终循环了 85 次找到了最后一个数字16044,输入到 url 中就闯关成功。

    33 关既有趣又能锻炼使用 Python 解决问题的技巧,感兴趣的话去玩玩看。

    网址: http://www.pythonchallenge.com/

    如果遇到不会做的题,可以在这里找到参考答案:

    中参考文教程:

    https://www.cnblogs.com/jimnox/archive/2009/12/08/tips-to-python-challenge.html

    官方参考教程:

    http://garethrees.org/2007/05/07/python-challenge/

    原标题:在家防疫也会“瞎了眼”?请给孩子的眼睛收下这10条建议~

      据《米兰体育报》记者尼科洛-希拉的消息称,此前尤文对阵维罗纳的比赛,多特蒙德在意大利的球探前往现场观看了这场比赛,并且考察了维罗纳20岁后卫小将马拉什-库姆布拉。  与此同时,曼城的球探也观看了这场比赛,并且考察了马拉什-库姆布拉。  本赛季,马拉什-库姆布拉为维罗纳出战了18场比赛,均为首发,打进了1球。

      原标题:2020年Q1消费者在应用上的支出达到了创纪录的234亿美元来源:.COM

    【太平洋汽车网 】前不久发布了i4 ,巨大的“双肾”格栅使其成为了一时热话,但笔者认为,即便把这辆车的俩大鼻孔挡住,它在大街上的回头率也绝对不会低。这种短前悬短后悬、引擎舱修长的轿跑,其的身段基本在50米开外就可以吸引路人的目光。而这类车车都有一个共同的特点:掀背。

    【编者按】近日,一批港交所B 股上市的本土创新药企交出了他们2019年度成绩单,大多是上市后首份。第一系列的财报盘点包括创新疫苗企业康希诺、主攻肿瘤免疫治疗的基石药业、生物类似药第一企业复宏汉霖、细胞凋亡领头企业亚盛医药、专攻“冷门”抗病毒药企歌礼制药。2019年,他们都取得了什么进展?遇到了什么困难?

    Powered by 玉林芙暴百货零售有限公司 @2018 RSS地图 html地图

    Copyright 365站群 © 2013-2018 版权所有