gpt4 book ai didi

从字典中提取多个数组并用 numpy 堆叠它们的 Pythonic 方法

转载 作者:行者123 更新时间:2023-11-28 22:13:01 25 4
gpt4 key购买 nike

我有一本字典,里面有数组。我想用 numpy 抓取这些数组并使用 np.dstack 将它们堆叠起来,但我不知道该怎么做。字典格式如下所示,当然减去了 nxx。此外,我在序列中显示了 nx 个数字,虽然字典包含键 n1、n2 直到最高 n 值,但它们实际上并不在序列中。

{'n0': masked_array, 'n1': masked_array, 'n2': masked_array, ..., 'nxx': masked_array}

每对的数据显示为

'n0': masked_array(
data=[[0.13530391454696655, 0.26814308762550354, 0.26814308762550354,
..., --, --, --],
[0.21222707629203796, 0.22386012971401215, 0.19620446860790253,
..., --, --, --],
[0.22701908648014069, 0.23818181455135345, 0.23777709901332855,
..., --, --, --],
...,
[--, --, --, ..., --, --, --],
[--, --, --, ..., --, --, --],
[--, --, --, ..., --, --, --]],
mask=[[False, False, False, ..., True, True, True],
[False, False, False, ..., True, True, True],
[False, False, False, ..., True, True, True],
...,
[ True, True, True, ..., True, True, True],
[ True, True, True, ..., True, True, True],
[ True, True, True, ..., True, True, True]],
fill_value=-inf,
dtype=float32)

使用指定每个实体的打印

print(arraydict['n0'])

提供

[[0.13530391454696655 0.26814308762550354 0.26814308762550354 ... -- --
--]
[0.21222707629203796 0.22386012971401215 0.19620446860790253 ... -- --
--]
[0.22701908648014069 0.23818181455135345 0.23777709901332855 ... -- --
--]
...
[-- -- -- ... -- -- --]
[-- -- -- ... -- -- --]
[-- -- -- ... -- -- --]]

因此,如果它们是单独的变量,我就可以做类似的事情(遵循 n 顺序很重要)

arraystack = np.dstack((n0, n1, n2, n3, ..., nxx, ))

我这辈子都无法概念化如何使用 np.dstack 从字典中提取和堆叠每个从 n0 开始的

arraystack = np.dstack(([arraydict[key] for key in arraydict]))

似乎确实有效,但它似乎没有保持 n0、n1、n2、n3 顺序。

最佳答案

你可以试试

arraystack = np.dstack([arraydict['n'+str(i)] for i in range(len(arraydict))])

这将确保订单得以保留。

关于从字典中提取多个数组并用 numpy 堆叠它们的 Pythonic 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54344872/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com