2013-08-31 5 views
2

for 루프 중 하나가 어떻게 Hard Way ex.41에서 Python을 배우는지 이해하는 데 어려움이 있습니다. http://learnpythonthehardway.org/book/ex41.html 아래는 수업의 코드입니다.어려운 방법으로 파이썬 배우기 Ex.41 For 루프에 대해

내가 혼란스러워하는 루프는 for i in range(0, snippet.count("@@@")): 0의 스 니펫 (6 개 스 니펫이 있음)을 반복하고 "@@@"의 카운트의 추가 값을 추가합니까? 따라서 다음 줄의 코드 param_count = random.randint(1,3)에 대해 "@@@"의 추가 값이 적용됩니까? 또는 나는 떨어져있다!?

건배 대런

import random 
from urllib import urlopen 
import sys 

WORD_URL = "http://learncodethehardway.org/words.txt" 
WORDS = [] 

PHRASES = { 
    "class %%%(%%%):": 
     "Make a class named %%% that is-a %%%.", 
    "class %%%(object):\n\tdef __init__(self, ***)" : 
     "class %%% has-a __init__ that takes self and *** parameters.", 
    "class %%%(object):\n\tdef ***(self, @@@)": 
     "class %%% has-a function named *** that takes self and @@@ parameters.", 
    "*** = %%%()": 
     "Set *** to an instance of class %%%.", 
    "***.***(@@@)": 
     "From *** get the *** function, and call it with parameters self, @@@.", 
    "***.*** = '***'": 
     "From *** get the *** attribute and set it to '***'." 
} 

# do they want to drill phrases first 
PHRASE_FIRST = False 
if len(sys.argv) == 2 and sys.argv[1] == "english": 
    PHRASE_FIRST = True 

# load up the words from the website 
for word in urlopen(WORD_URL).readlines(): 
    WORDS.append(word.strip()) 


def convert(snippet, phrase): 
    class_names = [w.capitalize() for w in 
        random.sample(WORDS, snippet.count("%%%"))] 
    other_names = random.sample(WORDS, snippet.count("***")) 
    results = [] 
    param_names = [] 

    for i in range(0, snippet.count("@@@")): 
     param_count = random.randint(1,3) 
     param_names.append(', '.join(random.sample(WORDS, param_count))) 

    for sentence in snippet, phrase: 
     result = sentence[:] 

     # fake class names 
     for word in class_names: 
      result = result.replace("%%%", word, 1) 

     # fake other names 
     for word in other_names: 
      result = result.replace("***", word, 1) 

     # fake parameter lists 
     for word in param_names: 
      result = result.replace("@@@", word, 1) 

     results.append(result) 

    return results 


# keep going until they hit CTRL-D 
try: 
    while True: 
     snippets = PHRASES.keys() 
     random.shuffle(snippets) 

     for snippet in snippets: 
      phrase = PHRASES[snippet] 
      question, answer = convert(snippet, phrase) 
      if PHRASE_FIRST: 
       question, answer = answer, question 

      print question 

      raw_input("> ") 
      print "ANSWER: %s\n\n" % answer 
except EOFError: 
    print "\nBye" 

답변

3

snippet.count("@@@")"@@@"snippet에 나타나는 횟수를 반환합니다. "@@@" 6.

+0

덕분에 @Omar Abdeldayem, 바라건대 당신은 내가 조금 더 명확하게 도움이 될 수 있습니다 : 이것은 좋은 디버거없이 디버깅 방법입니다. 그래서''@@@ ''이 3 번 나타납니다. 첫 번째 반복에서'param_count = random.randint (1,3)'코드의 다음 줄에서 임의의 정수'2 '를 얻을 수 있다고 가정 해 봅시다. 그런 다음 다음 줄의 코드'param_names.append (','.join (random.sample (WORDS, param_count))) '는 임의의 단어가'사과 '와'치즈 '라고 말할 수 있습니다. 'param_names = []'리스트에 추가 된 첫번째 항목은'[ ', apple, cheese']'일까요? 그 다음에는 3 번 반복이 목록에 추가됩니다. 유감스럽게도이 코드가 전체 코드에서 어떻게 작동하는지 확신하지 못했습니다. –

