numpy.where — NumPy v1.13 Manual (original) (raw)

numpy. where(_condition_[, x, _y_])

Return elements, either from x or y, depending on condition.

If only condition is given, return condition.nonzero().

Parameters: condition : array_like, bool When True, yield x, otherwise yield y. x, y : array_like, optional Values from which to choose. x, y and condition need to be broadcastable to some shape.
Returns: out : ndarray or tuple of ndarrays If both x and y are specified, the output array contains elements of x where condition is True, and elements from_y_ elsewhere. If only condition is given, return the tuplecondition.nonzero(), the indices where condition is True.

Notes

If x and y are given and input arrays are 1-D, where is equivalent to:

[xv if c else yv for (c,xv,yv) in zip(condition,x,y)]

Examples

np.where([[True, False], [True, True]], ... [[1, 2], [3, 4]], ... [[9, 8], [7, 6]]) array([[1, 8], [3, 4]])

np.where([[0, 1], [1, 0]]) (array([0, 1]), array([1, 0]))

x = np.arange(9.).reshape(3, 3) np.where( x > 5 ) (array([2, 2, 2]), array([0, 1, 2])) x[np.where( x > 3.0 )] # Note: result is 1D. array([ 4., 5., 6., 7., 8.]) np.where(x < 5, x, -1) # Note: broadcasting. array([[ 0., 1., 2.], [ 3., 4., -1.], [-1., -1., -1.]])

Find the indices of elements of x that are in goodvalues.

goodvalues = [3, 4, 7] ix = np.isin(x, goodvalues) ix array([[False, False, False], [ True, True, False], [False, True, False]], dtype=bool) np.where(ix) (array([1, 1, 2]), array([0, 1, 1]))