字典排序

import heapq
portfolio = [
        {'name': 'IBM', 'shares': 100, 'price': 91.1},
        {'name': 'AAPL', 'shares': 50, 'price': 543.22},
        {'name': 'FB', 'shares': 200, 'price': 21.09},
        {'name': 'HPQ', 'shares': 35, 'price': 31.75},
        {'name': 'YHOO', 'shares': 45, 'price': 16.35},
        {'name': 'ACME', 'shares': 75, 'price': 115.65}
    ]
    # 方法一
    small= heapq.nsmallest(3, portfolio, key=lambda x: x["price"])
    big= heapq.nlargest(3, portfolio, key=lambda x: x["price"])
    print(small)
    print(big)

	# 方法二
    max_price = sorted(portfolio, key=lambda x: x["price"],reverse=True)[:3:]
    min_price = sorted(portfolio, key=lambda x: x["price"],reverse=False)[:3:]
    print(max_price)
    print(min_price)

方法一
nsmallestn:你要几个元素
iterable:可迭代对象,比如列表、元组等等
key:你要根据可迭代对象里面的年一个元素进行排序
heapq.nsmallest:从小到大排序
heapq.nlargest:从大到小排序
方法二
sorted
返回一个新列表,其中包含按升序排列的iterable中的所有项。
可以提供自定义键函数来自定义排序顺序,以及可以将反转标志设置为按降序请求结果。
reverse=True)[:3:]:降序取前三个,不写[:3:]代表全部
reverse=False)[:3:]:升序取前三个,不惜代表全部

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值