numpy用法(logical_and, nonzero,arange, reshape)

numpy里面有很多数组矩阵的用法,遇到一个就记一个。

1.np.logical_and/or/not (逻辑与/或/非)

np.logical_and(逻辑与)

Syntax

np.logical_and(x1, x2, *args, **kwargs)

Test

>>> np.logical_and(True, False)
False
>>> np.logical_and([True, False], [False, False])
array([False, False], dtype=bool)

>>> x = np.arange(5)
>>> np.logical_and(x>1, x<4)
array([False, False,  True,  True, False], dtype=bool)

np.logical_or(逻辑或)

Syntax

np.logical_or(x1, x2, *args, **kwargs)

Test

>>> np.logical_or(True, False)
True
>>> np.logical_or([True, False], [False, False])
array([ True, False], dtype=bool)

>>> x = np.arange(5)
>>> np.logical_or(x < 1, x > 3)
array([ True, False, False, False,  True], dtype=bool)

np.logical_not(逻辑非)

Syntax

logical_not(x, *args, **kwargs)
Test
>>> np.logical_not(3)
False
>>> np.logical_not([True, False, 0, 1])
array([False,  True,  True, False], dtype=bool)

>>> x = np.arange(5)
>>> np.logical_not(x<3)
array([False, False, False,  True,  True], dtype=bool)

转自:https://blog.csdn.net/JNingWei/article/details/78651535?locationNum=2&fps=1


2.numpy中的nonzero()的用法

 nonzero(a)返回数组a中值不为零的元素的下标,它的返回值是一个长度为a.ndim(数组a的轴数)的元组,元组的每个元素都是一个整数数组,其值为非零元素的下标在对应轴上的值。例如对于一维布尔数组b1,nonzero(b1)所得到的是一个长度为1的元组,它表示b1[0]和b1[2]的值不为0(False)。

>>> b1=np.array([True, False, True, False])  
>>> np.nonzero(b1)  
(array([0, 2], dtype=int64),)  

对于二维数组b2,nonzero(b2)所得到的是一个长度为2的元组。它的第0个元素是数组a中值不为0的元素的第0轴的下标,第1个元素则是第1轴的下标,因此从下面的结果可知b2[0,0]、b[0,2]和b2[1,0]的值不为0:

>>> b2 = np.array([[True, False, True], [True, False, False]])  
>>> np.nonzero(b2)  
(array([0, 0, 1], dtype=int64), array([0, 2, 0], dtype=int64))  
当布尔数组直接做为 numpy数组 下标时,相当于使用由nonzero()转换之后的元组作为下标对象:
>>> a = np.arange(3*4*5).reshape(3,4,5)  
>>> a  
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]]])  
>>> a[b2]  
array([[ 0,  1,  2,  3,  4],  
       [10, 11, 12, 13, 14],  
       [20, 21, 22, 23, 24]])  
>>> a[np.nonzero(b2)]  
array([[ 0,  1,  2,  3,  4],  
       [10, 11, 12, 13, 14],  
       [20, 21, 22, 23, 24]])  

为了观察变化,下面有一个例子:

dataSet=array(  
    [[1,0,0,0],  
    [0,1,0,0],  
    [0,1,0,0],  
    [0,0,0,1]])  
a=dataSet[:,1]>0.5  
print(a)  
print('--------------')  
print(nonzero(a))  
print('--------------')  
print(nonzero(a)[0])  
print('--------------')  
print(dataSet[nonzero(a)[0],:])  
输出结果:
[False  True  True False]  
--------------  
(array([1, 2], dtype=int64),)  
--------------  
[1 2]  
--------------  
[[0 1 0 0]  
 [0 1 0 0]]  

转自:https://blog.csdn.net/zhihaoma/article/details/51235016


3.range和np.arange()

  • range()返回的是range object,而np.nrange()返回的是numpy.ndarray() 
    range尽可用于迭代,而np.nrange作用远不止于此,它是一个序列,可被当做向量使用。

  • range()不支持步长为小数,np.arange()支持步长为小数

  • 两者都可用于迭代

  • 两者都有三个参数,以第一个参数为起点,第三个参数为步长,截止到第二个参数之前的不包括第二个参数的数据序列 
    某种意义上,和STL中由迭代器组成的区间是一样的,即左闭右开的区间。[first, last)或者不加严谨地写作[first:step:last)

>>>range(1,5)
range(1,5)
>>>tuple(range(1, 5))
(1, 2, 3, 4)
>>>list(range(1, 5))
[1, 2, 3, 4]


>>>r = range(1, 5)
>>>type(r)
<class 'range'>

>>>for  i in range(1, 5):
...    print(i)
1
2
3
4

>>> np.arange(1, 5)
array([1, 2, 3, 4])

>>>range(1, 5, .1)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'float' object cannot be interpreted as an integer

>>>np.arange(1, 5, .5)
array([ 1. ,  1.5,  2. ,  2.5,  3. ,  3.5,  4. ,  4.5])

