sort()/sorted()和参数
sort()是在原位重新排列列表
sorted()是产生一个新的列表
sort(iterable,cmp/key/reverse…)
iterable:是可迭代类型;
cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;
key:用列表元素的某个属性和函数进行作为关键字,有默认值,迭代集合中的一项;
reverse:排序规则. reverse = True 或者 reverse = False,有默认值。
返回值:是一个经过排序的可迭代类型,与iterable一样。
注;一般来说,cmp和key可以使用lambda表达式。
如果列表中每个元素有多个子元,一般用key,如果想自定义排序规则,一般用cmp
lambda的用法
注:效率上,key比cmp要快
1.cmp
cmp(a,cmp=lambda 输入:cmp(cmp的参数))
sorted (a, cmp=lambda x,y:cmp(x[1],y[1]) )
lambda是隐函数,lambda后面的冒号左边是输入参数,冒号右边的是输出参数,输入参数按照cmp函数定义的排序规则进行排序
x,y是列表a中的元素(是元祖),用cmp的排序规则按照元祖的第二个元素进行排序
2.参数key
参数key:带一个参数的函数(排序时,会依次传入列表的每一项,作为该函数的参数)。该函数用于在比较排序之前进行的操作
sort(a,key 输入:输出)
输入就是列表a中的元素,输出就是按照第几个子元排序
例如下面这句话:
sort(a,key=lambda x:x[0])
key是关键词,看下面这句命令,lambda是一个隐函数,是固定写法,不要写成别的单词;x表示列表中的一个元素,在这里,表示一个元组,x只是临时起的一个名字,你可以使用任意的名字;x[0]表示元组里的第一个元素,当然第二个元素就是x[1];所以这句命令的意思就是按照列表中第一个元素排序
如何按照第一个元素排序完再按照第二个元素进行排序呢?
sort(a,key=lambda x:(x[0],x[1])
如何按照第一个元素升序,第二个元素降序呢?
sort(a,key=lambda x:(x[0],-x[1])
3.Reverse
sort(a);
sort(a,reverse=True);