如何在scipy中将ndarray转换为矩阵?

1 投票
2 回答
4661 浏览
提问于 2025-04-16 16:36

我该如何把一个ndarray转换成numpy中的矩阵呢?我想从一个csv文件导入数据,然后把它变成一个矩阵。

from numpy import array, matrix, recfromcsv
my_vars = ['docid','coderid','answer1','answer2']
toy_data = matrix( array( recfromcsv('toy_data.csv', names=True)[my_vars] ) )
print toy_data
print toy_data.shape

但是我得到了这个:

[[(1, 1, 3, 3) (1, 2, 4, 1) (1, 3, 7, 2) (2, 1, 3, 3) (2, 2, 4, 4)
  (2, 4, 3, 1) (3, 1, 3, 3) (3, 2, 4, 3) (3, 3, 3, 4) (4, 4, 5, 1)
  (4, 5, 6, 2) (4, 2, 4, 3) (5, 2, 5, 4) (5, 3, 3, 1) (5, 4, 7, 2)
  (6, 1, 3, 3) (6, 5, 4, 1) (6, 2, 5, 2)]]
(1, 18)

我该怎么做才能从这段代码中得到一个4行18列的矩阵呢?这个问题应该有简单的解决办法,但我就是找不到。

2 个回答

0

你可以把所有的数值读入一个向量,然后再调整它的形状。

fo = open("toy_data.csv")

def _ReadCSV(fileobj):
  for line in fileobj:
    for el in line.split(","):
      yield float(el)


header = map(str.strip, fo.readline().split(","))
a = numpy.fromiter(_ReadCSV(fo), numpy.float64)
a.shape = (-1, len(header))

不过,使用更新版的numpy,可能还有更简单的方法。

5

如果最终目的是要制作一个矩阵,那么其实没必要创建一个带有命名列的记录数组。你可以使用 np.loadtxt 来把csv文件加载到一个ndarray(多维数组)中,然后再用 np.asmatrix 将它转换成矩阵:

import numpy as np
toy_data = np.asmatrix(np.loadtxt('toy_data.csv',delimiter=','skiprows=1))
print toy_data
print toy_data.shape

这样就能得到

[[ 1.  1.  3.  3.]
 [ 1.  2.  4.  1.]
 [ 1.  3.  7.  2.]
 [ 2.  1.  3.  3.]
 [ 2.  2.  4.  4.]
 [ 2.  4.  3.  1.]
 [ 3.  1.  3.  3.]
 [ 3.  2.  4.  3.]
 [ 3.  3.  3.  4.]
 [ 4.  4.  5.  1.]
 [ 4.  5.  6.  2.]
 [ 4.  2.  4.  3.]
 [ 5.  2.  5.  4.]
 [ 5.  3.  3.  1.]
 [ 5.  4.  7.  2.]
 [ 6.  1.  3.  3.]
 [ 6.  5.  4.  1.]
 [ 6.  2.  5.  2.]]
(18, 4)

注意:skiprows这个参数是用来跳过csv文件中的表头的。

撰写回答