Python 3.x,如何读取文件内容(进入一维列表)

问题描述 投票:-1回答:2

我是python和自学的新手。我正在尝试从包含整数的.csv文件中读取数据到一维数组(python列表)。

.csv文件如下所示:

"1","2","3","4","5","6","7","8"
"9","10","11","12","13","14","15","16"
.
.
.

我试过这样的:

l = []
f = open('file.csv', 'r')
for line in f:
      l.append(line)
f.close()

我得到一个'列表列表'(2D数组)而不是我想要的线性列表。另外,我希望列表包含整数而不是字符串。

python arrays csv
2个回答
0
投票

实际上,您没有获得列表列表,而是获取字符串列表(文件中的行),每个字符串看起来像一个列表。首先,你需要拆分线。您可以使用line.split(",")执行此操作,但由于您有CSV文件,因此您应该只使用csv模块。这也将照顾你删除"..."

import csv
with open('test.csv') as f:
    r = csv.reader(f)
    lst = []
    for line in r:
          lst.append(line)

现在,我们有一个实际的列表列表:[['1', '2', '3', '4', '5', '6', '7', '8'], ['9', '10', '11', '12', '13', '14', '15', '16']]

接下来,如果你想要一个包含所有行中所有数字的平面列表,你应该使用extend而不是append,你也可以将这些str转换为int

    for line in r:
        lst.extend(map(int, line))

这给你[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16]。您还可以使用列表推导在一行中完成所有这些操作:

    lst = [int(s) for line in r for s in line]

-1
投票

试试这个

with open("main.csv") as csvfile:
    tlines = [line.split(",", 2) for line in csvfile.readlines()]
    text = [" ".join(line) for line in tlines]
print text

它可能对你有帮助。

© www.soinside.com 2019 - 2024. All rights reserved.