A. python 字典排序 字典序排序是什么意思
字典就是包含key:value对的集合
比如
L = [{"name": "zhangsan", "birth":19920208, "gender":"m"}, {"name": "lisi", "birth":19900609, "gender":"m"}, {"name": "wanghong", "birth":19950907, "gender":"f"}]
对字典排序就是对列表进行排序后打印:
from operator import itemgetter
L = sorted(L,key=itemgetter('birth'),reverse=True)
for i in range(0,len(L)):
... print("Name: {:10} Gender: {:2} Birth: {}".format(L[i]["name"],L[i]["gender"],L[i]["birth"]))
B. python字典排序问题
python字典里根本就没顺序,即便你用键值大小排序,那你也把所有简直放到一个列表里比较下才能找到最值,最终还是在列表里完成的排序。
C. Python字典排序问题
有的,你可以使用第三方库sortedcontainers,可以使用pip安装它。它由纯Python和快速C实现,能够按顺序自动维护键,而且速度非常快。下面是演示
from sortedcontainers import SortedDict
sd = SortedDict({'c': 3, 'a': 1, 'b': 2})
print(sd)
输出:
SortedDict({'a': 1, 'b': 2, 'c': 3})
D. Python怎么排序字典,当字典里的值都是一个类的实例化对象,键为不同的字符串,根据实例化对象的值x排序
http://www.360doc.cn/article/16740871_381432205.html
很容易,调用函数按值排序就好了。
E. python字典中根据值的大小,按顺序排列键有什么方法
s={"a":"bb","b":"cc","c":"aa"}
deffun(s):
d=sorted(s.iteritems(),key=lambdat:t[1],reverse=False)
returnd
d=fun(s)
printd
iteritems() 得到的[(键,值)]的列表, 通过sorted方法,指定排序的键值key是原来字典中的value属性,其中用到了匿名函数lambda, 参数为t列表,返回第二个元素t[1],也就是每个键值对中的value, 从小到大排序时 reverse=False,从大到小排序是True!
F. python中字典能排序吗
字典本身就是无序的,也就不存在排序。
但是可以参照键、值,就行排序输出元组列表,
例如图中例子
G. python字典是否有序
默认情况下Python的字典输出顺序是按照键的创建顺序。
字典的无序是指,不能人为重新排序。
比如说你按键值1,2,3,4的顺序创建的字典,只能由解析器按创建顺序,还是1,2,3,4的输出。
你无法控制它按照4,3,2,1的顺序输出,你也无法做到1,3,2,4的顺序。
而且这个输出顺序是也不是能真正按照创建顺序可以控的。
这里面有两个影响因素:
(1)键值的哈希碰撞,hash(key1) == hash(key2)时,向字典里连续添加的这个两个键的顺序是不可以控制的,也是无法做到连续的,后来的键会按算法调整到其它位置。
(2)字典空间扩容,当键的数量超过字典默认开的空间时,字典会做空间扩容,扩容后的键顺和创建顺序就会发生变化,不受人为控制。
H. python 字典排序问题 有如下字典,怎么通过key最后面的数字排序,求大神指教。
python中字典存储是无序的,不像元组或列表那样需要通过顺序来取值。字典存储类型为key/value、一个键一个值,取值需要key,获取key用值。没明白你说的“通过key最后面的数字排序”是什么意思,详细描述一下需求