转眼间又一个月没有逛博客园,明显的感觉到自己的代码能力变弱,前两周搞项目去了,只是形式上面的答辩而已,并没有涉及到代码层面,也就玩了一下验证码,没有识别玩出校器网页的验证码;转眼间又是各种考试,所幸,考试进入尾声,今天可以玩玩pythonchanllenge,一周没继续闯关,明显感觉到自己的智商余额不足,直接上题:
http://www.pythonchallenge.com/pc/def/oxygen.html
进入这个题目,只有一张图片,源码里面的信息只给了网页的title是"smarty",图片的名字叫氧气——“oxygen.png”。那么只能在图片里面找信息,图片的内容是一条河,河边是草木,值得注意的是,图片中间有一段灰色区域,初步估计信息隐藏在这个马赛克区域内。
首先,利用画图工具可得出该图片的像素是:629*95,再将这段马赛克区域的坐标提取出来:
横坐标的范围是:0-609,纵坐标的范围是:43-53。
其次,利用python的Image模块得到里面的像素列表:
1 from PIL import Image 2 3 4 def ques_7(img): 5 data = [img.getpixel((i, j)) for i in range(0, 609) for j in range(43, 53)] # 横坐标在0-609中变动,纵坐标在43-53内变动 6 print data 7 8 png = Image.open("C:\Users\wing1995\Desktop\oxygen.png", 'r') 9 ques_7(png)
输出结果如下:
[(115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (115, 115, 115, 255), (98, 127, 47, 255)................
根据上述结果可知,输出的像素是一个有着4个元素的元祖列表,其中每个元组里面的第四个元素都是255,并且每个元祖重复7次,那么如何将这些输出结果与答案联系?一般情况,答案的链接都是英文字母,那么可以尝试使用函数`chr`把这些ASCII码转换为字母。
第二次改进的代码
1 def ques_7(img): 2 data = [chr(img.getpixel((i, j))[0]) for i in range(0, 609, 7) for j in range(43, 53, 7)] # 横坐标在0-609中变动,纵坐标在43-53内变动 3 print ''.join(data)
输出结果如下:
ssmmaarrtt gguuyy,, yyoouu mmaaddee iitt.. tthhee nneexxtt lleevveell iiss [[110055,, 111100,, 111166,, 110011,, 110033,, 111144,, 110055,, 111166,, 112211]]
嘿嘿,很明显,除去重复的字母,最后的样子显现出来。
smart guy, you made it. the next level is [105, 110, 116, 101, 103, 114, 105, 116, 121]
那么,数据就是列表[105, 110, 116, 101, 103, 114, 105, 116, 121]隐含的信息,继续将该数组中的数转化为字母,得到的单词为:integrity。
下一关的网址为:http://www.pythonchallenge.com/pc/def/integrity.html