当我使用np.savetxt('file.txt', (arr1, arr2, arr3))时,如何将多个numpy数组保存到文件中的最佳方式?这些数组是按列而不是按行保存的,这使得将其导入Excel变得困难。如何以更标准的方式保存数组?
谢谢。
x = np.random.random_integers(0, 10, size=10)
np.savetxt('test.txt', x)
它会生成以下内容的文件
0.0e+00 8.0e+00 7.0e+00 6.0e+00 1.0e+01 7.0e+00 9.0e+00 9.0e+00 0.0e+00 3.0e+00
这很好,基于列的表示意味着很容易导入到CSV兼容的程序中,如Excel、LabView、Matlab和Origin。
但是当我们想要保存两个或更多数组并确保文件仍然可以轻松地导入到不同的程序中时,会发生什么。
如果我们只是使用
x = np.random.random_integers(0, 10, size=10)
y = np.random.random_integers(0, 10, size=10)
z = np.random.random_integers(0, 10, size=10)
np.savetxt('test.txt', (x, y, z))
9.0e+00 9.0e+00 4.0e+00 2.0e+00 0.0e+00 8.0e+00 1.0e+01 2.0e+00 1.0e+00 9.0e+00 2.0e+00 3.0e+00 1.0e+00 9.0e+00 2.0e+00 5.0e+00 1.0e+01 2.0e+00 8.0e+00 3.0e+00 9.0e+00 8.0e+00 2.0e+00 7.0e+00 9.0e+00 0.0e+00 6.0e+00 0.0e+00 2.0e+00 3.0e+00所以,我们可以使用numpy vstack。
x = np.random.random_integers(0, 10, size=10)
y = np.random.random_integers(0, 10, size=10)
z = np.random.random_integers(0, 10, size=10)
np.savetxt('test.txt', np.vstack((x, y, z)).T)
test.txt
的文件,其中包含以下内容:
9.0e+00 2.0e+00 9.0e+00 9.0e+00 3.0e+00 8.0e+00 4.0e+00 1.0e+00 2.0e+00 2.0e+00 9.0e+00 7.0e+00 0.0e+00 2.0e+00 9.0e+00 8.0e+00 5.0e+00 0.0e+00 1.0e+01 1.0e+01 6.0e+00 2.0e+00 2.0e+00 0.0e+00 1.0e+00 8.0e+00 2.0e+00 9.0e+00 3.0e+00 3.0e+00这样更加便携,并且可以轻松地导入到诸如Excel之类的程序中。
x, y, z = np.loadtxt('test.txt').T