Bootstrap

python对字典进行排序

标准的python字典是无序的。即使对(键、值)对进行了排序,也无法以保留排序的方式将它们存储在dict中。

如果仅仅是按序遍历

如果你只是想要按字典key的顺序来遍历字典,那可以先对字典的 key 列表进行排序,然后遍历即可。

my_dict = {'carl':40,
          'alan':2,
          'bob':1,
          'danny':3}
    
for key in sorted(my_dict.keys()):  # 可以改成for key in sorted(mydict.keys()):
    print("%s: %s" % (key, my_dict[key]))

其中 sorted(my_dict.keys()) 改成 sorted(my_dict) 同样可以达到返回排序后的字典 key 列表的效果

如果真的是想要有序字典

如果你真的是想要一个排好序的字典,而不是按字典key 顺序遍历字典,那么有两种方式,一个是用一个临时字典,在用上面的方式遍历字典的过程中,把key value存在新字典中;第二种方式是借用 ordereddict。

方式一:

my_dict = {'carl':40,
          'alan':2,
          'bob':1,
          'danny':3}
new_dict = {}
    
for key in sorted(my_dict.keys()):
    new_dict[key] = my_dict[key]

print(new_dict)

运行结果,new_dict确实已经是一个按字典key顺序排好了序的字典

{'alan': 2, 'bob': 1, 'carl': 40, 'danny': 3}

方式二:

sorted(my_dict.items())会返回一个 按key拍好了序的列表,将这个列表强转成一个有序字典即可

import collections

my_dict = {'carl':40,
          'alan':2,
          'bob':1,
          'danny':3}

new_dict = {}

print(sorted(my_dict.items()))

new_dict = collections.OrderedDict(sorted(my_dict.items()))
print(new_dict)

运行结果

[('alan', 2), ('bob', 1), ('carl', 40), ('danny', 3)]
OrderedDict([('alan', 2), ('bob', 1), ('carl', 40), ('danny', 3)])

python3.7 以上的版本,可以直接用 dict 代替 OrderDict

import collections

my_dict = {'carl':40,
          'alan':2,
          'bob':1,
          'danny':3}
new_dict = {}

print(sorted(my_dict.items()))

new_dict = dict(sorted(my_dict.items()))
print(new_dict)

运行结果:

[('alan', 2), ('bob', 1), ('carl', 40), ('danny', 3)]
{'alan': 2, 'bob': 1, 'carl': 40, 'danny': 3}

参考:关于python:如何按键对字典进行排序?

;