python内置关于排序的工具主要有两个一个是列表自带的 sort() 方法,另外一个是 sorted() 函数.Python 列表内置方法可以直接修改列表.而 sorted() 内置函数从一个可迭代对象(列表,元组等都可以)构建一个新的排序列表.其函数原型分别如下:
对列表进行默认排序
从函数原型来看,可以看到两者都具有两个可选参数,它们都必须指定为关键字参数.
key 指定带有单个参数的函数,用于从 iterable 的每个元素中提取用于比较的键 (例如 key=str.lower).默认值为 None (直接比较元素). key 形参的值应该是个函数(或其他可调用对象),它接受一个参数并返回一个用于排序的键.
假设有其他类型的变量,比如一个自定义的类或者列表中又是一个列表.以官网例子为例有这样一个列表,其元素为元组,
可以用以下方式按照年龄排序
类似的有自定义类
可以用如下方式进行排序
也可以显示定义一个函数,且只有一个参数,返回用于排序的键,比如
都说到这里了大家应该明白就是定义一个函数返回一个用于排序的键,可以用lambda函数或者 def 定义都可以.
上面实现的简单函数实际就是实现了返回一个有序结构的第 n 的元素,或者某个类中的某个属性,所以呢 Python 提供了便利功能,使访问器功能更容易,更快捷.operator 模块有 itemgetter() 、 attrgetter() 函数.分别完成返回第 n 个元素,某个属性功能.上面的排序可以用如下方式进行实现
这种作用先定义如何比较两个变量,以上面的学生列表按照年龄排序为例
这种做法自定义比较函数接收两个形参,返回比较结果(bool),而新式方法接受一个参数,返回的是比较的键.
print(sorted(students,key=lambda s: s[0]))
key指定一个接收一个参数的函数,这个函数用于从每个元素中提取一个用于比较的关键字.默认值为None
例子
为啥会这样呢?默认不是应该按升序排列.
仔细看 我们lambda返回的是一个元祖,(布尔,布尔,绝对值)
由于key函数主要作用是根据我们自己的要求,取出指定的元素来进行排序,不过我们现在返回的是一个元祖,所以我们首先按布尔进行排序,当有相同的我们在往后面一个元素找,然后进行排序,所以就变成这样了.
①.、示例代码
def bigToSmall(uList):
uList.sort()
print(uList)
uList.sort(reverse=True)
bigToSmall(amn)