怎么在Python中利用sorted对字典的key进行排序?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
sorted函数
sorted(iterable,key,reverse)
对key排序
d:dict={"p":59,"o":9,"s":5,"a":20,"z":18}
li:list=sorted(d.keys())
print(li)
执行结果:
['a', 'o', 'p', 's', 'z']
对value排序
在对value之前, 先来回炉一下Python的lambda表达式
f=lambdax:x+1
print(f(5))
defff(x):
returnx+1
print(ff(5))
执行结果:
66
以上两种方式是等价的, lambda表达式写法更简洁, 一般当做匿名表达式/匿名函数使用
lambda x:y
接下来进入到对字典的value排序正题, 这里就需要使用到lambda表达式
直接对值排序
d:dict={"p":59,"o":9,"s":5,"a":20,"z":18}
li:list=sorted(d.values())
print(li)
执行结果:
[5, 9, 18, 20, 59]
在包含Key的情况下对值排序
d:dict={"p":59,"o":9,"s":5,"a":20,"z":18}
li:list=sorted(d.items(),key=lambdax:x[1])
print(li)
执行结果:
[('s', 5), ('o', 9), ('z', 18), ('a', 20), ('p', 59)]
d.items() 返回以元组形式构成的列表 dict_items([('p', 59), ('o', 9), ('s', 5), ('a', 20), ('z', 18)]) (列表为可迭代对象)
lambda x: x[1] lambda表达式中, x为入参, 每次x的值为一个d.items()中的元素(一个元组), 第一个入参为('p', 59) 冒号后面的x[1]是运算表达式, 意思是取元组中的第二个元素返回(索引为1), 返回的元素即为排序的依据. 所以如果需要对key进行排序, 也可以在表达式里写 x[0]
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注恰卡编程网行业资讯频道,感谢您对恰卡编程网的支持。