sorted函数是Python的高阶函数,利用函数名作为参数。实现对另一个参数的数据排序功能。
骨子里还是个排序算法,可对list进行排序。
可以接收一个key函数来实现自定义排序。
sorted函数包含两个参数:
参数一:一个可迭代的数据集。
参数二:一个key函数,以一定的算法对参数一中的元素(某数值或字符串等)进行修改和计算。
例如:
按照绝对值大小排序
sorted([36, 5, -12, 9, -21], key=abs)
#结果为:[5, 9, -12, -21, 36]
将abs作为key函数,对第一个参数list的每个元素进行改造,取绝对值,再由小到大进行排序。
注意,排序的元素仍然保持原来的数值。
再来一个例子:
sorted之字符串排序忽略大小写
sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower)
#结果为:['about', 'bob’, 'Credit', 'Zoo’]
如果想要从大到小排序,也就是逆序排序,需要再加一个参数:
sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower, reverse=True)
#结果为:['Zoo', 'Credit', 'bob', 'about']
再举一个例子:
假设我们用一组tuple表示学生名字和成绩
L = [('Bob', 75), ('Adam', 92), ('Bart', 66), ('Lisa', 88)]
请用sorted()对上述列表分别按名字排序
首先,先构建函数by_name,功能是取出某tuple的第一个元素。在本例中,将用于取出名字信息。
接下来将by_name作为key函数,构建sorted函数。得到一个排序后的list。
# -*- coding: utf-8 -*-
L = [('Bob', 75), ('Adam', 92), ('Bart', 66), ('Lisa', 88)]
def by_name(t):
return t[0]
L2 = sorted(L, key=by_name)
print(L2)
引申的例子:
如果上面例子按成绩由低到高排序呢?
那应该构建一个新的key函数如下:
def by_score(t):
return t[1]
接下来构建sorted函数
L2 = sorted(L, key=by_score)
print(L2)
如果上面例子按成绩由高到低排序呢?
有两个方法:
第一,构建新的key函数。
def by_score1(t):
return -t[1]
第二,沿用原来的by_score,但改造sorted函数,加入reverse参数
L2 = sorted(L, key=by_score, reverse=True)
print(L2)
听懂了就点个赞吧。