python字典如何排序
‘壹’ python 字典排序
dict_a={0:5,1:4,2:5,3:4,4:2,5:2,6:2,7:0,8:2,9:0,10:2,11:0,12:0,13:4,14:0,15:0,16:0,17:0,18:0,19:0,20:0,21:0,22:0,23:2,24:3,25:2,26:0,27:1,28:1,29:0,30:2,31:3,32:3,33:3}
dict_b=sorted(dict_a.iteritems(),key=lambdad:d[1],reverse=True)
printdict_a
printdict_b
foriinrange(5):
printdict_b[i][0]
‘贰’ Python字典嵌套字典排序,该怎么处理
感觉这个需求有些许问题,因为通常对比排序的都是同一类型的数据,譬如aaa代表是年龄,bbb代表的是工资,等等... 所以不会拿自己的年龄和工资作一次排序。
# 要做的话,可以手动给它并成一个新列‘sort_key’。 obj就是你最外层的a,免得同名混淆
for i in obj:
obj[i]['sort_key'] = obj[i].values()[0]
# 目的是构造出这样的结构:
# ('c', {'sort_key': 1, 'ccc': 1}), ('d', {'sort_key': 2, 'ddd': 2}), .....)
print(sorted(obj.items(), key = lambda x:x[1]['sort_key']))
‘叁’ python怎么对字典进行排序
给你看看这个字典
dic
=
{'a':1
,
'b':2
,
'c':
3},字典中的元素没有顺序,所以dic[0]是有语法错误的。并且不可以有重复的键值,所以
dic.add['c']
=
4后,字典变成
{'a':1
,
'b':2
,
'c':
4}.现思考如下:如何根据需要可以根据“键”或“键值”进行不同顺序的排序?函数原型:sorted(dic,value,reverse)解释:dic为比较函数,value
为排序的对象(这里指键或键值),
reverse:注明升序还是降序,true--降序,false--升序(默认)案例:dic
=
{'a':1
,
'b':2
,
'c':
3}1.print
sorted(dic.iteritems(),
key
=
lambda
asd:asd[0]
,reverse
=
true)#结果:[('c',
3),
('b',
2),
('a',
1)]2.print
sorted(dic.iteritems(),
key
=
lambda
asd:asd[0]
)#结果:[('a',
1),
('b',
2),
('c',
3)]
,默认(升序)3.print
sorted(dic.iteritems(),
key
=
lambda
asd:asd[1]
)#结果:[('a',
1),
('b',
2),
('c',
3)]这里介绍两个函数:1.lambda案例:fuc
=
lambda
x:x+
2print
fuc(3)
#结果5,意思对于x
,返回
x
+
22.iteritems()案例:dic
=
{'a':1
,
'b':2
,
'c':
3}print
dic.iteritems()
#
返回字典键-值对的一个迭代器在函数sorted(dic.iteritems(),
key
=
lambda
asd:asd[1])中,第一个参数传给第二个参数“键-键值”,第二个参数取出其中的键(【0】)或键值(【1】)
‘肆’ python 字典排序
字典是无序的,兄弟
你看嘛:
>>>testmap={123:['aaa',5],234:['bbb',2],345:['ccc',3],456:['ddd',1]}
>>>printtestmap
{456:['ddd',1],345:['ccc',3],234:['bbb',2],123:['aaa',5]}
>>>testmap={456:['ddd',1],234:['bbb',2],345:['ccc',3],123:['aaa',5]}
>>>printtestmap
{456:['ddd',1],345:['ccc',3],234:['bbb',2],123:['aaa',5]}
>>>
‘伍’ Python字典如何排序啊,给例子谢谢
在Python2.7.x版本中, collections类增加了OrderedDict, 用法如下:
在Python2.7.x版本中, collections类增加了OrderedDict, 用法如下:
pywugw@pywugw-laptop:~$ /usr/local/bin/python2.7
Python 2.7b1 (r27b1:79927, Apr 26 2010, 11:44:19)
[GCC 4.4.3] on linux2
Type "help", "right", "credits" or "license" for more information.
>>> from collections import OrderedDict
>>> d = {'banana': 3, 'apple':4, 'pear': 1, 'orange': 2}
#按key排序
>>> OrderedDict(sorted(d.items(), key=lambda t: t[0]))
OrderedDict([('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)])
#按value排序
>>> OrderedDict(sorted(d.items(), key=lambda t: t[1]))
OrderedDict([('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)])
#按key的长度排序
>>> OrderedDict(sorted(d.items(), key=lambda t: len(t[0])))
OrderedDict([('pear', 1), ('apple', 4), ('orange', 2), ('banana', 3)])
‘陆’ python中字典能排序吗
用标准的dict生成的字典是无序的。但python在标准库中提供了ordereddict,它提供了有序字典的数据结构。

‘柒’ python字典怎么排序
python字典怎么排序?
定义一个字典类型
mydict = {2: '小路', 3: '黎明', 1: '郭富城', 4:'周董'}
可分别打印 key和value 看一下数据
按KEY排序,使用了 lambda和 reverse= False(正序)
key和value都输出
reverse= True(逆序)
按value排序,汉字次序不是按拼音输出
sorted并不改变字典本身的数据次序。
输出后为列表和元组
可以 A = sorted(mydict.items(),key = lambda mydict:mydict[1],reverse= False) 赋值给A ,A的次序是变化后的
推荐:《Python教程》
注意事项
sorted并不改变字典本身的数据次序
如果要变化后的 可以赋值给另一个列表变量以上就是小编分享的关于python字典怎么排序的详细内容希望对大家有所帮助,更多有关python教程请关注环球青藤其它相关文章!
‘捌’ python字典是否有序
默认情况下Python的字典输出顺序是按照键的创建顺序。
字典的无序是指,不能人为重新排序。
比如说你按键值1,2,3,4的顺序创建的字典,只能由解析器按创建顺序,还是1,2,3,4的输出。
你无法控制它按照4,3,2,1的顺序输出,你也无法做到1,3,2,4的顺序。
而且这个输出顺序是也不是能真正按照创建顺序可以控的。
这里面有两个影响因素:
(1)键值的哈希碰撞,hash(key1) == hash(key2)时,向字典里连续添加的这个两个键的顺序是不可以控制的,也是无法做到连续的,后来的键会按算法调整到其它位置。
(2)字典空间扩容,当键的数量超过字典默认开的空间时,字典会做空间扩容,扩容后的键顺和创建顺序就会发生变化,不受人为控制。
‘玖’ Python怎么排序字典,当字典里的值都是一个类的实例化对象,键为不同的字符串,根据实例化对象的值x排序
http://www.360doc.cn/article/16740871_381432205.html
很容易,调用函数按值排序就好了。
‘拾’ python 字典是按照什么排序的
按hash表内的顺序排。其实是有顺序的,但是一直假装没有顺序。如果需要有顺序的字典就用ordereddict
