文章目录
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)