können Sie dstack verwenden:
>>> np.array(zip(a.ravel(),b.ravel()), dtype=('i4,i4')).reshape(a.shape)
array([[(0, 0), (1, 1), (2, 2), (3, 3)],
[(4, 4), (5, 5), (6, 6), (7, 7)]],
dtype=[('f0', '<i4'), ('f1', '<i4')])
Für Python 3+ Sie das zip
Objekt Iterator erweitern müssen:
>>> np.dstack((a,b))
array([[[0, 0],
[1, 1],
[2, 2],
[3, 3]],
[[4, 4],
[5, 5],
[6, 6],
[7, 7]]])
Wenn Sie Tupel haben müssen. Bitte beachten Sie, dass dies schrecklich ineffizient:
>>> np.array(list(zip(a.ravel(),b.ravel())), dtype=('i4,i4')).reshape(a.shape)
array([[(0, 0), (1, 1), (2, 2), (3, 3)],
[(4, 4), (5, 5), (6, 6), (7, 7)]],
dtype=[('f0', '<i4'), ('f1', '<i4')])
Dank! 'dstack' funktioniert super für mich! – LWZ
Für den zweiten Befehl bekomme ich 'TypeError: ein Byte-ähnliches Objekt ist erforderlich, nicht 'zip' - warum ist das? – Make42
@ Make42 In Python 3 gibt 'zip' einen Iterator zurück. Siehe bearbeitete Antwort. – Daniel