1

我正在尝试规范化 pytable 和 recarray 的格式,以便将 recarray 附加到 pytable。为此,我需要从recarray 中获取字段信息(即名称和字段格式),我可以使用以下方法轻松获取recarray 名称列表:

namelist = Myrecarray.dtype.names

但还没有找到对应的属性。recarray dtypes 属性返回名称和格式的元组列表,但无法遍历此列表以检索格式。这似乎是非标准的,因为我能够遍历其他元组列表以获得特定的元组项。例如,以下代码显示了对数组和recarray 的迭代,并尝试对recarray 的dtype 的元组列表进行迭代:

import numpy as np

my_list = [(1, 2), (3, 4), (5, 6)]
print([x[0] for x in my_list])
print('-----------------------')

my_array =  np.array([(1.0, 2, 5), (3.0, 4, 77)], dtype=[('x', float), ('y', int), ('z', float)])
print([x[2] for x in my_array])
print('-----------------------')

img = np.array([[(0,0,0), (1,0,0)], [(0,1,0), (0,0,1)]], {'names': ('r','g','b'), 'formats': ('f4', 'i2', 'f4')})
nta = np.array(img.dtype)
print(img.dtype)
print(img.dtype.names)
print(img.dtype[0])
print(nta)
print([x[0] for x in nta])
print([x[0] for x in img.dtype])

这段代码的打印输出(如下所示)表明我可以:1)遍历一个元组列表;
2) 遍历一个recarray;3) 将记录数组的 dtype 检索为明显的元组列表;
4) 从recarray 中检索名称 5) 检索recarray 的一个字段的格式

但我不能:

6) 遍历 recarray dtype 以检索每个字段的格式 7) 遍历作为数组转换的 recarray dtype 以检索每个字段的格式

输出是:

[1, 3, 5]
-----------------------
[5.0, 77.0]
-----------------------
[('r', '<f4'), ('g', '<i2'), ('b', '<f4')]
('r', 'g', 'b')
float32
[('r', '<f4'), ('g', '<i2'), ('b', '<f4')]
'import sitecustomize' failed; use -v for traceback
Traceback (most recent call last):
  File "....\Python\test0.py", line 23, in <module>
    print([x[0] for x in nta])
TypeError: iteration over a 0-d array

有谁知道如何从记录数组中检索字段格式作为列表?

4

1 回答 1

2

嗯,新手找到了自己问题的答案。我需要“descr”属性把它变成一个可迭代的对象

print([x[1] for x in img.dtype.descr])
于 2012-09-04T11:45:17.717 回答