前言
最近在工作中碰到一个小的排序问题,需要按嵌套对象的多个属性来排序,于是发现了Python里的operator模块和sorted函数组合可以实现这个功能。本文介绍了Python用operator模块实现对象的多级排序的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:
比如我有如下的类关系,A对象引用了一个B对象,
class A(object): def __init__(self, b): self.b = b def __str__(self): return "[%s, %s, %s]" % (self.b.attr1, self.b.attr2, self.b.attr3) def __repr__(self): return "[%s, %s, %s]" % (self.b.attr1, self.b.attr2, self.b.attr3) class B(object): def __init__(self, attr1, attr2, attr3): self.attr1 = attr1 self.attr2 = attr2 self.attr3 = attr3 def __str__(self): return "[%s, %s, %s]" % (self.attr1, self.attr2, self.attr3) def __repr__(self): return "[%s, %s, %s]" % (self.attr1, self.attr2, self.attr3)
下面是测试排序代码,这里是按照A对象的内嵌对象B的attr2和attr3属性来排序。
from operator import itemgetter, attrgetter a1 = A(B('u1', 'AAA', 100)) a2 = A(B('u2', 'BBB', 100)) a3 = A(B('u3', 'BBB', 10)) aaa = (a1, a2, a3,) print sorted(aaa, key=attrgetter('b.attr2', 'b.attr3')) print sorted(aaa, key=attrgetter('b.attr2', 'b.attr3'), reverse=True)
运行上面的测试,结果如下:
[[u1, AAA, 100], [u3, BBB, 10], [u2, BBB, 100]] [[u2, BBB, 100], [u3, BBB, 10], [u1, AAA, 100]]
那么,如果我需要先按b.attr2正序,再按b.attr3倒序来排序,可以使用下面组合来实现:
s = sorted(aaa, key=attrgetter('b.attr3'), reverse=True) s = sorted(s, key=attrgetter('b.attr2')) print s
运行结果如下:
[[u1, AAA, 100], [u2, BBB, 100], [u3, BBB, 10]]
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。
本文向大家介绍Python利用Beautiful Soup模块创建对象详解,包括了Python利用Beautiful Soup模块创建对象详解的使用技巧和注意事项,需要的朋友参考一下 安装 通过 pip 安装 Beautiful Soup 模块:pip install beautifulsoup4 。 还可以使用 PyCharm IDE 来写代码,在 PyCharm 中的 Preferences
本文向大家介绍详解利用Angular实现多团队模块化SPA开发框架,包括了详解利用Angular实现多团队模块化SPA开发框架的使用技巧和注意事项,需要的朋友参考一下 0、前言 当一个公司有多个开发团队时,我们可能会遇到这样一些问题: 1.技术选项杂乱,大家各玩各 2.业务重复度高,各种通用api,登录注销,权限管理都需要重复实现(甚至一个团队都需要重复实现) 3.业务壁垒,业务之间的互通变得比较
本文向大家介绍python re模块的高级用法详解,包括了python re模块的高级用法详解的使用技巧和注意事项,需要的朋友参考一下 总结 以上所述是小编给大家介绍的python re模块的高级用法详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!
本文向大家介绍Python实现堆排序的方法详解,包括了Python实现堆排序的方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python实现堆排序的方法。分享给大家供大家参考,具体如下: 堆排序作是基本排序方法的一种,类似于合并排序而不像插入排序,它的运行时间为O(nlogn),像插入排序而不像合并排序,它是一种原地排序算法,除了输入数组以外只占用常数个元素空间。 堆(定义):(
heapq模块实现了python中的堆排序,并提供了有关方法。让用Python实现排序算法有了简单快捷的方式。 heapq的官方文档和源码:8.4.heapq-Heap queue algorithm 下面通过举例的方式说明heapq的应用方法 实现堆排序 #! /usr/bin/evn python #coding:utf-8 from heapq import * def heapsort(i
本文向大家介绍详解python之heapq模块及排序操作,包括了详解python之heapq模块及排序操作的使用技巧和注意事项,需要的朋友参考一下 说到排序,很多人可能第一想到的就是sorted,但是你可能不知道python中其实还有还就中方法哟,并且好多种场景下效率都会比sorted高。那么接下来我就依次来介绍我所知道的排序操作。 sorted(iterable, *, key=None, re