如何将输出导出到csv?

时间:2019-04-04 16:03:24

标签: python csv export-to-csv

我正在尝试导出组合列表的输出,但似乎无法正确显示?有人可以帮忙吗?

我尝试过使用numpy以及我能找到的任何解决方案

import csv
from itertools import combinations

comb = combinations([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59], 6) 

for i in list(comb): 
    print(i)

writer = csv.writer(data.csv)
writer.writerow([i])

预期结果将在csv中输出,但是csv不会被创建,它只会向我显示终端中的输出。

1 个答案:

答案 0 :(得分:0)

我希望您想要这样的东西:

import csv
from itertools import combinations

comb = combinations([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59], 6) 

with open("/tmp/data.csv", "w") as f:
    writer = csv.writer(f)
    for i in comb:
        writer.writerow(i)

请注意,这将写入800MB的文件。

为提高代码的可读性,您可以做的一件好事是使用 range()定义数据。这样可以轻松处理数据集的大小。像这样:

comb = combinations(range(1,60), 6)

@triplee在他的回答中添加了一些很好的注释,这些注释同样适用于此处,因为它们与您的原始代码对话。我们猜测您希望 data.csv 是文本文件名,而不是未定义对象 data 的属性 csv 。无论哪种方式,您都必须首先打开一个文件,以便拥有一个类似文件的对象,然后将其传递给 csv.writer() ;;为了提高效率,没有理由将整个组合列表扩展到内存中(这就是list()调用将执行的操作),而是让Combines()方法在循环时生成我们的数据片段。