将条件逻辑表述为数组运算

numpy.where()是一个三目运算的表达式

 In [34]: xarr = np.array([1.1,1.2,1.3,1.4,1.5])

 In [35]: yarr = np.array([2.1,2.2,2.3,2.4,2.5])

 In [36]: condi = np.array([True,False,True,True,False])

假设有上面三个数组,当condi中的值为True的时候,从xarr中选取值,否则从yarr中选取值,组成一个新的数组。利用普通的列表推导式如下:

result = [(x if c else y) for x,y,c in zip(xarr,yarr,condi)]

但是这种方式有缺点:在进行大量数据处理的时候,速度并不快(速度慢就是python的“特色”)。无法运用到多维数组中。

用where方法就简单好多了

result = np.where(condi,xarr,yarr)

numpy.where的第二个和第三个参数,不一定非得是数组,它们也可以是标量。

假设我们希望根据condi生成一个新的数组,如果condi中的值为True时,选择数字1,否则为数字0。

In [41]: res = np.where(condi,1,0)

In [42]: res
Out[42]: array([1, 0, 1, 1, 0])

在一个多维数组中,用“+”代替正数,“-”代替负数

In [46]: arr = np.random.randn(4,4)

In [47]: arr
Out[47]:
array([[-0.33641281, -0.56924078, 0.25727917, -0.35087934],
[-0.00734107, -0.47985579, -1.35289703, -1.31366566],
[-0.71342875, -0.21957414, -1.25596815, 0.0859283 ],
[-0.93246019, -0.61227975, -0.87573005, 1.4124276 ]]) In [48]: np.where(arr>0,"+","-")
Out[48]:
array([['-', '-', '+', '-'],
['-', '-', '-', '-'],
['-', '-', '-', '+'],
['-', '-', '-', '+']], dtype='<U1')

where还可以实现多条件运算

In [51]: np.where(cond1 &cond2 ,0, np.where(cond1,1,np.where(cond2,2,3)))

#类似于
li=[]
for x,y in zip(cond1,cond2):
if x and y:
li.append(0)
elif x :
li.append(1)
elif y:
li.append(2)
else:
li.append(3)

数学和统计方法

sum、mean、std 既可以作为数组的方法调用,也可以作为NumPy的顶级函数调用。

In [63]: arr = np.arange(15).reshape(3,5)

In [64]: arr
Out[64]:
array([[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14]])
#作为数组的方法调用
In [65]: arr.sum()
Out[65]: 105
In [67]: arr.mean()
Out[67]: 7.0
#作为numpy的顶级方法调用
In [68]: np.mean(arr)
Out[68]: 7.0

mean、sum这类的函数可以接受一个参数,用于计算该轴向上的统计值,最终结果是一个少一维的数组

In [69]: arr = np.arange(60).reshape(3,4,5)

In [70]: arr
Out[70]:
array([[[ 0, 1, 2, 3, 4],
[ 5, 6, 7, 8, 9],
[10, 11, 12, 13, 14],
[15, 16, 17, 18, 19]], [[20, 21, 22, 23, 24],
[25, 26, 27, 28, 29],
[30, 31, 32, 33, 34],
[35, 36, 37, 38, 39]], [[40, 41, 42, 43, 44],
[45, 46, 47, 48, 49],
[50, 51, 52, 53, 54],
[55, 56, 57, 58, 59]]]) In [71]: arr.sum(axis = 1)#参数的值为shape的索引,不了解shape可以去看一下numpy基础知识那一篇blog
Out[71]:
array([[ 30, 34, 38, 42, 46],
[110, 114, 118, 122, 126],
[190, 194, 198, 202, 206]])

sum(axis=1)将指定的维度的数组进行聚合求和

其他如cumsum和cumprod之类的方法则不进行聚合,而是产生一个由中间结果组成的数组:

In [72]: arr = np.array([[0,1,2],[3,4,5],[6,7,8]])

In [73]: arr
Out[73]:
array([[0, 1, 2],
[3, 4, 5],
[6, 7, 8]]) In [74]: arr.cumsum()
Out[74]: array([ 0, 1, 3, 6, 10, 15, 21, 28, 36], dtype=int32) In [75]: arr.cumsum(0)
Out[75]:
array([[ 0, 1, 2],
[ 3, 5, 7],
[ 9, 12, 15]], dtype=int32) In [76]: arr.cumsum(1)
Out[76]:
array([[ 0, 1, 3],
[ 3, 7, 12],
[ 6, 13, 21]], dtype=int32) In [77]: arr.cumprod(1)
Out[77]:
array([[ 0, 0, 0],
[ 3, 12, 60],
[ 6, 42, 336]], dtype=int32)

作为顶级函数的用法

In [78]: np.cumsum(arr)
Out[78]: array([ 0, 1, 3, 6, 10, 15, 21, 28, 36], dtype=int32) In [79]: np.cumsum(arr,axis =0)
Out[79]:
array([[ 0, 1, 2],
[ 3, 5, 7],
[ 9, 12, 15]], dtype=int32)

用于布尔型数组的方法:sum、any和all

In [82]: bools = np.array([True,False,True,True,False])