+0

이전 주석에서 코드의 한 섹션을 제대로 끝내지 않았습니다. 나는 param_names.append (','.join (random.sample (WORDS, param_count)))'의 끝에 백틱을 두지 않았다. 실수로 하나의 qoute를 실수로 넣었고 코드 섹션을 제대로 끝내지 않았다. –

+0

그래, 네가 말한 건 모두 옳은 것 같아. 'param_names []'리스트가 빌드되면'snippet'의 모든 "@@@"인스턴스는'param_names []'의 이름으로 대체됩니다. 코드를 이해하는 데 도움이 필요하면 알려주십시오. –

0

0에서 6 다음 회의에 대한 루프 반복을 표시

경우 블록 내부 루프 "진정한 동안"사용자 히트

^D.

때까지 프로그램을 실행 "을 제외하고 시도" "try"는 PHRASES 이력서의 키 목록을 미리보기로 저장합니다. 키 순서는 매번 다릅니다 (셔플 방식 때문). "for loop"안에 "While loop"는 각 스 니펫을 거쳐 해당 스 니펫의 키와 값에 대한 변환 메소드를 호출하는 것입니다.

모두 "변환 방법"은 해당 키와 값의 %%%, *** 및 @@@을 URL 목록의 임의 단어로 바꾸고 목록을 반환합니다 (결과)는 두 개 문자열 : 하나는 키로 만들고 하나는 값으로 만듭니다.

그런 다음 프로그램은 문자열 중 하나를 질문으로 인쇄 한 다음 raw_input (">")을 사용하여 사용자 입력을 가져 오지만 사용자가 입력 한 내용과 상관없이 다른 반환 된 문자열을 대답으로 인쇄합니다.

변환 방법 내부에는 class_names, other_names 및 param_names의 세 가지 목록이 있습니다. class_names를 만들기 위해, 프로그램은 %%%의 수를 그 키 또는 값과 비교합니다 (그러나 어쨌든 %%%와 같은 수입니다). class_names는 %%%의 카운트 크기의 임의의 단어 목록입니다.

other_names는 임의의 단어 목록입니다. 몇 마디입니까? (또는 어떤 값이든 상관 없습니다.)

param_names는 @@@의 크기로 된 문자열 목록입니다. 녹이다. 각 문자열은에 의해 분리 된 하나, 둘 또는 세 개의 서로 다른 단어로 구성됩니다.

'결과'는 문자열입니다. 프로그램은 세 개의 목록 (class_names, param_names 및 other_names)을 검사하고 결과 문자열의 내용을 이미 준비한 내용으로 바꿉니다. 그런 다음 결과 목록에 추가하십시오. 'snippet'과 'phrase'는 두 개의 다른 문자열이기 때문에 (for snippet, phrase :) 루프는 두 번 실행됩니다. 따라서 'result'문자열이 두 번 만들어지고 있습니다 (하나는 대답 용).

https://github.com/MahshidZ/python-recepies/blob/master/random_word_set.py

마지막으로, 나는 프린트를 넣어하는 것이 좋습니다 :

나는 URL에 임의의 단어에서 특정 크기의 목록을 생성하는 방법을 명확히하기 위해 더 작은 하위 프로그램으로이 프로그램의 한 부분을 넣어 당신이 더 잘 이해할 필요가있는 코드의 문장.예를 들어,이 코드의 경우 나는 무엇이 진행되고 있는지를 알기 위해 많은 변수를 출력했다. (내 코드에서 부울 변수 DEBUG 확인)

DEBUG = 1 
if DEBUG: 
    print "snippet: " , snippet 
    print "phrase: ", phrase 
    print "class names: ", class_names 
    print "other names: " , other_names 
    print "param names: ", param_names 
관련 문제