the python challenge闯关记录(9-16)

Posted 噼里巴啦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了the python challenge闯关记录(9-16)相关的知识,希望对你有一定的参考价值。

9 第九关

 是一张图,上面有很多的黑点,查看网页源代码发现了上一关的提示:

还发现了一大串的数字

感觉又是一个使用PIL库进行图像处理的题,百度后知道要将这些点连接起来并重新画图。但是不能在原始图上修改,我们应该重新画图并进行修改。

编写代码:

from PIL import Image

def main(three):
    img = Image.open(\'good.jpg\')
    # 利用img的模式和大小创建新图片
    img1 = Image.new(img.mode, img.size)
    # 两两为一个像素位置
    positions = []
    for i in range(0, len(three), 2):
        position = (three[i], three[i+1])
        positions.append(position)
    for j in positions:
        img1.putpixel(j, (255, 255, 255))
    img1.show()
    
if __name__ == \'__main__\':
    first = [146,399,163,403,170,393,169,391,166,386,170,381,170,371,170,355,169,346,167,335,170,329,170,320,170,
310,171,301,173,290,178,289,182,287,188,286,190,286,192,291,194,296,195,305,194,307,191,312,190,316,
190,321,192,331,193,338,196,341,197,346,199,352,198,360,197,366,197,373,196,380,197,383,196,387,192,
389,191,392,190,396,189,400,194,401,201,402,208,403,213,402,216,401,219,397,219,393,216,390,215,385,
215,379,213,373,213,365,212,360,210,353,210,347,212,338,213,329,214,319,215,311,215,306,216,296,218,
290,221,283,225,282,233,284,238,287,243,290,250,291,255,294,261,293,265,291,271,291,273,289,278,287,
279,285,281,280,284,278,284,276,287,277,289,283,291,286,294,291,296,295,299,300,301,304,304,320,305,
327,306,332,307,341,306,349,303,354,301,364,301,371,297,375,292,384,291,386,302,393,324,391,333,387,
328,375,329,367,329,353,330,341,331,328,336,319,338,310,341,304,341,285,341,278,343,269,344,262,346,
259,346,251,349,259,349,264,349,273,349,280,349,288,349,295,349,298,354,293,356,286,354,279,352,268,
352,257,351,249,350,234,351,211,352,197,354,185,353,171,351,154,348,147,342,137,339,132,330,122,327,
120,314,116,304,117,293,118,284,118,281,122,275,128,265,129,257,131,244,133,239,134,228,136,221,137,
214,138,209,135,201,132,192,130,184,131,175,129,170,131,159,134,157,134,160,130,170,125,176,114,176,
102,173,103,172,108,171,111,163,115,156,116,149,117,142,116,136,115,129,115,124,115,120,115,115,117,
113,120,109,122,102,122,100,121,95,121,89,115,87,110,82,109,84,118,89,123,93,129,100,130,108,132,110,
133,110,136,107,138,105,140,95,138,86,141,79,149,77,155,81,162,90,165,97,167,99,171,109,171,107,161,
111,156,113,170,115,185,118,208,117,223,121,239,128,251,133,259,136,266,139,276,143,290,148,310,151,
332,155,348,156,353,153,366,149,379,147,394,146,399]
    second = [156,141,165,135,169,131,176,130,187,134,191,140,191,146,186,150,179,155,175,157,168,157,163,157,159,
157,158,164,159,175,159,181,157,191,154,197,153,205,153,210,152,212,147,215,146,218,143,220,132,220,
125,217,119,209,116,196,115,185,114,172,114,167,112,161,109,165,107,170,99,171,97,167,89,164,81,162,
77,155,81,148,87,140,96,138,105,141,110,136,111,126,113,129,118,117,128,114,137,115,146,114,155,115,
158,121,157,128,156,134,157,136,156,136]
    main(first+second)

得到图像:

图像上是个牛,就是英文的bull

那么第十关的url为:http://www.pythonchallenge.com/pc/return/bull.html

10 第十关

看标题好像是求len(a[30])是多少,查看网页源代码

发现一大串数据,并且发现一个txt文件

点开后发现是一个列表

百度后才知道含义

11— 表示前一个数“1”是 1 个 1;
21— 表示前一个数“11”是 由 2 个 1 组成;
1211— 表示前一个数“21”是 由 1 个 2、1 个 1 组成;
111221— 即 11 12 21 ,表示前一个数“1211”是依次由 1 个 1,1 个 2,
2 个 1组成;

那么后一组的数据就会是312211

于是编写程序求解低30位是什么元素:

def main():
    # 申请2个字符串,一个为1,一个为空,a是用来存放数据的
    a = \'1\'
    sub1 = \'\'
    for i in range(30):
        j = k = 0
        while j <len(a):
            while k < len(a) and a[k] == a[j]:
                k += 1
            sub1 += str(k-j) + a[j]
            j = k
        a = sub1
        sub1 = \'\'
    print(len(a))

if __name__ == \'__main__\':
    main()

得到答案:

所以低11关的url是:http://www.pythonchallenge.com/pc/return/5808.html

 11 第十一关

查看网页源代码

标题叫做奇偶,应该和图像处理有关,修改制定位置的像素,我们把图片下载到本地,修改奇数位置的像素:

from PIL import Image

im = Image.open(\'cave.jpg\')
odd = Image.new(im.mode, (im.size[0], im.size[1]))
for x in range(1, im.size[0], 2):
    for y in range(1, im.size[1], 2):
        odd.putpixel(((x-1),(y-1)),im.getpixel((x, y)))
odd.show()

得到结果:

有个单词evil,试了下

则12关的url是:http://www.pythonchallenge.com/pc/return/evil.html

如果要求输入账号密码,还是输入 huge file

12 第十二关

这题的源代码也没有任何提示,估计又是和图像梳理有关

发现图形的url为:http://www.pythonchallenge.com/pc/return/evil1.jpg

试着把evil1改为evil2,出现

图上说not jpg 而是 gfx,于是后缀修改为gfx,自动就把gfx文件下载下来了

将evil2修改为evil3出现

看来关键点就在下载下的evil.gfx文件

evil1图上是把扑克分成了5份,于是我们把evil.gfx文件也分成5份,evil.gfx的第一个字节给第一个文件,第二个字节给第二个文件,第三个字节给第三个文件,第四个字节给第四个文件,第五个字节给第五个文件,第六个字节给第一个文件,第七个字节给第二个文件……

编写代码:

with open(\'evil2.gfx\', \'rb\') as f:
    data = f.read()
for i in range(5):
    with open(\'evil%d.jpg\'%i, \'wb\') as f1:
        f1.write(data[i::5])

得到五张图:

连起来的单词是:disproportional

所以第13关的url是:http://www.pythonchallenge.com/pc/return/disproportional.html

13 第十三关

查看网页源代码

点击php文件,发现提示信息

百度得到提示 是使用xmlrpclib,即xml的远程方法调用(https://www.jb51.net/article/44515.htm

import xmlrpc.client

s = xmlrpc.client.ServerProxy(\'http://www.pythonchallenge.com/pc/phonebook.php\')
print(s.system.listMethods())

得到输出:

看到有个phone方法,于是修改代码:

由上题的提示得知,这个恶魔的名字叫Bert,必须在ie浏览器打开

import xmlrpc.client

s = xmlrpc.client.ServerProxy(\'http://www.pythonchallenge.com/pc/phonebook.php\')
print(s.system.methodHelp(\'phone\'))
print(s.phone(\'Bert\'))

得到答案:

第14关的url是:http://www.pythonchallenge.com/pc/return/italy.html

14 第十四关

 

打开网页源代码

发现提示提多的:

  1 walk around

  2 remember: 100*100 = (100+99+99+98) + (...

  3 有个图片wire.png

from PIL import Image

im = Image.open(\'wire.png\')
print(im.size)

则它的像素为:(10000, 1)

那么这道题要做的是将10000*1的图像改成100*100的图像,像绕圈圈一样,先向右走100步,然后再向下走99步,再向左走99步,再向上走98步。典型的蛇形矩阵

from PIL import Image

im = Image.open(\'wire.png\')
im1 = Image.new(im.mode, (100, 100))
# 代表四个方向 right down left up
direction = [(1, 0), (0, 1), (-1, 0), (0, -1)]
# 初始位置
x , y = -1 ,0
k = 0
# 100*100 = [[100, 99, 99, 98],[98, 97, 97, 96]]...应该有200个元素,
steps = 200
while steps/2>0:
    # 做一圈的迭代
    for vector in direction:
        step = steps//2
        for i in range(step):
            x = x + vector[0]
            y = y + vector[1]
            pixel = im.getpixel((k, 0))
            im1.putpixel((x, y), pixel)
            k += 1
        steps -= 1
im1.show()

得到一个图像:

是个猫。对应的英文应该是cat.

第14关的url为:http://www.pythonchallenge.com/pc/return/cat.html

输入发现是张图,有提示:

所以第14关的url应该为:http://www.pythonchallenge.com/pc/return/uzi.html

15 第十五关

 

有一张日历图,仔细看26号这天是被圈出来的

查看网页源代码

 收到了2个提示:

  1 他不是最年轻的吗,他是第二位的

  2 要做的事,为了明天买花

再看日历右下角,二月有29号,所以这一年是闰年。需要我们求出闰年时,1月27号是星期二的日期。

于是编写代码:

import datetime
import calendar

for year in range(1800, 2000):
    t = datetime.date(year,1,27)
    if calendar.isleap(year) and t.weekday() == 1:
        print(t)

得到结果:

百度出1756-1-27莫扎特出生

所以答案是:mozart

第十六关的url是:http://www.pythonchallenge.com/pc/return/mozart.html

16 第十六关

查看网页源代码:

上面的语句意思是让我们做吧,是句俚语

打印每行像素的值,我们发现每行像素都有连续5个195的值

我们以195为基准位置,反转一下色素,得到新的图片

编写程序:

from PIL import Image

im = Image.open(\'mozart.gif\')
widt, heig = im.size
for y in range(heig):
    line = [im.getpixel((x,y)) for x in range(widt)]
    idx = line.index(195)
    lines = line[idx:] + line[:idx]
    for x in range(widt):
        im.putpixel((x, y), lines[x])
im.show()

 得到图片:

 

第17关的url为:http://www.pythonchallenge.com/pc/return/romance.html

 

以上是关于the python challenge闯关记录(9-16)的主要内容,如果未能解决你的问题,请参考以下文章

Python challenge通关代码及攻略(0-7)

pythonchallenge闯关 第0题

pythonchallenge闯关 第1题

pythonchallenge闯关 第3题

pythonchallenge闯关 第9题

pythonchallenge闯关 第2题