1.collections模块中的OrderedDict类,
在迭代的时候保持插入的顺序
因内部维护着另外一个链表,大小是普通字典的两倍.
如果构建一个将来需要序列化为其他格式的映射的时候,OrderedDict非常有用.
from collections import OrderedDict
d = OrderedDict()
d['q'] = 0
d['w'] = 1
d['e'] = 2
d['r'] = 3
print(d)
import json
print(json.dumps(d))
'''
OrderedDict([('q', 0), ('w', 1), ('e', 2), ('r', 3)])
{"q": 0, "w": 1, "e": 2, "r": 3}
'''
对字典进行排序,首先按值,并在值相等时按键进行排序
可以使用sorted()
函数,并为其提供一个key
参数,该参数是一个函数,用于从字典项中提取排序键。在这种情况下,可以返回一个元组,其中第一个元素是值,第二个元素是键。Python在比较元组时会首先比较第一个元素,如果它们相等,则会比较第二个元素,依此类推。
# 原始字典
dict_data = {
'c': 3,
'a': 1,
'b': 2,
'e': 2,
'd': 4,
'f': 3
}
# 对字典进行排序,首先按值,然后按键
sorted_items = sorted(dict_data.items(), key=lambda item: (item[1], item[0]))
# 转换为排序后的字典(注意:Python 3.7+ 中的字典保持插入顺序,但这不是真正的排序)
# 如果你需要一个真正的排序后的字典,可以使用 collections.OrderedDict
from collections import OrderedDict
sorted_dict = OrderedDict(sorted_items)
# 打印排序后的列表和字典
print("Sorted items:", sorted_items)
print("Sorted dictionary:", sorted_dict)