习题41 学习面向对象术语

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_27469517/article/details/53129928

这一节学习的是面向对象术语。


单词练习

首先要求是要记住一些术语,就是单词的定义。

  • class:类。告诉Python创建新类型的东西。
  • object:对象。最基本的东西,或是某个东西的实例。
  • instance:实例。让Python创建一个类时得到的东西。原文:What you get when you tell Python to create a class.
  • def:这是在类里面定义函数的方法。
  • self:在类的函数中,self指代被访问的对象或者实例的一个变量。
  • inheritance:继承。指一个类可以继承另一个类的特性,和父子关系类似。
  • composition:组合。指一个类可以将别的类作为它的部件构建起来,有点儿像车子和车轮的关系。
  • attribute:属性。类的一个属性,它来自于组合,而且通常是一个变量。
  • is-a:是什么。用来描述继承关系,如Salmon is-a Fish(鲑鱼是一种鱼)。原文:as in a "salmon" is-a "fish."
  • has-a:有什么。用来描述某个东西是由另外一些东西组成的,或者某个东西有某个特征,如Salmon has-a mouth(鲑鱼有一张嘴)。原文:as in "a salmon has-a mouth."


书上的意思就是要记住上面这些个东西,有什么用一会儿就知道了。


语汇练习

然后给了一些代码吧,大概就是用上了上面的单词(Word)构成了一些短语(Phrase)。

  • class X(Y)  

创建一个叫X的类,它是Y的一种。

  • class X(object):def__init__(self,J)  

类X有一个__init__j接收self和J作为参数。

  • class X(object):def M(self,J)  

类X有一个函数名称为M,它接收self和J作为参数。 

  • foo = X()
将foo设为类X的一个实例。

  • foo.M(J)

从foo中找到M函数,并使用self和J参数调用它

  • foo.K = Q

从foo中获取K属性,并将其设为Q。

其中每一条的X,Y,M,J,K,Q及foo的地方,都可以将他们当做空白点来对待。


阅读代码

来一段试试,这段代码调用了一个叫urllib的库。

运行之前我要说一下,这段代码应该是从网址上获取了一个库,然后无穷无尽的练习这些术语,但是对于中文母语的我真的蛋疼。

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"

运行结果就不放图了。

主要是要分析一下这段代码。但是我目前水平渣渣,有部分不太懂。





阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页