NumPy имеет эффективную функцию / метод nonzero()
для идентификации индексов ненулевых элементов в ndarray
объекте. Что является наиболее эффективным способом , чтобы получить индексы элементов , которые делают имеют нулевое значение?
Ответы:
numpy.where () - мой любимый.
>>> x = numpy.array([1,0,2,0,3,0,4,5,6,7,8])
>>> numpy.where(x == 0)[0]
array([1, 3, 5])
np.zeros((3,))
для создания трех-длинного вектора. Я подозреваю, что это упрощает синтаксический анализ параметров. В противном случае реализовать что-то вроде np.zeros(3,0,dtype='int16')
versus np.zeros(3,3,3,dtype='int16')
было бы неприятно.
where
возвращает кортеж ndarray
s, каждый из которых соответствует измерению ввода. в этом случае входом является массив, поэтому на выходе будет 1-tuple
. Если бы x было матрицей, то это была бы a 2-tuple
, и так далее
numpy.where
специально рекомендует использовать numpy.nonzero
напрямую, а не вызывать where
только с одним аргументом.
where
, как видно из ответа Душа . Согласно where
документации , where(x)
эквивалентно asarray(x).nonzero()
.
Есть np.argwhere
,
import numpy as np
arr = np.array([[1,2,3], [0, 1, 0], [7, 0, 2]])
np.argwhere(arr == 0)
который возвращает все найденные индексы в виде строк:
array([[1, 0], # Indices of the first zero
[1, 2], # Indices of the second zero
[2, 1]], # Indices of the third zero
dtype=int64)
Вы можете искать любое скалярное условие с помощью:
>>> a = np.asarray([0,1,2,3,4])
>>> a == 0 # or whatver
array([ True, False, False, False, False], dtype=bool)
Что вернет массив как логическую маску условия.
a[a==0] = epsilon
Вы также можете использовать nonzero()
его с помощью булевой маски условия, потому что False
это тоже своего рода ноль.
>>> x = numpy.array([1,0,2,0,3,0,4,5,6,7,8])
>>> x==0
array([False, True, False, True, False, True, False, False, False, False, False], dtype=bool)
>>> numpy.nonzero(x==0)[0]
array([1, 3, 5])
Он делает то же самое, что mtrw
и он, но это больше связано с вопросом;)
nonzero
метод проверки условий.
Вы можете использовать numpy.nonzero, чтобы найти ноль.
>>> import numpy as np
>>> x = np.array([1,0,2,0,3,0,0,4,0,5,0,6]).reshape(4, 3)
>>> np.nonzero(x==0) # this is what you want
(array([0, 1, 1, 2, 2, 3]), array([1, 0, 2, 0, 2, 1]))
>>> np.nonzero(x)
(array([0, 0, 1, 2, 3, 3]), array([0, 2, 1, 1, 0, 2]))
Если вы работаете с одномерным массивом, есть синтаксический сахар:
>>> x = numpy.array([1,0,2,0,3,0,4,5,6,7,8])
>>> numpy.flatnonzero(x == 0)
array([1, 3, 5])
numpy.flatnonzero(numpy.logical_or(numpy.logical_or(x==0, x==2), x==7))
Я бы сделал так:
>>> x = np.array([[1,0,0], [0,2,0], [1,1,0]])
>>> x
array([[1, 0, 0],
[0, 2, 0],
[1, 1, 0]])
>>> np.nonzero(x)
(array([0, 1, 2, 2]), array([0, 1, 0, 1]))
# if you want it in coordinates
>>> x[np.nonzero(x)]
array([1, 2, 1, 1])
>>> np.transpose(np.nonzero(x))
array([[0, 0],
[1, 1],
[2, 0],
[2, 1])
where()
возвращает кортеж?numpy.where(x == 0)[1]
вне поля. с чем тогда связан индексный массив?