python 3 自定义sort

python3 自定义sort 不同于c++,不能用传入cmp函数来实现比较a,b,而是需要一个key ,利用这个key 计算出当前的值,然后再进行排序,所以比较坑爹了

数字定义排序

a = [3,2,1]
a.sort() # 默认从小到大
a = [103,2,101] # 如果想要按个位从小到大怎么办呢?
a.sort(key = lambda x:x%10)


##类定义排序方式

class myclass:
    x,y = 0,0
a = []
for i in range(10):
    t = myclass()
    t.x,t.y = 10-i,i*10
    a.append(t)
a.sort(key = lambda t:t.x)# 按第一个关键字排序
for i in range(10):
    print(a[i].x,a[i].y)
a.sort(key = lambda t:t.y)# 按第二个关键字排序
for in range(10):
	print(a[i].x,a[i].y)