Python sorted排序方法如何实现
在给列表排序时,sorted非常好用,语法如下:
sorted(iterable[,cmp[,key[,reverse]]])
sorted定义如下:
- sorted(iterable[,cmp[,key[,reverse]]])
- iterable:是可迭代类型类型;
- cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;
- key:用列表元素的某个属性和函数进行作为关键字,有默认值,迭代集合中的一项;
- reverse:排序规则.reverse=True或者reverse=False,有默认值。
- 返回值:是一个经过排序的可迭代类型,与iterable一样。简单列表排序,很容易完成,sorted(list)返回的对象就是列表结果,但是遇到列表中嵌套元组时,需要使用特殊的方法解决。
问题描述:
给定列表如下:
list_example=[('John',35),('Jack',32),('Michael',28),('Sean',20)]
输出要求:
[('Sean',20),('Michael',28),('Jack',32),('John',35)]
解决方法:
1.传入函数给key,完成操作;
2.直接使用lambda函数;
方法1的代码如下:
defrevsort(oldlist): returnoldlist[::-1] defby_age(li): returnsorted(li,key=revsort)
方法2的代码如下:
defby_age(li): returnsorted(li,key=lambdax:x[1])
直接print可以得到结果:
print(by_age(list_example))
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。