0. 2的38次方

 print 2**38
 ##apply the result to the url

1. 看图是要right shift两位, 切片即可。

 import string

 intab = string.ascii_lowercase
 outtab = intab[2:] + intab[:2]
 trans_table = string.maketrans(intab, outtab)

 s = """
     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."""

 print s.translate(trans_table)
 print 'map'.translate(trans_table)

 ##The result is
 ##
 ##    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.
 ##ocr

 ##apply ocr to the url

2. 寻找出现次数少的character

 import string

 result = {}
 text = open('003help.txt').read()
 for ch in text:
     result[ch] = result.get(ch, 0) + 1

 print result
 print ''.join(ch for ch in result if result[ch]==1)
 s = []
 for i in text:
     if i in string.ascii_lowercase:
         s.append(i)
 print ''.join(s)

 ##apply 'equality' to the url

3. One small letter, surrounded by EXACTLY three big bodyguards on each of its sides. 正则表达式!

import re

pattern = re.compile('[^A-Z][A-Z]{3}([a-z])[A-Z]{3}[^A-Z]')
text = open('004help.txt').read()

t = re.findall(pattern, text)
print ''.join(t)

##apply to the url

4. follow the chain. 还是回到网页源代码,发现linkedlist.php?nothing=12345,替代linkedlist.php然后得到the next nothing is  .其实就是从这个网页中提取nothing后面的数字替换,作者说不超过400次,加一个for循环,如下:

 import re
 import urllib

 url = 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing='
 nothing = '
 pattern = re.compile(r'and the next nothing is (\d+)')
 for i in range(400):
     try:
         text = urllib.urlopen(url+nothing).read()
         nothing = pattern.findall(text)[0]
         print nothing
     except Exception, e:
         print e
         break
 print text

中间又一次exception,16044,让除以2,改成8022,继续,最后得到peak.html。

5. pronounce it. 读了好长时间,也没有神奇的事情发生,后来bing了才知道peakhell --> pickle. 也在我学识浅薄,没学习过这个模块。查了一下pickle的文档,这是一个python对象序列化的模块,感觉很抽象,好在api不复杂,页面源码提供了peakhell src,就是那个banner.p下载下来之后,用loads函数进行处理,下面是loads函数的说明(注意,不是load()):

pickle.loads(string)
Read a pickled object hierarchy from a string. Characters in the string past the pickled object’s representation are ignored.

 #cPickle是c语言实现的pickle模块
 import cPickle as pickle

 t = open('banner.p').read()
 s = pickle.loads(t)
 print s

结果是一个list,研究了半天只知道列和95(小学生思维)。这下更摸不着头脑了,只好__人有两件宝,双手和电脑__去搜索答案了。Amazing!

 for line in s:
     print ''.join(map(lambda pair: pair[0]*pair[1], line))

try it, try it! 不禁让我想到linuxlogo,这种ascii图还很养眼。

不过,前方的路坎坷又长

6. zip, 没有其他提示了,替换html,发现下载了channel.zip的文件,打开readme.txt,发现第一条提示类似前面的问题,又得到collect the comments,修改了re部分,发现没结果,后来百度才知道是有关zipfile这个module的。实现也不是很难:

 import re
 import os
 import zipfile

 def find_next():
     comments = []
     prefix = '
     suffix = '.txt'
     pattern = re.compile(r'\D+(\d+)')
     z = zipfile.ZipFile('/home/zhangqi/channel.zip', mode='r')
     while True:
         try:
             filename = 'channel/' + prefix + suffix
             text = open(filename).read()
             prefix = pattern.findall(text)[0]
             print prefix
             comments.append(z.getinfo(prefix + suffix).comment)

         except Exception, e:
             print e
             break

     print ''.join(comments)

 find_next()
 #it's in the air. look at the letters.

最后看组成hockey的字母,连环trick有木有!

stay tuned...

