【发布时间】:2015-05-16 18:10:34
【问题描述】:
我想选择数组的某些元素并根据这些值执行加权平均计算。但是,使用过滤条件会破坏数组的原始结构。形状为(2, 2, 3, 2) 的arr 变成了一维数组。这对我没有用,因为并非所有这些元素都需要稍后相互组合(但它们的子数组)。如何避免这种扁平化?
>>> arr = np.asarray([ [[[1, 11], [2, 22], [3, 33]], [[4, 44], [5, 55], [6, 66]]], [ [[7, 77], [8, 88], [9, 99]], [[0, 32], [1, 33], [2, 34] ]] ])
>>> arr
array([[[[ 1, 11],
[ 2, 22],
[ 3, 33]],
[[ 4, 44],
[ 5, 55],
[ 6, 66]]],
[[[ 7, 77],
[ 8, 88],
[ 9, 99]],
[[ 0, 32],
[ 1, 33],
[ 2, 34]]]])
>>> arr.shape
(2, 2, 3, 2)
>>> arr[arr>3]
array([11, 22, 33, 4, 44, 5, 55, 6, 66, 7, 77, 8, 88, 9, 99, 32, 33,
34])
>>> arr[arr>3].shape
(18,)
【问题讨论】:
-
详细说明您需要对这些值进行的计算。你将如何使用
arr结构?