为了账号安全,请及时绑定邮箱和手机立即绑定

如何解决:“如果list不仅仅包含 Student 类,则 __cmp__ 可能会报错”

L = [Student('Tim', 99), Student('Bob', 88), 100, 'Hello']
print sorted(L)

正在回答

3 回答

当含有其他类是,可以判断其他类的类型。例如有数字和字符串,数字和分数比较,字符串和名字比较

    def __cmp__(self, s):
        if isinstance(s,Student):
            if self.score<s.score:
                return -1
            elif self.score>s.score:
                return 1
            else:
                if self.name<s.name:
                    return -1
                elif self.name>s.name:
                    return 1
                else:
                    return 0
        elif isinstance(s,str):
            if self.name<s:
                return -1
            elif self.name>s:
                return 1
            else:
                return 0
        elif isinstance(s,int):
            if self.score<s:
                return -1
            elif self.score>s:
                return 1
            else:
                return 0

这样写有点复杂,不如重写一个cmp方法,重复调用

当然也可以按照其他同学的方法:同类的话进行比较,不同类的话顺序不变。但是此方法有问题:如果是中间夹带,那么只比较前后顺序使得最后结果不对。

Ex:L = [Student('Tim', 99), Student('Bob', 88), Student('Alice', 99),100,'Hello',Student('im', 99)] 最后结果为只排序了前半段。

[(Bob: 88), (Alice: 99), (Tim: 99), 100, 'Hello', (im: 99)]

1 回复 有任何疑惑可以回复我~
#1

kall778

你把im:99改成im:98,它就会排在BOb:88的后面的~,结果有什么不对的?
2015-05-18 回复 有任何疑惑可以回复我~
s1 = Student('Alice','female',18,'Middle school',87)
s2 = Student('Bob','male',17,'Middle school',78)

def fn_cmp(obj1,obj2):
    if obj1.__str__() > obj2.__str__():
        return -1
    else:
        return 0

L=[s1,s2,"hello",13]
print sorted(L,fn_cmp)

例如这样

0 回复 有任何疑惑可以回复我~

可以自己写一个比较函数来处理 [Student('Tim', 99), Student('Bob', 88), 100, 'Hello'] 这样的状况,然后把L和函数同时传给sorted()

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

如何解决:“如果list不仅仅包含 Student 类,则 __cmp__ 可能会报错”

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信