博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
『Numpy学习指南』排序&索引&抽取函数介绍
阅读量:5810 次
发布时间:2019-06-18

本文共 2325 字,大约阅读时间需要 7 分钟。

排序:

numpy.lexsort():

numpy.lexsort()是个排字典序函数,因为很有意思,感觉也蛮有用的,所以单独列出来讲一下:

强调一点,本函数只接受一个参数

1 import numpy as np2 3 a = np.array([1,2,3,4,5])4 b = np.array([50,40,30,20,10])5 6 c = np.lexsort((a,b))7 print(list(zip(a[c],b[c])))
[(5, 10), (4, 20), (3, 30), (2, 40), (1, 50)]

 这是一个间接排序函数,会优先使用后面列排序,后面一样才使用前面的列排序,测试如下:

1 a = np.array([1,2,3,4,5])2 b = np.array([40,40,30,20,10])3 4 c = np.lexsort((a,b))5 print(list(zip(a[c],b[c])))
[(5, 10), (4, 20), (3, 30), (1, 40), (2, 40)]

 交换次序:

1 a,b = b,a2 3 c = np.lexsort((a,b))4 print(list(zip(a[c],b[c])))
[(40, 1), (40, 2), (30, 3), (20, 4), (10, 5)]

 而且可以按照此规则进行多列排序(大于2个):

1 a = np.array([1,2,3,4,5])2 b = np.array([50,30,40,20,10])3 d = np.array([400,300,300,100,200])4 5 c = np.lexsort((a,b,d))6 print(list(zip(a[c],b[c],d[c])))
[(4, 20, 100), (5, 10, 200), (2, 30, 300), (3, 40, 300), (1, 50, 400)]

 numpy中的几种排序手段:

numpy.sort()           正常排序

numpy.msort()        正常排序,定死axis=0

Notes    -----    ``np.msort(a)`` is equivalent to  ``np.sort(a, axis=0)``.

array.sort()              原地排序,无return

numpy.argsort()       间接排序

numpy.lexsort()        间接排序,字典序

numpy.sort_complex()      复数排序,先实部后虚部

1 np.random.seed(42)2 complex_number = np.random.random(5) + np.random.random(5)*1j3 print(complex_number)4 print(np.sort_complex(complex_number)) # 复数排序,先实后虚
[ 0.37454012+0.15599452j  0.95071431+0.05808361j  0.73199394+0.86617615j  0.59865848+0.60111501j  0.15601864+0.70807258j][ 0.15601864+0.70807258j  0.37454012+0.15599452j  0.59865848+0.60111501j  0.73199394+0.86617615j  0.95071431+0.05808361j]

 索引:

np.argmax(a)              最大值索引

np.nanargmin(b)         忽略nan的最小值索引

np.argwhere(a<=4)     符合条件的索引

1 a = np.array([2,4,8])2 print(np.argmax(a))3 b = np.array([np.nan,2,4])4 print(np.nanargmin(b))5 c = np.array([2,4,8])6 print(np.argwhere(a<=4))
21[[0] [1]]

np.searchsorted(a,[-2,7])

np.insert(a,indices,[-2,7])

1 a = np.arange(5)2 indices = np.searchsorted(a,[-2,7])   # 返回向有序数组中插入,不改变有序性的索引3 print(indices)4 print(np.insert(a,indices,[-2,7]))    # 插入函数{目标数组,插入索引,插入数组}
[0 5][-2  0  1  2  3  4  7]

 抽取:

np.extract(condition,a)

np.where(a%2==0)

np.nonzero(a)

1 a = np.arange(7)2 condition = (a%2)==03 print(a[a%2==0])                   # 使用布尔索引4 print(np.extract(condition,a))     # 使用np.extract()5 print(np.where(a%2==0))            # 使用np.where()6 print(np.nonzero(a))               # 提取非零元素
[0 2 4 6][0 2 4 6](array([0, 2, 4, 6]),)(array([1, 2, 3, 4, 5, 6]),)

转载地址:http://zrcbx.baihongyu.com/

你可能感兴趣的文章
os模块大全详情
查看>>
【ros】Create a ROS package:package dependencies报错
查看>>
从内积的观点来看线性方程组
查看>>
kali linux 更新问题
查看>>
HDU1576 A/B【扩展欧几里得算法】
查看>>
廖雪峰javascript教程学习记录
查看>>
WebApi系列~目录
查看>>
限制CheckBoxList控件只能单选
查看>>
Java访问文件夹中文件的递归遍历代码Demo
查看>>
项目笔记:测试类的编写
查看>>
如何迅速分析出系统CPU的瓶颈在哪里?
查看>>
通过容器编排和服务网格来改进Java微服务的可测性
查看>>
re:Invent解读:没想到你是这样的AWS
查看>>
PyTips 0x02 - Python 中的函数式编程
查看>>
阿里云安全肖力:安全基础建设是企业数字化转型的基石 ...
查看>>
使用《Deep Image Prior》来做图像复原
查看>>
如何用纯 CSS 为母亲节创作一颗像素画风格的爱心
查看>>
Linux基础命令---rmdir
查看>>
优秀程序员共有的7种优秀编程习惯
查看>>
iOS sqlite3(数据库)
查看>>