1. 特殊方法汇总列表

 

 

2. 仿集合类

__len__:返回对象的长度

__getitem__:获得某一项的值

__setitem__:设置莫一项的值

__delitem__删除某一项

__contains__:包含某一项

 

实现说明:

1) 模拟一副扑克牌,包含两个类,一个是卡片类(Card),一个是 扑克(PuKe),PuKe类包含52张牌,13个大小(AJQK,2-10),4张花色("redheart", "spades", "diamond", "club").

2) 卡片类包含两个属性,rank(等级)、color(花色),以及重写了__eq__方法,判断卡片的相同性,为后续PuKe类中的__getitem__,__setitem__方法中的判断做铺垫;

3) 实现PuKe中的__len__,__getitem__,__setitem__,__contains__等方法。

代码实现:

Card类代码如下:

class Card:
def __init__(self, rank, color):
self.rank = rank
self.color = color
def __repr__(self):
return "Card rank is %s and color is %s" % (self.rank, self.color) def __eq__(self, other):
if isinstance(other, (tuple, )):
if self.rank == other[0] and self.color == other[1]:
return True
if isinstance(other, (Card,)):
if self.rank == other.rank and self.color == other.color:
return True return False

说明:

1) __init__方法包含两个属性,rank和color

2) 重写__repr__方法,格式化后续的Card类对象的打印信息

3) 重写__eq__方法,只有rank、color两个属性都满足的情况下,才能判断卡片是相同的。

PuKe类的实现:

class PuKe:
ranks = [str(rank) for rank in range(2, 11)] + list("JQKA")
colors = ["redheart", "spades", "diamond", "club"] def __init__(self):
"""
初始化生成牌
"""
self._cards = [Card(rank, color) for rank in PuKe.ranks
for color in PuKe.colors] def __len__(self):
"""
返回一副扑克中牌的张数
:return:
""" return len(self._cards) def __getitem__(self, item):
"""
获得某一张牌
:param item:
:return:
"""
assert item is not None
result = None
if isinstance(item, (int,)):
result = self._cards[item]
elif isinstance(item, (tuple,)):
result = []
for card in self._cards:
if card == item:
return card return result def __setitem__(self, key, value):
"""
设置某一项的值
:param key: rank+color,为一元组
:param value: other rank+color,元组
:return: void
"""
assert key is not None
if not isinstance(key, (tuple,)) or not isinstance(value, (tuple,)):
return
for card in self._cards:
if card == key:
card.rank = value[0]
card.color = value[1]
return
def __contains__(self, item):
"""
判断是否包含一个牌
:param item: 元组
:return:
"""
for card in self._cards:
if card == item:
return True
return False

 

说明:

1) __init__方法,初始化52中卡片

2) __len__方法,返回卡片的数量,肯定等于52

3) 在__getitem__方法的实现中,两种实现方法来获得某一张卡片,一个是根据索引号,一个是根据卡片的rank和color属性来定位一张卡片。

4) __setitem__方法中,key是rank和color的元组,实现卡片的定位

5) __contains__方法,判断卡片是否在扑克牌中。

 

代码测试:

if __name__ == '__main__':

    puke1 = PuKe()
print("一副牌的张数为%d " % len(puke1))
print("牌分别为:")
#循环,同样会调用__getitem__
for card in puke1:
print(card) card5 = puke1[5]
print("第5张牌的rank为%s,花色为:%s" % (card5.rank, card5.color)) cardA = puke1[("A", "spades")]
print("A牌的花色分别为:%s" % cardA.color) print("随机选张牌")
from random import choice # 随机选择,同样会调用__getitem__
card = choice(puke1)
print(card) #会调用__setitem__方法
puke1[("7", "spades")] = ("7", "gagagwer")
#再次打印puke
for card in puke1:
print(card)
#会调用__container__方法
print(("7", "gagagwer") in puke1)

 

总结:循环会调用__getitem__,如果某个对象要能循环,必须具备___getitem__方法

