Python_重写集合

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python_重写集合相关的知识,希望对你有一定的参考价值。

class Set(object):
def __init__(self,data=None):
if data == None:
self.__data = []
else:
if not hasattr(data,‘__iter__‘):
#提供的数据不可以迭代,实例化失败
raise Exception(‘必须提供可迭代的数据类型‘)
temp = []
for item in data:
#集合中的元素必须是可哈希
hash(item)
if not item in temp:
temp.append(item)
self.__data = temp

#析构函数
def __del__(self):
del self.__data

#添加元素,要求元素必须可哈希
def add(self, other):
hash(other)
if other not in self.__data:
self.__data.append(other)
else:
print(‘元素已存在,操作被忽略‘)

#删除元素
def remove(self,other):
if other in self.__data:
self.__data.remove(other)
print(‘删除成功‘)
else:
print(‘元素不存在,删除操作被忽略‘)

#随机弹出并返回一个元素
def pop(self):
if not self.__dat:
print(‘集合已空,弹出操作被忽略‘)
return
import random
item = random.choice(self.__data)
self.__data.remove(item)
return item

#运算符重载,集合差集运算
def __sub__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
#空集合
result = Set()
#如果一个元素属于当前集合而不属于另一个集合,添加
for item in self.__data:
if item not in other.__data:
result.__data.append(item)
return result

#提供方法,集合差集运算,复用上面的代码
def difference(self,other):
return self - other

#|运算符重载,集合并集运算
def __or__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
result = Set(self.__data)
for item in other.__data:
if item not in result.__data:
result.__data.append(item)
return result

#提供方法,集合并集运算
def union(self,otherSet):
return self | otherSet

#&运算符重载,集合交集运算
def __and__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
result = Set()
for item in self.__data:
if item in other.__data:
result.__data.append(item)
return result

#^运算符重载,集合对称差集
def __xor__(self, other):
return (self-other) | (other-self)

#提供方法,集合对称差集运算
def symetric_difference(self,other):
return self ^ other

#==运算符重载,判断两个集合是否相等
def __eq__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
if sorted(self.__data) == sorted(other.__data):
return True
return False

#>运算符重载,集合包含关系
def __gt__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
if self != other:
flag1 = True
for item in self.__data:
if item not in other.__data:
#当前集合中有的元素不属于另一个集合
flag1 = False
break
flag2 = True
for item in other.__data:
if item not in self.__data:
#另一集合中的元素不属于当前集合
flag2 = False
break
if not flag1 and flag2:
return True
return False

#>=运算符重载,集合包含关系
def __ge__(self, other):
if not isinstance(other,Set):
raise Exception(‘类型错误‘)
return self == other or self > other

#提供方法,判断当前集合是否为另一个集合的真子集
def issubset(self,other):
return self<other

#提供方法,判断当前集合是否为另一集合的超集
def issuperset(self,other):
return self > other

#提供方法,清空集合所有元素
def clear(self):
while self.__data:
del self.__data[-1]
print(‘集合已清空‘)

#运算符重载,使得集合可迭代
def __iter__(self):
return iter(self.__data)

#运算符重载,支持in运算符
def __contains__(self, item):
return item in self.__data

#支持内置函数len()
def __len__(self):
return len(self.__data)

#直接查看该类对象时调用该函数
def __repr__(self):
return ‘{‘+str(self.__data)[1:-1]+‘}‘

#使用print()函数输出该类对象时调用该函数
__str__ = __repr__
































































































































































以上是关于Python_重写集合的主要内容,如果未能解决你的问题,请参考以下文章

python 重写__repr__与__str__函数

python 类中内置方法的重写

python之重写父类方法

python_day14_前端_JS-重写

python类的继承和重写

python学习笔记——线程threading 重写run()方法和守护进程daemon()