首页 技术 正文
技术 2022年11月7日
0 收藏 467 点赞 357 浏览 1648 个字

共同点

都有三个参数,

cmp用户自定义(指定函数),每个元素都会调用,效率没key高

key带一个参数的函数,用来为每个元素提取比较值

reverse=True    翻转

sort

sort作用的对象一般是列表

sort直接排序后就改变了自己,不用生成新的对象,所以效率更高

>>> m=[1,2,3,4,5]

>>> m.sort(reverse=True

>>> m

[5, 4, 3, 2, 1]

>>> m

[‘This’, ‘is’, ‘a’, ‘test’, ‘string’, ‘from’, ‘Andrew’]

>>> m.sort()

>>> m

[‘Andrew’, ‘This’, ‘a’, ‘from’, ‘is’, ‘string’, ‘test’]

>>> m.sort(key=str.lower)

>>> m

[‘a’, ‘Andrew’, ‘from’, ‘is’, ‘string’, ‘test’, ‘This’]

sorted

python的内置函数

能够接受一切可迭代的对象

排序后不会改变自身,会新建一个对象,因此效率较低,但功能强大

对字典的排序(只是key)

>>> sorted({1: ‘D’, 2: ‘B’, 3: ‘B’, 4: ‘E’, 5: ‘A’})

[1, 2, 3, 4, 5]

>>> sorted(“This is a test string from Andrew”.split(), key=str.lower)

[‘a’, ‘Andrew’, ‘from’, ‘is’, ‘string’, ‘test’, ‘This’]                        #和上面的sort也可以

key参数需要指定一个函数,这个函数一个需要一个参数,且返回一个可用来比较的权值

这个函数仅仅会调用一次,比cmp参数指定的函数效率要高

我们可以使用operator中itemgetter, attrgetter, methodcaller来快速定义key函数,

>>> from operator import itemgetter, attrgetter, methodcaller

>>> sorted(student_tuples, key=itemgetter(1,2))            #允许多级比较

[(‘john’, ‘A’, 15), (‘dave’, ‘B’, 10), (‘jane’, ‘B’, 12)]            #和上面的sort也可以

>>> test            #字典同样也可以多级比较,只不过是指定key

[{‘grade’: ‘A’, ‘score’: 15, ‘name’: ‘john’}, {‘grade’: ‘B’, ‘score’: 10, ‘name’: ‘dave’}, {‘grade’: ‘B’, ‘score’: 12, ‘name’: ‘jane’}]

>>> sorted(test, key=itemgetter(‘score’,’grade’) )

[{‘grade’: ‘B’, ‘score’: 10, ‘name’: ‘dave’}, {‘grade’: ‘B’, ‘score’: 12, ‘name’: ‘jane’}, {‘grade’: ‘A’, ‘score’: 15, ‘name’: ‘john’}]

使用attrgetter,可以对 对象的属性进行排序等

sorted(student_objects, key=attrgetter(‘grade’, ‘age’))

[(‘john’, ‘A’, 15), (‘dave’, ‘B’, 10), (‘jane’, ‘B’, 12)]

对字典排序:

>>> test                #按分数排再按等级排

{‘sun’: [‘E’, 3], ‘zhao’: [‘A’, 90], ‘wang’: [‘A’, 88], ‘li’: [‘B’, 75]}

>>> sorted(test.iteritems(), key=lambda x: (x[1][1],x[1][0]))

[(‘sun’, [‘E’, 3]), (‘li’, [‘B’, 75]), (‘wang’, [‘A’, 88]), (‘zhao’, [‘A’, 90])]

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,983
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,500
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,344
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,127
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,761
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,838