python - 如何将输出导出到 csv?

标签 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 从未创建,它仅向我显示终端中的输出。

最佳答案

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

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 的 undefined object 的属性 csv。不管怎样,你必须首先打开一个文件,这样你就有一个类似文件的对象,然后将其传递给 csv.writer();为了提高效率,没有理由将整个组合列表展开到内存中(这就是 list() 调用所做的),而是让 Combinations() 方法在循环时逐段生成数据。

关于python - 如何将输出导出到 csv?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55520478/

相关文章:

Python email quoted-printable编码问题

python - Odoo - 获取记录并将其转换为 python 对象

python - 如何在有条件的情况下在 ndarray 上使用 numpy.mean() ?

python - 改进一个简单的 spring 网络的 numpy 实现

java - java excel 提取器的问题

mysql - 导出数据转义换行不起作用

javascript - 如何创建可以将 html 导出到 CSV 文件的功能?

javascript - 使用 d3.legend 进行强制布局上的交互式图例

django - 在 Django View 响应中下载文件后返回消息

mysql - magento 订单导出时出现相同 ID 错误