In [83]: bools.sum()
Out[83]: 3 In [84]: In [84]: bools.any()
Out[84]: True In [85]: bools.all()
Out[85]: False
#顶级函数
In [86]: np.all(bools)
Out[86]: False In [87]: np.sum(bools)
Out[87]: 3 In [88]:

排序

方法基本跟python的list一样

In [93]: arr = np.random.randn(8)

In [94]: arr
Out[94]:
array([-2.97429771, 0.37645009, -0.04291609, -0.61994895, -0.26251303,
-1.1557209 , -0.19910847, -0.11393288]) In [95]: arr.sort() In [96]: arr
Out[96]:
array([-2.97429771, -1.1557209 , -0.61994895, -0.26251303, -0.19910847,
-0.11393288, -0.04291609, 0.37645009])

对于多维数组,可以指定axis参数,用于任意一个轴向上排序

In [97]: arr = np.random.randn(4,5)

In [98]: arr
Out[98]:
array([[-0.78510617, -0.02370449, -0.12615757, -0.15039283, -1.00503264],
[ 0.24344011, -1.91231612, 0.80572501, -0.6740432 , -1.62471378],
[-0.09096377, 1.79134715, -0.28566318, -0.8119145 , -0.20454602],
[ 0.02648784, 0.57795444, -0.53447708, -0.74497177, -0.04684859]]) In [99]: arr.sort(1) In [100]: arr
Out[100]:
array([[-1.00503264, -0.78510617, -0.15039283, -0.12615757, -0.02370449],
[-1.91231612, -1.62471378, -0.6740432 , 0.24344011, 0.80572501],
[-0.8119145 , -0.28566318, -0.20454602, -0.09096377, 1.79134715],
[-0.74497177, -0.53447708, -0.04684859, 0.02648784, 0.57795444]]) In [101]: arr = np.random.randn(4,5) In [102]: arr
Out[102]:
array([[-0.99257127, 0.36384095, 1.14265096, 0.23094948, 1.42900315],
[ 0.07606583, 1.53456921, 1.15069057, -0.78014895, -0.24934741],
[ 0.63191444, 0.23237672, 0.4590821 , 0.01904812, 1.63680472],
[-1.24936364, -0.44730791, -0.30612594, -1.05307121, 1.28685507]]) In [103]: arr.sort(0) In [104]: arr
Out[104]:
array([[-1.24936364, -0.44730791, -0.30612594, -1.05307121, -0.24934741],
[-0.99257127, 0.23237672, 0.4590821 , -0.78014895, 1.28685507],
[ 0.07606583, 0.36384095, 1.14265096, 0.01904812, 1.42900315],
[ 0.63191444, 1.53456921, 1.15069057, 0.23094948, 1.63680472]])

需要注意的是顶级排序函数,返回的数组以排序的副本,而就地排序则会修改数组本身。

In [105]: arr = np.random.randn(4,5)

In [106]: arr_repeat=np.sort(arr,axis =1)

In [107]: arr_repeat
Out[107]:
array([[-0.64056336, 0.14082859, 0.44317426, 0.60988308, 0.77472024],
[-1.63521891, 0.39869871, 0.55635461, 0.58039867, 0.59073797],
[-1.62714899, -0.66642289, -0.16457651, 0.09046719, 0.5139126 ],
[-0.79493979, 0.12287039, 0.50570075, 1.08870126, 1.34838367]]) In [108]: arr
Out[108]:
array([[ 0.60988308, 0.44317426, 0.14082859, 0.77472024, -0.64056336],
[ 0.59073797, 0.55635461, 0.58039867, -1.63521891, 0.39869871],
[-0.16457651, -1.62714899, -0.66642289, 0.5139126 , 0.09046719],
[ 0.50570075, 1.34838367, 0.12287039, 1.08870126, -0.79493979]])

sort还有两个参数kind和order,kind是指定排序的算法,默认是快排,还有堆排序和归并排序 【quicksort,mergesort,heapsort】。order:一个字符串或列表,可以设置按照某个属性进行排序

import numpy as np
>>> dtype = [('Name', 'S10'), ('Height', float), ('Age', int)]
>>> values = [('Li', 1.8, 41), ('Wang', 1.9, 38),('Duan', 1.7, 38)]
>>> a = np.array(values, dtype=dtype)
>>> np.sort(a, order='Height') # 按照属性Height进行排序,此时参数为字符串
array([('Duan', 1.7, 38), ('Li', 1.8, 41),('Wang', 1.9, 38)],
dtype=[('Name', '|S10'), ('Height', '<f8'), ('Age', '<i4')])
>>> np.sort(a, order=['Age', 'Height'])
# 先按照属性Age排序,如果Age相等,再按照Height排序,此时参数为列表
array([('Duan', 1.7, 38), ('Wang', 1.9, 38),('Li', 1.8, 41)],
dtype=[('Name', '|S10'), ('Height', '<f8'), ('Age', '<i4')])

唯一化以及其他的一些集合逻辑运算

唯一化其实就是去重。ufunc是 numpy.unique()

In [119]: my_list = np.array([1,3,4,6,7,4,3,1,2])

