Python: sort,sorted,OrderedDict的用法
来源:互联网 发布:手机优化哪个好 编辑:程序博客网 时间:2024/04/29 16:17
python对容器内数据的排序有两种,一种是容器自己的sort函数,一种是内建的sorted函数。
sort函数和sorted函数唯一的不同是,sort是在容器内排序,sorted生成一个新的排好序的容器。
对于一个简单的数组 L=[5,2,3,1,4].
sort: L.sort()
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
iterable:待排序的可迭代类型的容器;
cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;
key:用列表元素的某个已命名的属性或函数(只有一个参数并且返回一个用于排序的值)作为关键字,有默认值,迭代集合中的一项;
reverse:排序规则. reverse = True 或者 reverse = False,有默认值。
返回值:是一个经过排序的可迭代类型,与iterable一样。
如果是一个多维的列表 L=[(‘b’,2),(‘a’,1),(‘c’,3),(‘d’,4)].
有三种选择对这个多维列表进行排序
- 利用cmp函数
sorted(L, cmp=lambda x,y:cmp(x[1],y[1]))
L.sort(cmp=lambda x,y:cmp(x[1],y[1]))
- 利用key
sorted(L, key=lambda x:x[1]);
L.sort(key=lambda x:x[1]);
- 反序
以上几种排序均可加上参数reverse.
例如 sorted(reverse=True), L.sort(reverse=True). 或者改成False
OrderedDict是collections中的一个包,能够记录字典元素插入的顺序,常常和排序函数一起使用来生成一个排序的字典。
比如,比如一个无序的字典
d = {‘banana’:3,’apple’:4,’pear’:1,’orange’:2}
通过排序来生成一个有序的字典,有以下几种方式
collections.OrderedDict(sorted(d.items(),key = lambda t:t[0]))
或者
collections.OrderedDict(sorted(d.items(),key = lambda t:t[1]))
或者
collections.OrderedDict(sorted(d.items(),key = lambda t:len(t[0])))
补充:
从2.4 开始数组的排序可以指定键位置!
所以:
for k, v in sorted(myDict.items()
, key=lambda x: x[1]
,reverse=True):
print k,v
就可以获得从大到小的排序字典输出了
- Python: sort,sorted,OrderedDict的用法
- Python: sort,sorted,OrderedDict的用法
- Python: sort,sorted,OrderedDict的用法
- python中排序,函数sort、sorted、argsort,collections.OrderedDict类
- python OrderedDict用法
- python sort、sorted 高级用法
- python sort 和sorted的区别和用法
- python 中 sorted() 和 list.sort() 的用法
- python 中 sorted() 和 list.sort() 的用法
- python中OrderedDict的使用
- Python-排序用法-sort、sorted、reverse、reversed
- python的排序 sort sorted
- python OrderedDict
- Python OrderedDict
- python的sorted用法
- Python sorted()的用法
- python中List的sort方法(或者sorted内建函数)的用法
- python中List的sort方法(或者sorted内建函数)的用法
- static 关键字
- CBitmap的使用
- 洗牌算法
- formvalidator 文本框独立验证
- 一分钟先生:如何做好向上管理
- Python: sort,sorted,OrderedDict的用法
- vc颜色转换
- Illegal attempt to associate a collection with two open sessions
- HADOOP的本地库(NATIVE LIBRARIES)介绍
- 说说positon相对定位和绝对定位的问题
- windows下编译ffmpeg源代码
- 关于C语言中a=a++与a=++a的研究
- Activity传递数据四种方法
- 实验4 编制模拟“五个哲学家”问题的程序