최근에 인터넷에서 매우 흥미로운 Python 게임 정리 웹사이트를 봤습니다. 레벨은 총 33개입니다. 각 레벨에는 Python 지식을 사용하여 문제를 해결하고 다음 레벨로 들어가야 합니다. 예를 들어, 일부 레벨에서는 정규식을 사용해야 하고 일부 레벨에서는 크롤러를 사용해야 합니다.
우리는 보통 Python을 장순, 패키지, 모듈 순으로 배우는데, 배우고 나면 잊어버리기 쉽습니다. 이 웹사이트를 사용하면 Python 숙달도를 종합적으로 테스트하여 부족한 점을 확인할 수 있습니다.
이 웹사이트를 사용하는 방법에 대해 이야기해 보겠습니다.
역사적인 느낌이 나는 메인 페이지죠? 10년 넘게 운영되고 있는 페이지죠. 하지만 골동품처럼 보인다고 과소평가하지 마세요.
즐거운 시간을 보내세요. "챌린지 받기"를 클릭하여 챌린지를 시작하세요.
레벨 0은 워밍업 세션입니다.
이 레벨의 요구 사항은 URL 링크를 수정하는 것입니다. 주어진 프롬프트는 컴퓨터의 수학적 표현인 2의 38승이므로 아마도 다음을 수행해야 할 것입니다. 값을 계산한 후 URL을 수정하여 다음 레벨로 들어갑니다.
이 레벨은 Python의 기본적인 수치 연산 테스트입니다. 계산하는 방법을 알고 있나요?
Python 터미널을 열고 한 줄의 코드로 결과를 계산할 수 있습니다:
원본 링크의 0을 274877906944로 바꾸고 Enter를 눌러 다음 레벨로 들어갑니다.
게임이 공식적으로 시작됩니다. . 사진 속 노트에는 세 그룹의 글자가 있는데, 패턴을 쉽게 찾을 수 있습니다. 앞에 있는 글자가 두 자리 뒤로 이동하여 뒤의 글자가 됩니다.
그러면 해야 할 일은 이 규칙에 따라 다음 프롬프트 문자열을 해독하고 실제 문장 의미를 얻기 위해 치환 해독을 수행하는 것입니다.
이 질문은 문자열 인코딩 및 for 루프와 관련된 지식을 테스트합니다. 코드는 다음과 같이 구현됩니다. 다음과 같습니다.
text = '''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.''' text_translate = '' for i in text: if str.isalpha(i): n = ord(i) if i >= 'y': n = ord(i) + 2 - 26 else: n = ord(i) + 2 text_translate += chr(n) else: text_translate += i print(text_translate)
결과 얻기:
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.
물론, 문제를 해결하려면 string.maketrans()를 사용하는 것이 좋습니다. 는 더 직접적인 방법이고 공식적인 방법은 더 간소화된 방법을 제공합니다:
import string l = string.lowercase t = string.maketrans(l, l[2:] + l[:2]) print (text.translate(t))
그런 다음 URL의 지도를 ocr로 변경하고 Enter를 눌러 두 번째 수준에 도달합니다.
저자는 계속해서 다음과 같이 말했습니다. 레벨 에 대한 팁은 책에 있거나(물론 불가능합니다) 웹 페이지의 소스 코드에 있을 수 있습니다. 그런 다음 마우스 오른쪽 버튼을 클릭하여 소스 코드를 보고 아래로 스크롤하여 녹색 영역을 확인합니다. 물론 문제를 발견했습니다.
즉, 다음과 같은 큰 문자열에서 가장 적은 문자를 찾으세요
다음 몇 가지 지식 포인트를 검토했습니다.
문자열을 추출하는 정규식
목록 계산
조건문
당신이라면 어떻게 하시겠습니까?
빠르게 구현할 10줄의 코드를 살펴보겠습니다.
import requests url = 'http://www.pythonchallenge.com/pc/def/ocr.html' res = requests.get(url).text text = re.findall('.*?<!--.*-->.*<!--(.*)-->',res,re.S) # list转为str便于遍历字符 str = ''.join(text) lst = [] key=[] #遍历字符 for i in str: #将字符存到list中 lst.append(i) #如果字符是唯一的,则添加进key if i not in key: key.append(i) # 将list列表中的字符出现字数统计出来 for items in key: print(items,lst.count(items))
먼저 요청을 사용하여 웹페이지를 요청한 다음 정규식을 사용하여 문자열을 추출한 다음 for 루프를 사용하여 각 캐릭터.
% 6104 $ 6046 @ 6157 _ 6112 ^ 6030 # 6115 ) 6186 & 6043 ! 6079 + 6066 ] 6152 * 6034 } 6105 [ 6108 ( 6154 { 6046 e 1 q 1 u 1 a 1 l 1 i 1 t 1 y 1
마지막 몇 글자가 가장 적게 나타나는 것을 볼 수 있는데, 이는 함께 "평등"을 의미합니다. URL 문자를 바꾸면 두 번째 레벨을 통과하고 다음 레벨로 진입하여 챌린지를 계속할 수 있습니다. 흥미롭지 않나요?
다음의 각 레벨에서는 레벨 4와 같은 문제를 해결하기 위해 관련 Python 기술을 사용해야 합니다.
이 레벨의 작성자는 URL에 값을 수동으로 입력하고 Enter 키를 눌러야 합니다. .끝난 것 같아? 끝없이 입력해야 할 새로운 값이 끊임없이 나타나는 것은 아닙니다.
所以,这一关肯定不能采取手动输入的方法闯关,自然要用到 Python 了。要实现自动填充修改 url 回车跳转到新 url,循环直到网页再也无法跳转为止这一功能。
如果是你,你会怎么做?
其实,一段简单的爬虫加正则就能搞定。思路很简单,把每次网页中的数值提取出来替换成新的 url 再请求网页,循环下去,代码实现如下:
import requests import re import os # 首页url resp = requests.get( 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing=12345').text url = 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing=' # 计数器 count = 0 while True: try: # 提取下一页动态数值 nextid = re.search('\d+', resp).group() count = count + 1 nextid = int(nextid) except: print('最后一个url为:%s' % nexturl) break # 获取下一页url nexturl = url + str(nextid) print('url %s:%s' % (count, nexturl)) # 重复请求 resp = requests.get(nexturl).text
输出结果如下:
可以看到,最终循环了 85 次找到了最后一个数字16044,输入到 url 中就闯关成功。
如果遇到不会做的题,可以在这里找到参考答案:
中参考文教程:
https://www.cnblogs.com/jimnox/archive/2009/12/08/tips-to-python-challenge.html
官方参考教程:
http://garethrees.org/2007/05/07/python-challenge/
위 내용은 게임 플레이를 통해 Python 숙달도 테스트의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!