The Python Challenge 0-4
The Python Challenge 0-4
项目地址:http://www.pythonchallenge.com/
Level-0
提示Hint: try to change the URL address. ,修改0.html为1.html,提示2**38 is much much larger. ,打开python控制台,计算后替换1.html为274877906944.html,进入下一关。
>>> 2**38
274877906944
Level-1
提示everybody thinks twice before solving this.,观察图片发现是一道找规律的数学题,字母间位置相差2,由此猜测位移计算,将字符串中所有字母右移两位。
str = "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. "
def right_2(str):
if str is 'y':
return 'a'
if str is 'z':
return 'b'
if str.isalpha() and str not in 'yz':
return chr(ord(str)+2)
return str
s = map(right_2, str)
print ''.join(s)
ord() 函数以一个字符(长度为1的字符串)作为参数,返回对应的 ASCII 数值。
chr() 用一个范围在 range(256)内的(就是0~255)整数作参数,返回一个对应的字符。
isalpha() 方法检测字符串是否只由字母组成。
map() 会根据提供的函数对指定序列做映射。第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。
程序运行结果为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. ,根据提示添加str = "map",运行得到结果ocr。
解法二:
根据提示的函数,maketrans() 方法用于创建字符映射的转换表,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。两个字符串的长度必须相同,为一一对应的关系。
生成字母表
>>> import string
>>> string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'
操作字符串自定义规则
import string
from string import maketrans
str = "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. "
def right_2(str):
s = string.ascii_lowercase
s1 = s
s2 = s[2:26] + s[0:2]
trantab = maketrans(s1,s2)
if str.isalpha():
return str.translate(trantab)
return str
str = map(right_2,str)
print ''.join(str)
Level-2
提示recognize the characters. maybe they are in the book,but MAYBE they are in the page source.,直接查看源代码提示find rare characters in the mess below,复制后保存到文件,程序如下,运行结果为equality。
import string
l = []
with open('/Users/markzhang/Desktop/level3.txt','r') as f:
str = f.read()
for s in str:
if s in string.ascii_lowercase:
l.append(s)
if s in string.ascii_uppercase:
l.append(s)
print ''.join(l)
Level-3
提示One small letter, surrounded by EXACTLY three big bodyguards on each of its sides. ,要求查找类似xXXXxXXXx的小写字母,直接查看源代码,复制后保存到文件,程序如下,运行结果为linkedlist。
import re
with open('/Users/markzhang/Desktop/level4.txt','r') as f:
str = f.read()
pattern = re.compile(r'[^A-Z][A-Z]{3}([a-z])[A-Z]{3}[^A-Z]')
result = re.findall(pattern,str)
print ''.join(result)
Level-4
打开是一张图片,点击图片提示and the next nothing is 44827,替换为nothing=44827后提示and the next nothing is 45439,继续替换时提示Your hands are getting tired and the next nothing is 94485,猜测是请求发包次数的问题,回到显示图片页面,查看源码提示urllib may help. DON'T TRY ALL NOTHINGS, since it will never end. 400 times is more than enough.,尝试获取noting的值,循环发包获取答案。
import requests
import re
p = '12345'
def next_index(p):
url = 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing=%s' %p
res = requests.get(url).content
pattern = re.compile(r'\d+')
index = re.search(pattern,res).group()
return index
for i in range(1,401):
print 'the %d time' %i
p = next_index(p)
print p
运行到86次报错,访问第85次的nothing值16044,提示Yes. Divide by two and keep going.,
根据提示除以二后使用8022继续访问,提示and the next nothing is 25357,赋值p后继续运行上面的程序,运行到55次出错,访问此时结果82683,提示You've been misleaded to here. Go to previous one and check.,
根据提示继续访问上一次运行结果82682,提示There maybe misleading numbers in the text. One example is 82683. Look only for the next nothing and the next nothing is 63579,继续访问63579,提示and the next nothing is 37278,赋值p后继续运行上面的程序,运行到109次报错,使用108次的值66831继续访问,得到peak.html。
The Python Challenge 0-4的更多相关文章
- Python Challenge 过关心得(0)
最近开始用Openerp进行开发,在python语言本身上并没有什么太大的进展,于是决定利用空闲时间做一点python练习. 最终找到了这款叫做Python Challenge(http://www. ...
- python challenge第1关--NoteBook上的“乱码”
在 python challenge第0关中已经得到第1关的地址了: http://www.pythonchallenge.com/pc/def/map.html 一.观察地址栏和标签: What a ...
- Python Challenge 第四题
这一题没有显示提示语,仅仅有一幅图片,图片也看不出什么名堂,于是直接查看源代码,源代码例如以下: <html> <head> <title>follow the c ...
- The Python Challenge 谜题全解(持续更新)
Python Challenge(0-2) The Python Challengehttp://www.pythonchallenge.com/ 是个很有意思的网站,可以磨练使用python的技巧, ...
- Python Challenge 第一关
偶然在网上看到这个,PYTHON CHALLENGE,利用Python语言闯关,觉得挺有意思,就记录一下. 第0关应该算个入口吧,试了好几次才试出来,没什么代码就不写了.计算一个结果出来就行. 第一关 ...
- The Python Challenge 闯关笔记
The Python Challenge : http://www.pythonchallenge.com/ Level 0: 看提示图片中为2**38,计算值为274877906944. Hint: ...
- python 2.4 与 python 3.0 的比较
转过来,留着日后查看 [转自:]http://hi.baidu.com/autoitcn/blog/item/5f41973294b5fc4fac4b5f77.html python 2.4 与 py ...
- Python 3.0(一) 简介
Python 3.0(一) 简介 [目录] 1.简介 2.python特点 3.安装 简介: Python是可以称得上即简单又功能强大的少有的语言中的一种.你将会惊喜地发现,专注于问题的解决方案而不是 ...
- HOWTO Use Python in the web — Python v3.0.1 documentation
HOWTO Use Python in the web - Python v3.0.1 documentation mod_python¶ People coming from PHP often f ...
随机推荐
- 【Linux】【Jenkins】代码编译和执行过程中的问题汇总
1.问题1:java.io.FileNotFoundException: /root/.jenkins/workspace/Videoyi_AutoTest_Maven/config-log4j\lo ...
- 关于页面缩放时css错乱的处理方法---之一
这几天遇到一个问题,就是在做网页的时候,页面缩放时,布局就乱了,原来的样子不会跟随缩放的放大或者缩小进行改变,直接导致的后果,就是页面很难看,无法使用 之前虽然写了代码,但是一直没有注意到缩放后页面的 ...
- HTML - input(转)
自: http://www.runoob.com 标签定义及使用说明 <input> 标签规定了用户可以在其中输入数据的输入字段. <input> 元素在 <form&g ...
- laravel不能读取session
Laravel用redis存储session,论坛有讨论说关于session无法保存的问题:https://laravel-china.org/topics/13510/points-to-be-pa ...
- C#、Unity 数据类型的默认值
using System.Collections; using System.Collections.Generic; using UnityEngine; public class Main : M ...
- Sql Server数据库之事务,视图,索引
一.事务的定义 事务是一种机制,包含一组操作指令,并将所有的命令作为一个整体一起向系统提交或撤销操作请求(要么都执行,要么都不执行) 二.事务的分类 显式事务:用Begin TRANSCATION开始 ...
- Java Bug -- java.util.ConcurrentModificationException
java.util.ConcurrentModificationException at java.util.ArrayList$ArrayListIterator.next(ArrayList.ja ...
- Python设计模式 - UML - 用例图(Use Case Diagram)
简介 用例图主要是从用户的角度出发对软件产品的功能及执行者进行描述的. 用例图是从需求分析到软件交付的第一步,图示化展示参与者与参与者之间.参与者与用例之间.用例与用例之间的关系,帮助开发人员更好的理 ...
- 纯css loading动效
.loading {margin: 100px; width: 3px; height:3px; border-radius: 100%; / ...
- [leetcode]716. Max Stack 最大栈
Design a max stack that supports push, pop, top, peekMax and popMax. push(x) -- Push element x onto ...