Как я могу преобразовать ndarray в матрицу в scipy? - PullRequest
1 голос
/ 28 апреля 2011

Как я могу преобразовать 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 ]

5 голосов
/ 28 апреля 2011

Если конечной целью является создание матрицы, нет необходимости создавать повторный массив с именованными столбцами.Вы можете использовать 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.

0 голосов
/ 28 апреля 2011

Вы можете просто прочитать все ваши значения в вектор, а затем изменить его.

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.

...