3

我在表格的文件 data.dat 中有数据:

column_1    col col col col col
1   2   3   1   2   3
4   3   2   3   2   4
1   4   3   1   4   3
5   6   4   5   6   4

我正在尝试使用 np.genfromtxt 导入,以便所有列名为 col 的数据都存储在变量 y 中。我使用以下代码进行了尝试:

import numpy as np
data = np.genfromtxt('data.dat', comments='#', delimiter='\t', dtype=None, names=True).transpose()
y = data['col']

但它给了我以下错误:

ValueError: two fields with the same name

如何在 Python 中解决这个问题?

4

1 回答 1

1

使用时name=Truenp.genfromtxt返回一个结构化数组。请注意,标记为coldata.dat列与以下形式的列名消除歧义col_n

In [114]: arr = np.genfromtxt('data', comments='#', delimiter='\t', dtype=None, names=True)

In [115]: arr
Out[115]: 
array([(1, 2, 3, 1, 2, 3), (4, 3, 2, 3, 2, 4), (1, 4, 3, 1, 4, 3),
       (5, 6, 4, 5, 6, 4)], 
      dtype=[('column_1', '<i8'), ('col', '<i8'), ('col_1', '<i8'), ('col_2', '<i8'), ('col_3', '<i8'), ('col_4', '<i8')])

因此,一旦使用names=True,选择与列 name 关联的所有数据变得更加困难col。此外,结构化数组不允许您一次切片多个列。因此,将数据加载到同质 dtype 数组中会更方便(如果没有 dtype,您将得到names=True):

with open('data.dat', 'rb') as f:
    header = f.readline().strip().split('\t')
    arr = np.genfromtxt(f, comments='#', delimiter='\t', dtype=None)

然后您可以找到名称为的那些列的数字索引col

idx = [i for i, col in enumerate(header) if col=='col']

并选择所有数据

y = arr[:, idx]

例如,

import numpy as np

with open('data.dat', 'rb') as f:
    header = f.readline().strip().split('\t')
    arr = np.genfromtxt(f, comments='#', delimiter='\t', dtype=None)
    idx = [i for i, col in enumerate(header) if col=='col']
    y = arr[:, idx]
    print(y)

产量

[[2 3 1 2 3]
 [3 2 3 2 4]
 [4 3 1 4 3]
 [6 4 5 6 4]]

如果你想y成为一维,你可以使用ravel()

print(y.ravel())

产量

[2 3 1 2 3 3 2 3 2 4 4 3 1 4 3 6 4 5 6 4]
于 2015-06-07T18:29:08.887 回答