对Python的字典进行排序-Python教程

资源魔 40 0

咱们晓得Python的内置dictionary数据类型是无序的,经过key来猎取对应的value。可是有时咱们需求对dictionary中 的item进行排序输入,可能依据key,也可能依据value来排。到底有几何种办法能够完成对dictionary的内容进行排序输入呢?上面摘取了 一些精彩的处理方法。

python对容器内数据的排序有两种,一种是容器本人的sort函数,一种是内建的sorted函数。

sort函数以及sorted函数惟一的没有同是,sort是正在容器内(in-place)排序,sorted天生一个新的排好序的容器。

1 依照Key值排序


#最简略的办法,这个是依照key值排序: 
def sortedDictValues1(adict): 
items = adict.items() 
items.sort() 
return [value for key, value in items] 
 
#又一个依照key值排序,貌似比上一个速率要快点 
def sortedDictValues2(adict): 
keys = adict.keys() 
keys.sort() 
return [dict[key] for key in keys] 
 
#仍是按key值排序,听说更快。。。并且当key为tuple的时分照样实用 
def sortedDictValues3(adict): 
keys = adict.keys() 
keys.sort() 
return map(adict.get, keys) 
 
#一行语句搞定: 
[(k,di[k]) for k in sorted(di.keys())] 
 
#用sorted函数的key参数(func)排序: 
#依照key进行排序 
print sorted(dict1.items(), key=lambda d: d[0])

2 依照value值排序


#来一个依据value排序的,先把item的key以及value替换地位放入一个list中,再依据list每一个元素的第一个值,即原来的value值,
排序: 
def sort_by_value(d): 
items=d.items() 
backitems=[[v[1],v[0]] for v in items] 
backitems.sort() 
return [ backitems[i][1] for i in range(0,len(backitems))] 
 
#仍是一行搞定: 
[ v for v in sorted(di.values())] 
 
#用lambda表白式来排序,更灵敏: 
sorted(d.items(), lambda x, y: cmp(x[1], y[1])), 或反序: 
sorted(d.items(), lambda x, y: cmp(x[1], y[1]), reverse=True) 
 
#用sorted函数的key参数(func)排序: # 依照value进行排序 
print sorted(dict1.items(), key=lambda d: d[1])

常识点扩大:

预备常识:

正在python里,字典dictionary是内置的数据类型,是个无序的存储构造,每一一元素是key-value对:

如:dict = {'username':'password','database':'master'},此中'username'以及'database'是key,而'password'以及'master'是value,能够经过d[key]取得对应值value的援用,然而不克不及经过value失去key。

关于dictionnary,需晓得如下几点留意事项:

a、 dictionary 的 key 是巨细写敏感的;

b、 一个dictionary中不克不及有反复的 key;

c、 dictionary是无序的,不元素程序的概念,它们只是序偶的简略陈列。

保举教程:《PHP》《Python教程》

以上就是对Python的字典进行排序的具体内容,更多请存眷资源魔其它相干文章!

标签: Python python教程 python编程 python使用问题 字典排序

抱歉,评论功能暂时关闭!