Python中排序常用到的sort 、sorted和argsort函数

本文详细介绍了Python中的sort和sorted函数的使用方法及区别,包括如何利用cmp、key参数进行复杂排序,以及argsort函数的用法。

Python中sort 和 sorted函数

一、介绍
sort函数是list列表中的函数,而sorted可以对list或者iterator进行排序
二、sort和sorted的比较
1、用sort函数对列表排序时会影响列表本身,而sorted不会
举例:

>>> a = [1,2,1,4,3,5]   >>> a.sort()    >>> a   [1, 1, 2, 3, 4, 5]

>>> a = [1,2,1,4,3,5]   >>> sorted(a)   [1, 1, 2, 3, 4, 5]  >>> a   [1, 2, 1, 4, 3, 5]

2、sorted(iterable,cmp,key,reverse)
参数:iterable可以是list或者iterator;
cmp是带两个参数的比较函数;
key 是带一个参数的函数;
reverse为False或者True;
举例说明
(1)用cmp函数排序

>>> list1 = [('david', 90), ('mary',90), ('sara',80),('lily',95)]   >>> sorted(list1,cmp = lambda x,y: cmp(x[0],y[0]))  [('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]   >>> sorted(list1,cmp = lambda x,y: cmp(x[1],y[1]))  [('sara', 80), ('david', 90), ('mary', 90), ('lily', 95)]

(2)用key函数排序

>>> list1 = [('david', 90), ('mary',90), ('sara',80),('lily',95)]   >>> sorted(list1,key = lambda list1: list1[0])  [('david', 90), ('lily', 95), ('mary', 90), ('sara', 80)]   >>> sorted(list1,key = lambda list1: list1[1])  [('sara', 80), ('david', 90), ('mary', 90), ('lily', 95)]

(3)用reverse排序

>>> sorted(list1,reverse = True)    [('sara', 80), ('mary', 90), ('lily', 95), ('david', 90)]

(4)用operator.itemgetter函数排序

from operator import itemgetter
sorted(list1, key=itemgetter(1))
[(‘sara’, 80), (‘david’, 90), (‘mary’, 90), (‘lily’, 95)]
sorted(list1, key=itemgetter(0))
[(‘david’, 90), (‘lily’, 95), (‘mary’, 90), (‘sara’, 80)]

介绍operator.itemgetter函数

    >>> import operator         >>> a = [1,2,3]         >>> b = operator.itemgetter(0)      >>> b(a)        1 

operator.itemgetter函数获取的不是值,而是定义了一个函数。
(5)多级排序

sorted(list1, key=itemgetter(0,1))
[(‘david’, 90), (‘lily’, 95), (‘mary’, 90), (‘sara’, 80)]

3.argsort函数

argsort函数返回的是数组值从小到大的索引值

Examples

One dimensional array:一维数组

x = np.array([3, 1, 2])
np.argsort(x)
array([1, 2, 0])

Two-dimensional array:二维数组

x = np.array([[0, 3], [2, 2]])
x
array([[0, 3],
[2, 2]])

np.argsort(x, axis=0) #按列排序
array([[0, 1],
[1, 0]])

np.argsort(x, axis=1) #按行排序
array([[0, 1],
[0, 1]])

#

例1:

x = np.array([3, 1, 2])
np.argsort(x) #按升序排列
array([1, 2, 0])
np.argsort(-x) #按降序排列
array([0, 2, 1])

x[np.argsort(x)] #通过索引值排序后的数组
array([1, 2, 3])
x[np.argsort(-x)]
array([3, 2, 1])

另一种方式实现按降序排序:

a = x[np.argsort(x)]
a
array([1, 2, 3])
a[::-1]
array([3, 2, 1])

Python中,`sort``sorted`都用于排序操作,但使用方法特性有所不同。 ### 使用方法 - **sort()**:是应用在列表(list)上的方法,使用方法为`list.sort()`。该方法没有返回值,直接对原有列表进行排序操作,排序完成后原列表顺序会改变 [^1][^3][^5]。 - **sorted()**:是Python内置的全局方法,可以对所有可迭代的对象进行排序操作,使用方法为`sorted(iterable)`,其中`iterable`是要排序的可迭代对象。该函数会返回一个新的已排序的可迭代对象,不会改变原来的对象 [^1]。 ### 区别 - **适用对象**:`sort`只能用于列表;而`sorted`可以对所有可迭代对象进行排序,如列表、元组、集合等 [^1]。 - **是否改变原对象**:`sort`会直接修改原列表;`sorted`返回新的可迭代对象,原对象保持不变 [^1]。 - **返回值**:`sort`没有返回值;`sorted`返回一个新的已排序的可迭代对象 [^5]。 ### 示例 以下是`sort()``sorted()`的使用示例代码: ```python # sort() 的使用示例 lst = [3, 1, 4, 1, 5, 9, 2, 6, 5] lst.sort() print(lst) # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9] # sorted() 的使用示例 lst = [3, 1, 4, 1, 5, 9, 2, 6, 5] new_lst = sorted(lst) print(new_lst) # 输出:[1, 1, 2, 3, 4, 5, 5, 6, 9] print(lst) # 输出:[3, 1, 4, 1, 5, 9, 2, 6, 5] ``` 另外,`sorted`函数`sort`方法还有一个`key`参数,可以提供一个函数,它们会根据这个函数的返回值对元素进行排序。示例如下: ```python items = [('apple', 2.5), ('banana', 1.8), ('cherry', 3.0)] # 使用 def 的繁琐方式 def get_price(item): return item[1] sorted_items = sorted(items, key=get_price) print(sorted_items) # 使用 lambda 的简洁方式 sorted_items_lambda = sorted(items, key=lambda item: item[1]) print(sorted_items_lambda) # 输出都是:[('banana', 1.8), ('apple', 2.5), ('cherry', 3.0)] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值