python 字典排序

mac2022-06-30  89

对字典进行排序?这其实是一个伪命题,搞清楚python字典的定义---字典本身默认以key的字符顺序输出显示---就像我们用的真实的字典一样,按照abcd字母的顺序排列,并且本质上各自没有先后关系,是一个哈希表的结构:

但实际应用中我们确实有这种排序的“需求”-----按照values的值“排序”输出,或者按照别的奇怪的顺序进行输出,我们只需要把字典转化成list或者tuple,把字典每一对键值转化为list中的两位子list或者子tuple再输出,就可以达到我们的目的:

 

【Python】 sorted函数  

我们需要对List、Dict进行排序,Python提供了两个方法 对给定的List L进行排序, 方法1.用List的成员函数sort进行排序,在本地进行排序,不返回副本 方法2.用built-in函数sorted进行排序(从2.4开始),返回副本,原始输入不变   --------------------------------sorted--------------------------------------- >>> help(sorted) Help on built-in function sorted in module __builtin__: sorted(...)     sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list ---------------------------------sort---------------------------------------- >>> help(list.sort) Help on method_descriptor: sort(...)     L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*;     cmp(x, y) -> -1, 0, 1 ----------------------------------------------------------------------------- iterable:是可迭代类型; cmp:用于比较的函数,比较什么由key决定; key:用列表元素的某个属性或函数进行作为关键字,有默认值,迭代集合中的一项; reverse:排序规则. reverse = True  降序 或者 reverse = False 升序,有默认值。 返回值:是一个经过排序的可迭代类型,与iterable一样。   参数说明: (1)  cmp参数 cmp接受一个函数,拿整形举例,形式为: def f(a,b):      return a-b 如果排序的元素是其他类型的,如果a逻辑小于b,函数返回负数;a逻辑等于b,函数返回0;a逻辑大于b,函数返回正数就行了   (2)  key参数  key也是接受一个函数,不同的是,这个函数只接受一个元素,形式如下 def f(a):      return len(a) key接受的函数返回值,表示此元素的权值,sort将按照权值大小进行排序   (3) reverse参数 接受False 或者True 表示是否逆序     dict={'a':1,'b':2,'c':3,'d':2,'ddd':2,'dd':2,'e':1} ##x表示dict.items()中的一项,这里提供了x的两个值,首先按照字典value值的大小排序,如果value大小相同,则使用索引的字典顺序进行排序 sorted_items = sorted(dict.items(), key=lambda x: (-x[1], x[0])) print(sorted_items)

结果:

 

转载于:https://www.cnblogs.com/shixisheng/p/9936134.html

最新回复(0)