用法:
dask.array.nonzero(a)
返回非零元素的索引。
此文档字符串是从 numpy.nonzero 复制的。
可能存在与 Dask 版本的一些不一致之处。
返回一个数组元组,每个维度对应
a
,包含该维度中非零元素的索引。a
中的值始终以行优先、C-style 顺序进行测试和返回。要按元素而不是维度对索引进行分组,请使用
argwhere
,它为每个非零元素返回一行。注意
在 zero-d 数组或标量上调用时,
nonzero(a)
被视为nonzero(atleast_1d(a))
。- a:array_like
输入数组。
- tuple_of_arrays:元组
非零元素的索引。
参数:
返回:
注意:
虽然可以使用
a[nonzero(a)]
获得非零值,但建议使用x[x.astype(bool)]
或x[x != 0]
代替,这将正确处理 0-d 数组。例子:
>>> x = np.array([[3, 0, 0], [0, 4, 0], [5, 6, 0]]) >>> x array([[3, 0, 0], [0, 4, 0], [5, 6, 0]]) >>> np.nonzero(x) (array([0, 1, 2, 2]), array([0, 1, 0, 1]))
>>> x[np.nonzero(x)] array([3, 4, 5, 6]) >>> np.transpose(np.nonzero(x)) array([[0, 0], [1, 1], [2, 0], [2, 1]])
nonzero
的常见用途是查找条件为 True 的数组的索引。给定一个数组a
,条件a
> 3 是一个布尔数组,并且由于 False 被解释为 0,因此 np.nonzero(a > 3) 产生条件为真的a
的索引。>>> a = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]]) >>> a > 3 array([[False, False, False], [ True, True, True], [ True, True, True]]) >>> np.nonzero(a > 3) (array([1, 1, 1, 2, 2, 2]), array([0, 1, 2, 0, 1, 2]))
使用这个结果来索引
a
相当于直接使用掩码:>>> a[np.nonzero(a > 3)] array([4, 5, 6, 7, 8, 9]) >>> a[a > 3] # prefer this spelling array([4, 5, 6, 7, 8, 9])
nonzero
也可以作为数组的方法调用。>>> (a > 3).nonzero() (array([1, 1, 1, 2, 2, 2]), array([0, 1, 2, 0, 1, 2]))
相关用法
- Python dask.array.not_equal用法及代码示例
- Python dask.array.negative用法及代码示例
- Python dask.array.nancumsum用法及代码示例
- Python dask.array.nanmin用法及代码示例
- Python dask.array.nan_to_num用法及代码示例
- Python dask.array.nansum用法及代码示例
- Python dask.array.nanargmin用法及代码示例
- Python dask.array.nanmax用法及代码示例
- Python dask.array.nanargmax用法及代码示例
- Python dask.array.nanmedian用法及代码示例
- Python dask.array.nextafter用法及代码示例
- Python dask.array.nanmean用法及代码示例
- Python dask.array.nanvar用法及代码示例
- Python dask.array.nanprod用法及代码示例
- Python dask.array.nanstd用法及代码示例
- Python dask.array.nancumprod用法及代码示例
- Python dask.array.stats.ttest_ind用法及代码示例
- Python dask.array.ma.masked_values用法及代码示例
- Python dask.array.divmod用法及代码示例
- Python dask.array.overlap.map_overlap用法及代码示例
注:本文由纯净天空筛选整理自dask.org大神的英文原创作品 dask.array.nonzero。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。