python 学习笔记(三)根据字典中值的大小对字典中的项排序

字典的元素是成键值对出现的,直接对字典使用sorted() 排序,它是根据字典的键的ASCII编码顺序进行排序,要想让字典根据值的大小来排序,可以有两种方法来实现:

一、利用zip函数将字典数据转化为元组再用sorted() 排序 

1 from random import randint
2 # 用随机函数生成待排序的字典数据
3 my_dict = {x: randint(60, 100) for x in 'abcxyzgkj'}
4 # 将字典数据转化为元组,把字典的值作为元组的第0项,键作为元组的第1项
5 my_tuple = zip(my_dict.values(), my_dict.keys())
6 # 打印输出排序后的结果
7 print(sorted(my_tuple))

 

二、传递sorted函数的key参数指定为字典的值

sorted函数的格式:sorted(iterable,key,reverse),sorted有iterable,key,reverse三个参数。

  iterable 表示可以迭代的对象,例如可以是dict.items()、dict.keys()等。

  key 是一个函数,通常使用使用lambda匿名函数来实现,用来选取参与比较的元素。

  reverse 用来指定按倒序还是顺序排序,reverse=True是倒序,reverse=False是顺序,默认reverse=False。

1 from random import randint
2 # 用随机函数生成待排序的字典数据
3 my_dict = {x: randint(60, 100) for x in 'abcxyzgkj'}
4 # 把my_dict.items()所得列表中每个元组的第二个元素(value)传到lambda函数进行排序
5 result = sorted(my_dict.items(), key=lambda x: x[1]) # x[0]是字典的键,x[1]是字典的值
6 # 打印输出排序后的结果
7 print(result)

 第一种方法是对字典中键值的全面比较,先比较值的大小,如果两者相等会接着比较键的大小来排序;第二种方法只比较指定的值的大小,如果两者相等则不会比较键的大小,只依照顺序来排序。

转载于:https://www.cnblogs.com/walo/p/11252162.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值