>>>range(1, 5, 2)
>>>for i in range(1, 5, 2):
...    print(i)
1
3

>>for i in np.arange(1, 5):
...    print(i)
1
2
3
4
转自:https://blog.csdn.net/lanchunhui/article/details/49493633


4.arange(),reshape()用法

arange()用于生成一维数组 

reshape()将一维数组转换为多维数组

import numpy as np

print('默认一维为数组:', np.arange(5))
print('自定义起点一维数组:',np.arange(1, 5))
print('自定义起点步长一维数组:',np.arange(2, 10, 2))
print('二维数组:', np.arange(8).reshape((2, 4)))
print('三维数组:', np.arange(60).reshape((3, 4, 5)))

print('指定范围三维数组:',np.random.randint(1, 8, size=(3, 4, 5)))

输出结果:

默认一维数组: [0 1 2 3 4]
自定义起点一维数组: [1 2 3 4]
自定义起点步长一维数组: [2 4 6 8]
二维数组: [[0 1 2 3]
 [4 5 6 7]]
三维数组: [[[ 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]]]
指定范围三维数组: [[[2 3 2 1 5]
  [6 5 5 6 7]
  [4 4 6 5 3]
  [2 2 3 5 6]]

 [[2 1 2 4 4]
  [1 4 2 1 4]
  [4 4 3 4 2]
  [4 1 4 4 1]]

 [[6 2 2 7 6]
  [2 6 1 5 5]
  [2 6 7 2 1]
  [3 3 1 4 2]]]
[[[3 3 5 6]
  [2 1 6 6]
  [1 1 3 5]]

 [[7 6 5 3]
  [5 6 5 4]
  [6 5 7 1]]]
转自:https://blog.csdn.net/chinacmt/article/details/78548420
  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `np.logical_and` 是 Numpy 中的一个函数,用于对两个布尔型数组进行逻辑与操作。它的用法是: ``` np.logical_and(x1, x2) ``` 其中 `x1` 和 `x2` 是两个布尔型数组。该函数会对 `x1` 和 `x2` 中对应位置的元素进行逻辑与操作,并返回一个新的布尔型数组。 例如: ``` import numpy as np x1 = np.array([True, False, True, False]) x2 = np.array([False, False, True, True]) result = np.logical_and(x1, x2) print(result) #输出 [False, False, True, False] ``` 这里x1,x2 的维度必须相同,如果不同会报错。 ### 回答2: np.logical_and是numpy库中的一个函数,用于实现逻辑与操作。它接受两个数组作为输入,并返回一个新的布尔数组。 这个函数的用法非常简单。它将逐元素地比较两个数组的对应元素,并在两个元素都为True时返回True,否则返回False。 例如,我们有两个数组arr1和arr2,它们的元素分别为[True, False, True]和[False, True, True]。我们可以使用np.logical_and(arr1, arr2)来执行逻辑与操作。 执行这个函数后,返回的结果将是一个新的布尔数组[False, False, True]。这是因为只有在两个数组对应的元素都为True时,结果才为True。 np.logical_and函数也可以同时比较多个数组。只需将所有要比较的数组作为参数传递给函数即可。例如,如果我们有三个数组arr1、arr2和arr3,分别为[True, False, True]、[False, True, True]和[True, True, False],我们可以使用np.logical_and(arr1, arr2, arr3)来执行逻辑与操作。 执行这个函数后,返回的结果将是一个新的布尔数组[False, False, False]。这是因为只有在所有数组对应的元素都为True时,结果才为True。 总结来说,np.logical_and用于实现逻辑与操作,对两个或多个数组中对应元素进行比较,并返回一个新的布尔数组,表示每个元素是否都为True。 ### 回答3: np.logical_and是NumPy库中用于逻辑与操作的函数。它接受两个参数并返回一个布尔数组,该数组对应于两个输入数组中对应元素进行逻辑与操作的结果。 函数的用法如下: np.logical_and(arr1, arr2) 其中,arr1和arr2是两个输入数组,可以是一维或多维数组。 函数返回的布尔数组的形状与输入数组相同,其中的每个元素是对应位置上arr1和arr2中元素进行逻辑与运算的结果,返回True表示逻辑与成立,返回False表示逻辑与不成立。 当输入数组维度不一致时,函数会尝试将输入数组广播到相同的形状,以便进行逻辑与操作。 例如,考虑以下示例: arr1 = np.array([True, True, False, False]) arr2 = np.array([True, False, True, False]) result = np.logical_and(arr1, arr2) 输出结果将是: [True, False, False, False] 在这个例子中,arr1和arr2的第一个元素都是True,所以对应位置的结果也是True。而在arr1和arr2的第二个元素中,只有arr2的元素是False,所以对应位置的结果是False。 可以通过逻辑与操作来实现一些常见的操作,比如筛选数组中满足特定条件的元素。在这种情况下,可以将逻辑与操作应用于两个条件的布尔数组之间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值