python sort 和sorted的区别和用法
1.最好的学习方法是看帮助文章
>>> help(list.sort)
sort(...)
L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*;
cmp(x, y) -> -1, 0, 1
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
2.函数的作用(以及主要区别)
(1)sort():是容器的函数,是可变对象(字典,列表)的方法,无返回值,但会改变原来对象的排序
(2)sorted():是一个内建函数,接受一个序列,返回有序的副本,但原来的对象顺序不变
3.参数说明:
(1)cmp():用于比较的函数,比较什么由key决定,有默认值是迭代集合中的一项,是带两个参数的比较函数。
返回值为:负数: e1 < e2, 0: e1 == e2, 正数: e1 > e2。 默认为 None
(2)key():用列表元素的某个已命名的属性或函数(只有一个参数并且返回一个用于排序的值)作为关键字
(3)reverse:True 降序 False(默认)升序
4.实例
(1)sort和sorted比较(注意差别):
>>> l=[4,2,6,8,10]
>>> l.sort()
>>> l (源列表顺序已改变)
[2, 4, 6, 8, 10]
>>> l=[4,2,6,8,10]
>>> sorted(l)
[2, 4, 6, 8, 10] (返回一个排序好的新列表)
>>> l
[4, 2, 6, 8, 10] (源列表顺序已改变)
(2)如果list中由tuple组成,默认情况下,sort和sorted都会根据tuple[0]作为排序的key进行排序
例如:
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort() (按着tuple[0]进行排序)
>>> l1
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>>
>>>
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>>
>>> sorted(l1) (按着tuple[0]进行排序))
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(3)用key函数进行排序
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort(key=lambda item : item[2])
>>> l1
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> sorted(l1,key=lambda item : item[2])
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(4)用cmp函数进行排序
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort(cmp=lambda a,b : cmp(a[0], b[0])) (基于tuple[0]进行排序)
>>> l1
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>>
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> sorted(l1, cmp=lambda a,b : cmp(a[2], b[2])) (基于tuple[2]进行排序)
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(5)对字典进行排序
sorted(author_cate_dict.items(), key=lambda d: d[1], reverse=True)
1.最好的学习方法是看帮助文章
>>> help(list.sort)
sort(...)
L.sort(cmp=None, key=None, reverse=False) -- stable sort *IN PLACE*;
cmp(x, y) -> -1, 0, 1
>>> help(sorted)
Help on built-in function sorted in module __builtin__:
sorted(...)
sorted(iterable, cmp=None, key=None, reverse=False) --> new sorted list
2.函数的作用(以及主要区别)
(1)sort():是容器的函数,是可变对象(字典,列表)的方法,无返回值,但会改变原来对象的排序
(2)sorted():是一个内建函数,接受一个序列,返回有序的副本,但原来的对象顺序不变
3.参数说明:
(1)cmp():用于比较的函数,比较什么由key决定,有默认值是迭代集合中的一项,是带两个参数的比较函数。
返回值为:负数: e1 < e2, 0: e1 == e2, 正数: e1 > e2。 默认为 None
(2)key():用列表元素的某个已命名的属性或函数(只有一个参数并且返回一个用于排序的值)作为关键字
(3)reverse:True 降序 False(默认)升序
4.实例
(1)sort和sorted比较(注意差别):
>>> l=[4,2,6,8,10]
>>> l.sort()
>>> l (源列表顺序已改变)
[2, 4, 6, 8, 10]
>>> l=[4,2,6,8,10]
>>> sorted(l)
[2, 4, 6, 8, 10] (返回一个排序好的新列表)
>>> l
[4, 2, 6, 8, 10] (源列表顺序已改变)
(2)如果list中由tuple组成,默认情况下,sort和sorted都会根据tuple[0]作为排序的key进行排序
例如:
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort() (按着tuple[0]进行排序)
>>> l1
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>>
>>>
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>>
>>> sorted(l1) (按着tuple[0]进行排序))
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(3)用key函数进行排序
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort(key=lambda item : item[2])
>>> l1
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> sorted(l1,key=lambda item : item[2])
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(4)用cmp函数进行排序
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> l1.sort(cmp=lambda a,b : cmp(a[0], b[0])) (基于tuple[0]进行排序)
>>> l1
[(2, 'zhangsan', 100), (6, 'wang', 150), (8, 'li', 50)]
>>>
>>> l1 = [(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
>>> sorted(l1, cmp=lambda a,b : cmp(a[2], b[2])) (基于tuple[2]进行排序)
[(8, 'li', 50), (2, 'zhangsan', 100), (6, 'wang', 150)]
>>> l1
[(2, 'zhangsan', 100), (8, 'li', 50), (6, 'wang', 150)]
(5)对字典进行排序
sorted(author_cate_dict.items(), key=lambda d: d[1], reverse=True)