赞
踩
系列文章回顾
【python】(01)初识装饰器Decorator
【python】(02)初识迭代器Iterator
【python】(03)初识生成器Generator
【python】(04)python中实现多任务并发和并行的区别
【python】(05)如何使用python中的logging模块记录日志信息
【python】(06)理解Python中的 lambda 、map、filter、reduce 函数
【python】(07)理解Python中函数的参数类型
【python】(08)理解Python中的可变对象和不可变对象
【python】(09)理解Python中的zip()和zip(*iterable)
【python】(10)理解Python中的数据聚合和分组运算
【python】(11)理解Python中的常用队列类型
【python】(12)理解Python中的三种常用的数组操作函数stack、hstack和vstack
【python】(13)理解Python中的处理时间的模块
【python】(14)理解Python中的pypinyin库
【python】(15)python的series进行值替换的4种代码实现方法
【python】(16)python的字典dict按照key或value排序的不同方法
本文介绍了6种用python实现字典dict按照key或value排序的方法,可发现以下5个结论:
1)字典dict按照key排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = dict(sorted(my_dict.items(), key=lambda item: item[0]))
print(sorted_dict)
2)字典dict按照value排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = dict(sorted(my_dict.items(), key=lambda item: item[1]))
print(sorted_dict)
简单易用,一行代码即可完成排序。
性能相对较差,特别是对于大型字典。
1)字典dict按照key排序
from collections import OrderedDict
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = OrderedDict(sorted(my_dict.items()))
print(sorted_dict)
2)字典dict按照value排序
from collections import OrderedDict
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = OrderedDict(sorted(my_dict.items(), key=lambda x: x[1]))
print(sorted_dict)
返回的是有序的字典,可以保留原始插入顺序。
对于大型字典,性能可能会有所下降。
1)字典dict按照key排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_keys = sorted(my_dict.keys())
sorted_dict = {k: my_dict[k] for k in sorted_keys}
print(sorted_dict)
2)字典dict按照value排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_keys = sorted(my_dict, key=my_dict.get)
sorted_dict = {k: my_dict[k] for k in sorted_keys}
print(sorted_dict)
灵活性强,可以方便地对key或value进行其他操作。
需要多行代码来完成排序,不如一行代码的sorted()函数简洁。
1)字典dict按照key排序
from operator import itemgetter
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = dict(sorted(my_dict.items(), key=itemgetter(0)))
print(sorted_dict)
2)字典dict按照value排序
from operator import itemgetter
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_dict = dict(sorted(my_dict.items(), key=itemgetter(1)))
print(sorted_dict)
itemgetter函数可以提高排序的性能。
相对于lambda表达式,语法略显复杂。
1)字典dict按照key排序
import pandas as pd
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_series = pd.Series(my_dict).sort_index()
sorted_dict = sorted_series.to_dict()
print(sorted_dict)
2)字典dict按照value排序
import pandas as pd
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_series = pd.Series(my_dict).sort_values()
sorted_dict = sorted_series.to_dict()
print(sorted_dict)
使用pandas库的Series对象可以方便地进行数据分析和处理。
引入了pandas库,对于小规模的操作可能显得过于庞大。
1)字典dict按照key排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_items = sorted(zip(my_dict.keys(), my_dict.values()))
sorted_dict = dict(sorted_items)
print(sorted_dict)
2)字典dict按照value排序
my_dict = {'c': 3, 'a': 1, 'b': 2}
sorted_items = sorted(zip(my_dict.values(), my_dict.keys()))
sorted_dict = {k: v for v, k in sorted_items}
print(sorted_dict)
可以一次性解决键值对的排序。
需要额外的步骤将排序后的元组转换为字典。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。