Python 自定义类的排序
短信预约 -IT技能 免费直播动态提醒
Python 里面自定义类的时候, 一般需要重写几个方法, __init__ 一般是构造函数
这里面有一个__cmp__() 是比较函数, 重写它的时候,一定要记得返回值有三个,0,±1 !! 而不是返回0,1 这里没有注意,导致在排序的时候,一直出错啊,QAQ
或者直接使用内置函数 cmp() 来返回就行
def __cmp__(self,other):
if self.age<other.age:
return -1
elif self.age==other.age:
return 0
else:
return
上述的等价于:
这样再重写了这个__cmp__ 函数之后,就可以为类列表排序了
def __cmp__(self,other):
return cmp(self.age,other.age)
看例子:
class Prople:
"""docstring for Prople"""
def __init__(self,n,a):
self.name=n
self.age=a
def __cmp__(self,other):
return cmp(self.age,other.age)
def __str__(self):
return self.name+" "+str(self.age)
p=Prople("liu",60)
pp=Prople("li",50)
li=[]
li.append(p)
li.append(pp)
print sorted(li)[0]
这次老老实实的记住了!! 排序坑了好长时间。。。。 伤不起。。。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341