1. np.where(条件)
a=np.where(b) 目的は、条件を満たす (b) のインデックス位置 (a) を見つけることです。ここで、a と b は両方とも配列型です。簡単な例を見つけてください。
import numpy as np
n=np.array([1,2,4,5])
m=np.array([1,2,3,5])
b=(m!=n[0]) #条件
print(b)
'''
输出b
[False True True True] #这是一个数组。
根据判断条件m中的元素不等于a的第一个元素,返回布尔类型的数据。
'''
a=np.where(b) #b=(m!=n[0])
print(a)
「」
出力
(配列([1, 2, 3], dtype=int64),)
なぜなら、a は条件を満たすインデックス値、つまり True のインデックス位置だからです。
「」
2. np.where(条件, x, y)
np.where(condition, x, y)、条件(condition)を満たしてxを出力、満たさない場合はyを出力します。前の例を続けて説明します。
a=np.where(b,'满足','不满足')
print(a) #['不满足' '满足' '满足' '满足']
b=np.where([[True,False], [True,True]],
[[1,2], [3,4]],
[[9,8], [7,6]])
print(b)
输出
array([[1, 8],
[3, 4]])
上面这个例子的条件为[[True,False], [True,False]],
分别对应最后输出结果的四个值。
第一个值从[1,9]中选,因为条件为True,所以是选1。
第二个值从[2,8]中选,因为条件为False,所以选8,后面的以此类推。
同理,再看下面的一个例子:
a = 7
np.where([[a > 5,a < 5], [a == 10,a == 7]],
[["yes","no"], ["yes","no"]],
[["no","yes"], ["no","yes"]])
输出
array([['yes', 'yes'],
['no', 'no']], dtype='<U3')