流畅的Python---纸牌(魔术方法:__getitem__ 与 __len__ )

 常用Python的内建模块(collections)、魔术方法(__getitem__ 与 __len__ )构建纸牌

  1.常用内建模块 collections、base64、struct、hashlib、itertools、XML、HTMLParser

    collections集合类:namedtuple、deque、defaultdict、OrdereDict、Counter

    namedtuple是一个函数,创建一个自定义tuple对象,并且规定tuple元素的个数,并且可以用属性,而不是索引来引用tuple的某个元素

import collections
Card = collections.namedtuple('Card',['rank','suit'])

    根据Card 写出4种花色、13个数,一共52张纸牌----FrenchDeck类

class FrenchDeck:
    ranks = [str(n) for n in range(2,11)] + list('JQKA')
    suits = 'spades diamods clubs hearts'.split()
    def __init__(self):
        self._cards = [Card(rank,suit) for suit in self.suits for rank in self.ranks]
    def __len__(self):
        return len(self._cards)
    def __getitem__(self , position):
        return self._cards[position]

    __init__为构造函数,在实例化对象后,对象中_cards将有52张纸牌,并且是元组类型的

    __len__为长度魔法方法,在实例化对象后,实列化出的对象可计数或者计算长度

    __getitem__为迭代魔法方法,在实列化对象后,实例化出的对象可迭代

# 实列化对象 deck
deck = FrenchDeck()
# 对象deck可计数
print(len(deck))
# 对象deck可迭代
for card in deck:
    print(card)
# 对象deck可反迭代
for card in reversed(deck):
    print(card)

    按照常规将纸牌排序,2最小、A最大、黑桃最大、红桃次之、方块再次、梅花最小

# 字典suit_values表示花色的大小
suit_values = dict(spades=3, hearts=2, diamods=1, clubs=0)
def spades_high(card):
    rank_value = FrenchDeck.ranks.index(card.rank)
    return rank_value * len(suit_values) + suit_values[card.suit]
for card in sorted(deck,key=spades_high):
    print(card)

  2. 魔术方法(使用原则)  

    这些特殊方法都是为了被Python解释器调用,我们不用调用。

    魔术方法使用得当,加快效率。

    很多时候这些魔术方法都是隐式的,无需直接使用特殊方法。但是在有大量的元编程存在时,直接调用特殊方法的频率应该远远低于我们去实现他们的次数。

    

    

posted @ 2019-04-09 22:47  CoyLee  阅读(437)  评论(3编辑  收藏  举报