python cookbook 学习笔记 第一章 数据结构和算法(13)排序不支持原生比较的对象

  • 问题
    • 想要排序类型相同的对象,但他们不支持原生的比较操作。
  • 解决方案
    • 内置的函数 sorted() 函数有一个关键字参数key,可以传入一个callable对象给它,这个callable对象 对每个传入的对象返回一个值,这个值会被sorted用来排序这些对象。比如,如果在应用程序里面有一个User 实例序列,并且希望通过他们的User_id属性来进行排序,可以提高一个以User实例作为输入并输出对应User_id 值的 callable 对象。比如:
class User():
    def __init__(self, user_id):
        self.user_id = user_id

    def __repr__(self):
        return "User({})".format(self.user_id)

def sort_notcompare():
    users = [User(23),User(3),User(99)]
    print(users)
    print(sorted(users,key= lambda u: u.user_id))  

sort_notcompare()  # [User(3), User(23), User(99)]
  • 另外一种方式是使用 operator.attrgetter() 来代替 lambda 函数:
from operator import attrgetter

sorted(users,key= attrgetter("user_id"))
  • 讨论: 选择使用 lambda 函数或者是 attrgetter() 可能取决于个人喜好。但是 attrgetter() 函数 通常会运行快点,并且还能同时允许多个字段进行比较。这个跟operator.itemgetter()函数作用于字典类 型很类似。例如,如果 User 实例还有一个first_name 和 last_name 属性,那么可以像下面这样排序:
sorted(users, key= attrgetter("last_name","first_name"))
  • 同时需要注意的是,这一小节讲到的演示,同样使用于像min()和max()之类的函数。比如:
min(users, key= attrgetter("user_id"))  # User(3)
max(users, key= attrgetter("user_id"))  # User(99)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值