python排序获得秩(index)
本文先讲述python中的排序函数,然后说明如何获得排序的index。
- python排序函数
- 排序获得秩index
python排序函数
python常用的排序函数有sort和sorted函数。
1.sort函数
是列表list的内置函数,对列表进行排序。需要注意的是它会改变当前列表对象。
函数原型: sort(fun,key,reverse=False)
fun: 是排序函数,默认是归并排序,很少改变这个参数;
key: 是用来指定一个函数,在每次元素比较时被调用,此函数代表排序的规则,也就是你按照什么规则对你的序列进行排序;一般是与lambda函数结合;
reverse: 表明是否逆序,默认的False情况下是按照升序的规则进行排序的,当reverse=True时,便会按照降序进行排序。
2. sorted函数
不只针对列表,是比较通用的排序函数。它不会改变当前列表对象,返回的是一个当前对象排序的副本。
函数原型: sorted(iterable, cmp=None, key=None, reverse=False)
iterable:待排序的可迭代类型的容器;
cmp:用于比较的函数,比较什么由key决定,有默认值,迭代集合中的一项;
key:用列表元素的某个已命名的属性或函数(只有一个参数并且返回一个用于排序的值)作为关键字,有默认值,迭代集合中的一项;
reverse:同上
注意:sort函数会改变列表对象,sorted函数不会改变列表对象。
python排序获得秩
方法一
用python的内置函数enumerate()
对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值。
因此可以与列表生成式相结合,得到秩的列表。返回类型为list
l = [0.9,0.4,0.2,0.5,0.7]
rank = [index for index,value in sorted(list(enumerate(l)),key=lambda x:x[1])]
方法二
用numpy的函数argsort,可以直接获得排序秩。返回类型为numpy的narray
import numpy as np
rank1 = np.argsort(l)