Python Challenge的更多相关文章

  1. python challenge第1关--NoteBook上的“乱码”

    在 python challenge第0关中已经得到第1关的地址了: http://www.pythonchallenge.com/pc/def/map.html 一.观察地址栏和标签: What a ...

  2. Python Challenge 过关心得(0)

    最近开始用Openerp进行开发,在python语言本身上并没有什么太大的进展,于是决定利用空闲时间做一点python练习. 最终找到了这款叫做Python Challenge(http://www. ...

  3. Python Challenge 第四题

    这一题没有显示提示语,仅仅有一幅图片,图片也看不出什么名堂,于是直接查看源代码,源代码例如以下: <html> <head> <title>follow the c ...

  4. The Python Challenge 谜题全解(持续更新)

    Python Challenge(0-2) The Python Challengehttp://www.pythonchallenge.com/ 是个很有意思的网站,可以磨练使用python的技巧, ...

  5. The Python Challenge 0-4

    The Python Challenge 0-4 项目地址:http://www.pythonchallenge.com/ Level-0 提示Hint: try to change the URL ...

  6. python challenge答案参考

    Solutions to python challenge. http://garethrees.org/2007/05/07/python-challenge/ https://github.com ...

  7. Python Challenge 第一关

    偶然在网上看到这个,PYTHON CHALLENGE,利用Python语言闯关,觉得挺有意思,就记录一下. 第0关应该算个入口吧,试了好几次才试出来,没什么代码就不写了.计算一个结果出来就行. 第一关 ...

  8. The Python Challenge 闯关笔记

    The Python Challenge : http://www.pythonchallenge.com/ Level 0: 看提示图片中为2**38,计算值为274877906944. Hint: ...

  9. Python Challenge 过关心得(1)

    正式开始第1关,这一关的URL的特殊部分是map. 这关的图片上有一个本子,上面写着K→M,O→Q,E→G,稍微思索就能发现这几个字母都是按照字母表的顺序向后移动了两位,那么最投机取巧的方法就是把ma ...

随机推荐

  1. OC准备知识

    #import 与 #include区别 include完成头文件的导入,可能会导致头文件的相互引用和函数或变量的重复定义 为了解决这个问题 我们必须这样做 #ifndef Student_h #de ...

  2. 005 列表以及append,extend方法

    定义一个列表: number=[,'changhao','常浩',5.2] 往这个列表里面添加单一新值(类型无限制),需要使用append方法. 例如: number.append() number. ...

  3. php不区分大小写

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. 工具使用 eclipse the user operation is waiting for Building Working to be completed。

    问题定位: 在使用 IDE开发时,学习一个新事物如语言,框架,出现错误时暂时无法判断是新写的代码错还是IDE使用错: 则编写简单的未使用该技术的test.java ,运行后还有异常出现,则不是代码问题 ...

  5. ubuntu安装体验

    本文记录一下昨晚及今天安装ubuntu系统的过程及体验 2016年6月13日09:36:11 更新 今天才有发现原来自己有个没填的坑 = = 那次安乌班图后第一感觉是很好用,新鲜了好几天,但是很快,新 ...

  6. js 跨域的使用

    try{document.domain="jincin.com"}catch(error){} 需要在被调用的函数和调用函数出都要加入上面相同的语句 下面看一下第二种跨域的解决方案 ...

  7. Git学习01 --git add, git commit , git log ,git status, git reset --hard, head

    Git官方提供的快速入门教程:https://try.github.io/levels/1/challenges/1 特点:Git极其强大的分支管理:分布式版本 集中式版本控制系统,版本库是集中存放在 ...

  8. android keytool 不是内部命令或外部命令在 (win7下不能用的解决方法)

    android 关于MD5指纹中 keytool在win7下不能用的解决方法 只要在cmd中执行如下命令即可:注意C:\Users\Administrator\.android\debug.keyst ...

  9. Servlet中Web.xml的配置详解

    1 定义头和根元素 部署描述符文件就像所有XML文件一样,必须以一个XML头开始.这个头声明可以使用的XML版本并给出文件的字符编码. DOCYTPE声明必须立即出现在此头之后.这个声明告诉服务器适用 ...

  10. 【HDU 4786 Fibonacci Tree】最小生成树

    一个由n个顶点m条边(可能有重边)构成的无向图(可能不连通),每条边的权值不是0就是1. 给出n.m和每条边的权值,问是否存在生成树,其边权值和为fibonacci数集合{1,2,3,5,8...}中 ...