我有一个名为 dists
的距离数组。我想选择范围内的 dists
。
dists[(np.where(dists >= r)) and (np.where(dists <= r + dr))]
但是,这仅针对条件进行选择
(np.where(dists <= r + dr))
如果我使用临时变量按顺序执行命令,它就可以正常工作。为什么上面的代码不起作用,我该如何让它起作用?
原文由 user1654183 发布,翻译遵循 CC BY-SA 4.0 许可协议
在 您的特定情况下,最好的方法就是将您的两个标准更改为一个标准:
它只创建一个布尔数组,在我看来更容易阅读,因为它说, 是
dist
在dr
或r
? (虽然我会重新定义r
成为您感兴趣区域的中心而不是开始,所以r = r + dr/2.
)但这并不能回答您的问题。你的问题的答案:
你实际上并不需要
where
如果你只是dists
不符合你的标准的元素:因为
&
会给你一个元素and
(括号是必要的)。或者,如果出于某种原因你确实想使用
where
,你可以这样做:为什么:
它不起作用的原因是因为
np.where
返回索引列表,而不是布尔数组。您正在尝试在两个数字列表之间获取and
,这当然没有您期望的True
/False
值。 Ifa
andb
are bothTrue
values, thena and b
returnsb
.所以说像[0,1,2] and [2,3,4]
只会给你[2,3,4]
。这是在行动:例如,您期望比较的只是布尔数组
现在您可以在组合的布尔数组上调用
np.where
:或者使用 花式索引 简单地用布尔数组索引原始数组