用Python的魔法方法实现扑克牌

用Python的魔法方法实现扑克牌

"""
@author:amgoole  
@date: 2021/6/26 
@email: xwen.xi@icloud.com
"""

import collections

# 实现一个简单卡片类
Card = collections.namedtuple("Card", ['rank', 'suit'])


# 实现一副扑克类
class FrenchDeck:
    ranks = [str(n) for n in range(2, 11)] + list("JQKA")
    suits = "spades diamonds clubs hearts".split()

    # 生成52张3扑克牌
    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, item):
        return self._cards[item]
    
    # 简易发牌
    def pop(self, cad=None):
        if not self._cards:
            print("牌已发完")
            return
        elif isinstance(cad, Card):
            self._cards.pop(self._cards.index(cad))
        else:
            self._cards.pop()


# 实例化单张牌
beer_card = Card('7', 'diamonds')
print(beer_card)

deck = FrenchDeck()

# 找出前三张牌
print(deck[:3])

# 找出所有的A
print(deck[12::13])

# 设置花型权重
weight = dict(spades=3, hearts=2, diamonds=1, clubs=0)


# 计算单张牌的排位顺序
def spades_high(cad: Card):
    rank = FrenchDeck.ranks.index(cad.rank)
    return rank * len(FrenchDeck.suits) + weight[cad.suit]


print(spades_high(Card('3', 'clubs')))
# 按照排位顺序输出
for card in sorted(deck, key=spades_high):
    print(card)

FranchDeck实例可以被索引,切片的原因是该类实现了__getitem__方法,当使用[]索引或切片时,会将操作[]传递给_cards代理实现,因而FranchDeck能够像列表一样被操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值