我有一个给定的数组:
array = [(u'Andrew', -3, 3, 100.032) (u'Bob', -4, 4, 103.323) (u'Joe', -5, 5, 154.324)]
是从另一个进程(我无法控制)生成的CSV表,它输出这个numpy数组。我现在需要分配列的dtypes来进行进一步的分析。
我该怎么做?
谢谢
答案 0 :(得分:5)
这是你需要的吗?
new_array = np.array(array, dtype = [("name", object),
("N1", int),
("N2", int),
("N3", float)])
其中name和N1-3是我给的列名。
它给出了:
array([(u'Andrew', -3, 3, 100.032), (u'Bob', -4, 4, 103.323),
(u'Joe', -5, 5, 154.324)],
dtype=[('name', 'O'), ('N1', '<i8'), ('N2', '<i8'), ('N3', '<f8')])
您可以按&#34; N1&#34;例如:
new_array.sort(order="N1")
new_array
array([(u'Joe', -5, 5, 154.324), (u'Bob', -4, 4, 103.323),
(u'Andrew', -3, 3, 100.032)],
dtype=[('name', 'O'), ('N1', '<i8'), ('N2', '<i8'), ('N3', '<f8')])
希望这有帮助。
答案 1 :(得分:3)
recarr = np.rec.fromrecords(array)
可选择设置字段名称:
recarr = np.rec.fromrecords(array, names="name, idata, idata2, fdata")