细数Python的特殊方法一:集合类的更多相关文章

  1. 细数Python Flask微信公众号开发中遇到的那些坑

    最近两三个月的时间,断断续续边学边做完成了一个微信公众号页面的开发工作.这是一个快递系统,主要功能有用户管理.寄收件地址管理.用户下单,订单管理,订单查询及一些宣传页面等.本文主要细数下开发过程中遇到 ...

  2. C语言:其他进制数转换为十进制(方法一)

    #include<stdio.h> #include<math.h> #include<string.h> //其他任意进制转换为十进制 int main() { ...

  3. Python笔记·第四章—— 细数Python中的数据类型以及他们的方法

    一.数据类型的种类及主要功能 1.数字类型 数字类型主要是用来计算,它分为整数类型int和浮点类型float 2.布尔类型 布尔类型主要是用于判断,它分为真True和False两种 3.字符串类型 字 ...

  4. 细数Python中的数据类型以及他们的方法

    一.数据类型的种类及主要功能 1.数字类型 数字类型主要是用来计算,它分为整数类型int和浮点类型float 2.布尔类型 布尔类型主要是用于判断,它分为真True和False两种 3.字符串类型 字 ...

  5. python高性能编程方法一

    python高性能编程方法一   阅读 Zen of Python,在Python解析器中输入 import this. 一个犀利的Python新手可能会注意到"解析"一词, 认为 ...

  6. 细数iOS上的那些安全防护

    细数iOS上的那些安全防护  龙磊,黑雪,蒸米 @阿里巴巴移动安全 0x00 序 随着苹果对iOS系统多年的研发,iOS上的安全防护机制也是越来越多,越来越复杂.这对于刚接触iOS安全的研究人员来说非 ...

  7. Spring Framework------>version4.3.5.RELAESE----->Reference Documentation学习心得----->使用spring framework的IoC容器功能----->方法一:使用XML文件定义beans之间的依赖注入关系

    XML-based configuration metadata(使用XML文件定义beans之间的依赖注入关系) 第一部分 编程思路概述 step1,在XML文件中定义各个bean之间的依赖关系. ...

  8. 细数.NET 中那些ORM框架 —— 谈谈这些天的收获之一

    细数.NET 中那些ORM框架 —— 谈谈这些天的收获之一(转) ADO.NET Entity Framework        ADO.NET Entity Framework 是微软以 ADO.N ...

  9. JBOSS通过Apache负载均衡方法一:使用mod_jk

    JBOSS通过Apache负载均衡方法一:使用mod_jk   本文第一.二节分别对Linux环境下前端使用Apache以及windows环境下前端使用IIS通过AJP协议和后端的JBOSS通信实现负 ...

随机推荐

  1. Codeforces 补题记录

    首先总结一下前段时间遇到过的一些有意思的题. Round #474 (Div. 1 + Div. 2, combined)   Problem G 其实关键就是n这个数在排列中的位置. 这样对于一个排 ...

  2. 可持久化01Trie树【p4735(bzoj3261)】最大异或和

    Description 给定一个非负整数序列\(\{a\}\),初始长度为\(N\). 有\(M\)个操作,有以下两种操作类型: A x:添加操作,表示在序列末尾添加一个数\(x\),序列的长度\(N ...

  3. 【Kubernetes】在K8s中创建StatefulSet

    在K8s中创建StatefulSet 遇到的问题: 使用Deployment创建的Pod是无状态的,当挂在Volume之后,如果该Pod挂了,Replication Controller会再run一个 ...

  4. 【解决问题】centOS 7 设置固定IP,无法上外网

    使用Xenserver搭建服务器集群,在安装centOS时候,发现如果将服务器IP设置成为static ip,只能内网互通,无法上外网(ping www.baidu.com 失败) 网上搜索了一下,发 ...

  5. BZOJ 3127 [Usaco2013 Open]Yin and Yang(树点分治)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3127 [题目大意] 给出一棵01边权树,求存在多少条路径,使得路径上0和1的数量相同, ...

  6. 【推导】Codeforces Round #364 (Div. 2) D. As Fast As Possible

    一种方法是二分总时间,复杂度O(nlogn). 另外我们可以证明,当所有人同时到达终点的时候,是最优的,因为没有人的时间“浪费”了. 我们又发现,每个人的运动过程总是两段,要么是走路,要么是坐车.于是 ...

  7. 【强联通分量缩点】【Tarjan】bzoj1051 [HAOI2006]受欢迎的牛

    就是看是否有一些点,从其他任何点出发都可到达 定理:有向无环图中唯一出度为0的点,一定可以由任何点出发均可达. 所以缩点,若出度为零的点(强联通分量)唯一,则答案为该强联通分量中点的度数. 若不唯一, ...

  8. ncnn阅读 - CMakeLists.txt

    CMAKE_TOOLCHAIN_FILE This variable is specified on the command line when cross-compiling with CMake. ...

  9. Problem C: 调用函数,求a+aa+aaa+....+aa...aa(n个a)

    #include <stdio.h> int fn(int a,int n)//定义函数 { ; ;i<=n;i++) { m=m+a;//当a=3时,m=3,然后a=30,m=33 ...

  10. mqtt 协议之 PINGREQ, PINGRESP

    mqtt 协议里最简单的是 ping 协议吧 (心跳包), ping 协议是已连接的客户端发往服务端, 告诉服务端,我还"活着" PINGREQ - PING request fi ...