import collections
# collections模块实现一些特定的数据类型,可以替代Python中常用的内置数据类型如
# dict, list, set, tuple,简单说就是对基本数据类型做了更上一层的处理
Point = collections.namedtuple("Point",["x","y"]) # namedtuple,可以创建包含名称的tuple
print(type(Point))
p = Point("10",2)
print(type(p.x))
print(p.x)
print(p.y)
Card = collections.namedtuple("Card",["rank","suit"]) # 创建了一个名字为card的元组数据类型,里面有两个元素他们的属性 分别是rank 和 suit
# namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素。
# 这样一来,我们用namedtuple可以很方便地定义一种数据类型,它具备tuple的不变性,又可以根据属性来引用,使用十分方便
class FrenchDeck:
ranks = [ str(n) for n in range(2,11)] + list("JKQA")
suits = '红桃 方片 梅花 黑桃'.split()
def __init__(self):
self._cards = [Card(rank,suit) for suit in self.suits for
rank in self.ranks]
# 在构造函数中创建一种数据类型,和Card的数据属性相同
def __len__(self):
return len(self._cards)
def __getitem__(self, position):
return self._cards[position]
# __getitem__ 让对象实现迭代功能
deck = Card("7","diamonds")
print(deck.rank)
deck_card = FrenchDeck()
# deck_card.print_s()
print(len(deck_card))
# 根据索引找纸牌
print(deck_card[0])
print(deck_card[-1])
# 遍历所有的纸牌
for index,card in enumerate(deck_card,1):
print(card,index)
# 利用切片
print(deck_card[10:20])
估计除了本人没人能看懂,真的还没理清楚