定义的顺序是 i,year,month 这就是形参的顺序调用的时候 给实参 也必须是这个顺序
列表中的数据种类很多,有字符串,有整型,有其他列表的嵌套,还有更多的数据类型,这些数据在列表中往往是错乱的,没有一定的逻辑关系,但是我们在使用列表的时候往往需要按照一定的逻辑关系进行调用或检索.下面就来看看 列表是如何排序和翻转的 ,所谓翻转也就是把既定列表倒序排列.
返回结果:
从上面的返回结果可以看出来,sort()函数如果遇到字符串是按照首字母顺序进行排列的,如果遇到浮点型数据还是按照大小排列.
由上面的结果可以看出来,不同的数据类型是没有办法进行排列的.
这个方法是把原列表中的元素顺序从左至右的重新存放,而不会对列表中的参数进行排序整理.如果需要对列表中的参数进行整理,就需要用到列表的另一种排序方式sort正序排序.
python有两个内置的函数用于实现排序,一个是list.sort()函数,一个是sorted()函数.
区别1:list.sort()函数只能处理list类型数据的排序;sorted()则可以处理多种类型数据的排序.
下面来动手写点代码进行测试:
list进行简单的排序
sorted()进行简单排序
list.sort()和sorted都有默认的参数reverse,该参数的默认值为"False",即默认升序排列.如果要进行降序排列:
对元组进行排列,不能使用list.sort()函数:
对字典的排序可以按照字典的key或者value进行排序:
假如需要排序的数据为一个list,但list的每一个元素都是一个字典,排序的方法如下:
{"name":"jim","age":1},
{"name":"jan","age":10}]print sorted(dic,key=lambda arg:arg.get('age'),reverse=False) #按照每个字典的age的值进行排序,字典的方法dict.get(key)将返回指定键的值.
print sorted(dic,key=lambda arg:arg.get('name'),reverse=False) #按照每个字典的name的值进行排序
假如需要排序的数据为一个二维的list,即list的每一个元素也是一个list,方法与上面的例子类似:
python内置关于排序的工具主要有两个一个是列表自带的 sort() 方法,另外一个是 sorted() 函数.Python 列表内置方法可以直接修改列表.而 sorted() 内置函数从一个可迭代对象(列表,元组等都可以)构建一个新的排序列表.其函数原型分别如下:
对列表进行默认排序
从函数原型来看,可以看到两者都具有两个可选参数,它们都必须指定为关键字参数.
key 指定带有单个参数的函数,用于从 iterable 的每个元素中提取用于比较的键 (例如 key=str.lower).默认值为 None (直接比较元素). key 形参的值应该是个函数(或其他可调用对象),它接受一个参数并返回一个用于排序的键.
假设有其他类型的变量,比如一个自定义的类或者列表中又是一个列表.以官网例子为例有这样一个列表,其元素为元组,
可以用以下方式按照年龄排序
类似的有自定义类
可以用如下方式进行排序
也可以显示定义一个函数,且只有一个参数,返回用于排序的键,比如
都说到这里了大家应该明白就是定义一个函数返回一个用于排序的键,可以用lambda函数或者 def 定义都可以.
上面实现的简单函数实际就是实现了返回一个有序结构的第 n 的元素,或者某个类中的某个属性,所以呢 Python 提供了便利功能,使访问器功能更容易,更快捷.operator 模块有 itemgetter() 、 attrgetter() 函数.分别完成返回第 n 个元素,某个属性功能.上面的排序可以用如下方式进行实现
这种作用先定义如何比较两个变量,以上面的学生列表按照年龄排序为例
这种做法自定义比较函数接收两个形参,返回比较结果(bool),而新式方法接受一个参数,返回的是比较的键.