刚写python遇到了排序问题。假设有一个类为Person,包含两个 Person 类的实例的 list,并给两个实例的 name赋值,然后按照 name 进行排序。
class Person(object):
pass
p1 = Person()
p1.name = 'art'
p2 = Person()
p2.name = 'Zdam'
p3 = Person()
p3.name = 'Lisa'
L1 = [p1, p2, p3]
L2 = ?
print L2[0].name
print L2[1].name
print L2[2].name
这里L2要怎么写呢?用到sorted()函数:sorted(L1, lambda p1, p2: cmp(p1.name, p2.name))
L1是指是可迭代类型;lambda是用户自定义的函数,也就是规则,cmp(a,b)比较a,b两值的不同,依次返回-1,0,1。
1.为什么不是cmp(p1.name,p2.name,p3.name)呢?
因为cmp()函数只接收两个参数,并且这个cmp函数是用户自定义的规则,执行之后p1.name,p2.name和p3.name都会执行这条规则,进行比较,从中得出符合规则的结果,也就是改变顺序的L2,而并不是只有p1和p2进行了比较,p3没有进行比较。
2.为什么不是sort()而是sorted()呢?
(1)sort是在原位重新排列列表,而sorted()是产生一个新的列表。
(2)list.sort()方法只为list定义。而sorted()函数可以接收任何的iterable。