In [120]: np.unique(my_list)
Out[120]: array([1, 2, 3, 4, 6, 7])

注意:数组本身没有unique方法。

numpy的集合函数

numpy利用数组进行数据处理的更多相关文章

  1. Numpy 利用数组进行数据处理

    Numpy数组使你可以将许多种数据处理任务表述为简洁的数组表达式(否则需要编写循环). 用数组表达式代替循环的做法,通常被称为矢量化.一般来说,矢量化数组运算要比等价的纯跑一趟湖南快 上一两个数量级( ...

  2. numpy使用数组进行数据处理

    numpy使用数组进行数据处理 meshgrid函数 理解: 二维坐标系中,X轴可以取三个值1,2,3, Y轴可以取三个值7,8, 请问可以获得多少个点的坐标? 显而易见是6个: (1,7)(2,7) ...

  3. 利用Python进行数据分析 第4章 NumPy基础-数组与向量化计算(3)

    4.2 通用函数:快速的元素级数组函数 通用函数(即ufunc)是一种对ndarray中的数据执行元素级运算的函数. 1)一元(unary)ufunc,如,sqrt和exp函数 2)二元(unary) ...

  4. python数据分析 Numpy基础 数组和矢量计算

    NumPy(Numerical Python的简称)是Python数值计算最重要的基础包.大多数提供科学计算的包都是用NumPy的数组作为构建基础. NumPy的部分功能如下: ndarray,一个具 ...

  5. NumPy 迭代数组

    NumPy 迭代数组 NumPy 迭代器对象 numpy.nditer 提供了一种灵活访问一个或者多个数组元素的方式. 迭代器最基本的任务的可以完成对数组元素的访问. 接下来我们使用 arange() ...

  6. Java利用数组随机抽取幸运观众

    编写程序,事先将所有观众姓名输入数组,然后获得数组元素的总数量,最后在数组元素中随机抽取元素的下标,根据抽取的下标获得幸运观众的姓名. 思路如下: 定义输入框的按键事件,使用KeyEvent类的get ...

  7. 找出numpy array数组的最值及其索引

    在list列表中,max(list)可以得到list的最大值,list.index(max(list))可以得到最大值对应的索引 但在numpy中的array没有index方法,取而代之的是where ...

  8. ACM -- 算法小结(一)利用数组存放实现排序

    利用数组存放实现排序    hodj1425   321MS   2011/08 题意:输入n个数字,要求输出从大到小排序的前m个数 解题技巧:利用大数存储在数组后面,小数存储在前面,倒序输出完成从大 ...

  9. poj 2262 筛法求素数(巧妙利用数组下标!)

    Goldbach's Conjecture Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 41582   Accepted: ...

随机推荐

  1. jquery样式表和效果

    $("p").css({ "color": "#ff0011", "background": "blue&qu ...

  2. 使用NGINX反向代理做小偷站

    用Nginx的反向代理可以轻松山寨对方的网站,但是反向代理后的网站还是有对方的绝对链接时,怎么办?所以要用替换链接方法. 1 使用官方的的模块 编译参数–with-http_sub_moduleub_ ...

  3. Charles 的几个调试技巧

    Charles 是一个网络调试的代理工具,类似 Windows 下的 Fildder,这里介绍下几个常用的调试技巧,使用的版本是 Charles 4. 1.移动端抓包 在移动开发中,经常会遇到在手机上 ...

  4. C语言指针解说

    指针是C语言的一种数据类型.类似于C中的其它类型,比如int ,char 等.既然指针是一种类型,当我们定义该类型变量.该类型变量就称为指针变量. C中有了指针就有了指向. 指向:指针变量指向本身保存 ...

  5. 修改PHP session 默认时间方法

    修改三行如下: 1.session.use_cookies把这个的值设置为1,利用cookie来传递sessionid 2.session.cookie_lifetime这个代表SessionID在客 ...

  6. 关于fork()父子进程返回值的问题

    我们都知道,父进程fork()之后返回值为子进程的pid号,而子进程fork()之后的返回值为0.那么,现在就有一个问题了,子进程fork()的返回值是怎么来的?如果子进程又执行了一遍fork()函数 ...

  7. 依赖Spring的情况下,Java Web项目如何在启动时加载数据库中的数据?

    原文:https://blog.csdn.net/u012345283/article/details/39558537 原文:https://blog.csdn.net/wandrong/artic ...

  8. Linux 文件管理(C语言库函数三)

    找到当前目录 char *getcwd(char * buf,size_t size) getcwd函数把当前工作目录的绝对路径名复制到buf中,size指示buf的大小 如果buf不够大,不能装下整 ...

  9. makefile编写---.so动态库的生成和调用

    http://blog.sina.com.cn/s/blog_559f6ffc0100fl3z.html  动静 http://blog.csdn.net/yuyunliuhen/article/de ...

  10. linux系统启动过程具体解释-开机加电后发生了什么 --linux内核剖析(零)

    本文參考了例如以下文章 深入理解linux启动过程 mbr (主引导记录(Master Boot Record)) 电脑从开机加电到操作系统main函数之前执行的过程 详细解释linux系统的启动过程 ...