原文地址为:[转].Python中sorted函数的用法
转载请注明本文地址:[转].Python中sorted函数的用法
我们需要对List、Dict进行排序,Python提供了两个方法
对给定的List L进行排序,
方法1.用List的成员函数sort进行排序, 在本地进行排序,不返回副本
方法2.用built-in函数sorted进行排序(从2.4开始), 返回副本,原始输入不变
--------------------------------sorted---------------------------------------
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
---------------------------------sort----------------------------------------
>>> help(list.sort)
Help on method_descriptor:
sort(...)
-----------------------------------------------------------------------------
iterable:是可迭代类型;
cmp:用于比较的函数,比较什么由key决定;
key:用列表元素的某个属性或函数进行作为关键字,有默认值,迭代集合中的一项;
返回值:是一个经过排序的可迭代类型,与iterable一样。
对给定的List L进行排序,
方法1.用List的成员函数sort进行排序, 在本地进行排序,不返回副本
方法2.用built-in函数sorted进行排序(从2.4开始), 返回副本,原始输入不变
--------------------------------sorted---------------------------------------
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
---------------------------------sort----------------------------------------
>>> help(list.sort)
Help on method_descriptor:
sort(...)
-----------------------------------------------------------------------------
iterable:是可迭代类型;
cmp:用于比较的函数,比较什么由key决定;
key:用列表元素的某个属性或函数进行作为关键字,有默认值,迭代集合中的一项;
返回值:是一个经过排序的可迭代类型,与iterable一样。
参数说明:
cmp接受一个函数,拿整形举例,形式为:
def f(a,b):
如果排序的元素是其他类型的,如果a逻辑小于b,函数返回负数; a逻辑等于b,函数返回0; a逻辑大于b,函数返回正数就行了
def f(a):
key接受的函数返回值,表示此元素的权值,sort将按照权值大小进行排序
(3) reverse参数
接受False 或者True 表示是否逆序
例子:
(1)按照元素长度排序
L = [{1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f(x):
return
sort(key=f) print
输出:
[{1: 9}, {1: 5, 3: 4}, {1: 3, 6: 3}, {1: 1, 2: 4, 5: 6}]
(2)按照每个字典元素里面key为1的元素的值排序
L1:5,3:4},{1:3,6:3},{1:1,2:4,5:6},{1:9}]
def f2(a,b):
return 1 ]-b[ 1 ]
L.sort(cmp=f2)
print L
. 对由tuple组成的List
用key函数排序:返回由tuple组成的list
- lambda
- lambda
用 operator 函数来加快速度,
- fromimport
2. 对由字典排序 ,返回由tuple组成的List,不再是字典。
转载请注明本文地址:[转].Python中sorted函数的用法
文章来源: [转].Python中sorted函数的用法