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 ...
随机推荐
- django 补充和中间件
配置 from django.conf import settings form组件 from django.forms import Formfrom django.forms import fie ...
- Hibernate工作原理及为什么要用?
1.原理: 1.读取并解析配置文件 new Configuration().configure()2.读取并解析映射信息,创建SessionFactory sf=buildSessionF ...
- python 爬虫启航2.0
文章解析: 1.正则表达式解析 2.beautifulsoup,BeautifulSoup是一个复杂的树形结构,她的每一个节点都是一个python对象,获取网页的内容就是一个提取对象内容的过程,它的提 ...
- 生活实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决?
2018-01-02 实遇记-Kindle好久没用,屏幕一直处于电池状态,怎么解决? 今天我翻腾出自己的kindle,好久没用了,屏幕一直是一个电池状态,充电头+线充了2个钟头,按电源键木有反应,也是 ...
- js方法用来获取路径传参上所带的参数
//js方法用来获取路径传参上所带的参数 function GetQueryString(param) { var reg = new RegExp("(^|&)" + p ...
- java.io.Flushable 接口
package java.io; import java.io.IOException; /** * 在什么情况下用呢? 缓冲输出到一个流中的情况下,这个流要刷新. */ public interfa ...
- ucore-lab1-练习5report
实验5--实现函数调用堆栈跟踪函数 需要完成kdebug.c中函数print_stackframe的实现,可以通过函数print_stackframe来跟踪函数调用堆栈中记录的返回地址. 一.函数堆栈 ...
- NTFS(Windows)、ext4(RHEL6)和xfs(RHEL7)文件系统的误删除恢复和备份
前言 对于误删除文件的设备,要马上停止任何写的操作,防止删除的文件被覆盖,导致数据丢失! 恢复NTFS文件系统下误删的文件 以Windows为例,市面上能恢复的工具不少,例如EasyRecovery. ...
- Eclipse 创建Android 模拟器失败:no cpu/abi system image available for this target
(从网上搜了一个使用Android 4.4 API 20编译的图片) 这是因为SDK中没有模拟器使用的操作系统镜像. 如果项目使用API 19编译,则SDK中的system-images文件夹下,需要 ...
- 回忆Partition算法及利用Partition进行快排
一.Partiton算法 Partiton算法的主要内容就是随机选出一个数,将这个数作为中间数,将大于它的排在它右边,小于的排在左边(无序的). int partition (int arr[],in ...