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 = ''
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)的更多相关文章
- the python challenge闯关记录(0-8)
0 第零关 2**38 = 274877906944 下一关的url:http://www.pythonchallenge.com/pc/def/274877906944.html 1 第一关 移位计 ...
- The Python Challenge 闯关笔记
The Python Challenge : http://www.pythonchallenge.com/ Level 0: 看提示图片中为2**38,计算值为274877906944. Hint: ...
- Python Challenge 第一关
偶然在网上看到这个,PYTHON CHALLENGE,利用Python语言闯关,觉得挺有意思,就记录一下. 第0关应该算个入口吧,试了好几次才试出来,没什么代码就不写了.计算一个结果出来就行. 第一关 ...
- THEPYTHONCHALLENG闯关记录
由于是自己看视频学python,总觉得不写几行代码就什么都没有学到. 找了一个写代码的网站其实只是因为这个看起来好玩. 闯关地址http://www.pythonchallenge.com/index ...
- Python 爬虫闯关(第一关)
在学习爬虫时,遇到了一个有意思的网站,这个网站设置了几个关卡,需要经过爬虫进行闯关,随着关卡的网后,难度不断增加,在闯关的过程中需要学习不同的知识,你的爬虫水平也自然随之提高. 今天我们先来第一关,访 ...
- python函数编程闯关总结
文件处理相关 1,编码问题 (1)请问python2与python3中的默认编码是什么? python .x默认的字符编码是ASCII,默认的文件编码也是ASCII python .x默认的字符编码是 ...
- Python Challenge 第九关
第九关只有一幅图,上面有一些黑点.网页名字叫:connect the dots.可能是要把这些点连起来. 查看源代码,果然有两个整数集合 first 和 second.并且有个提示:first+sec ...
- Python Challenge 第二关
第二关和第一关一样,还是一幅图和一行提示.提示说的是: recognize the characters. maybe they are in the book, but MAYBE they are ...
- Python基础闯关失败总结
对列表进行创建切片增删改查 对列表进行创建 L1 = [] # 定义L1 为一个空列表 List() #创建List 空列表 对列表进行查询 L2 = ['a','b','c','d','a','e ...
随机推荐
- 时分秒计时器 js
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Linux密码重置
在启动菜单选择启动内核: 按e编辑,编辑修改两处:ro改为rw,和找到rhgb quiet一行: 把rhgb quiet替换为init=/bin/bash(临时生效): 按CTRL+X进入单用户模式: ...
- Eclipse使用技巧 - 2. Eclipse自动补全功能轻松设置
本文介绍如何设置Eclipse代码自动补全功能.轻松实现输入任意字母均可出现代码补全提示框. Eclipse代码自动补全功能默认只包括 点”.” ,即只有输入”.”后才出现自动补全的提示框.想要自动补 ...
- 方法总结:如何实现html页面自动刷新
使用场景: 1. 页面需要定时刷新,实时加载数据,需要实时查看监控数据(H5中的WebSocket和SSE可以实现局部刷新) 2. 一定时间之后跳转到指定页面(登录注册之类) 3. 前端开发使用伪数据 ...
- 为什么MySQL数据库要用B+树存储索引?
小史:树的话,无非就是前中后序遍历.二叉树.二叉搜索树.平衡二叉树,更高级一点的有红黑树.B 树.B+ 树,还有之前你教我的字典树. 红黑树 一听到红黑树,小史头都大了,开始抱怨了起来. 小史:红黑树 ...
- python全栈开发day117-MongoDB,pymongo
1.MongoDB操作 使用了不存在的对象即创建该对象 1.增加: 官方不推荐写法: insert([{},{},{}]) 官方推荐写法: insertOne({}) insertMany([{},{ ...
- SQL反模式学习笔记4 建立主键规范【需要ID】
目标:建立主键规范 反模式:每个数据库中的表都需要一个伪主键Id 在表中,需要引入一个对于表的域模型无意义的新列来存储一个伪值,这一列被用作这张表的主键, 从而通过它来确定表中的一条记录,即便其他的列 ...
- 基于ASP.NET MVC 下的Extjs的Combbox加载速率问题,终于解决啦:)
在实际的开发项目中,自己遇到一个让自己苦恼很久的问题,一直也未解决,先简单介绍一下这个问题吧.当在表单里有多个combbox的时候(表单中的combbox是经过封装的控件,从后台请求同一个方法获取数据 ...
- CF 552 Neko does Maths
给出两个数a,b 求k 使得 a+k b+k有最小公倍数 a,b同时加上一个非负整数k,使得,a+k,b+k的最小公倍数最小 因为最小公公倍数=x*y / gcd(x,y),所以肯定离不开最大 ...
- python将多个pdf合成一个
'''# -*- coding:utf-8*-''' import sys import importlib importlib.reload(sys) import os import os.pat ...