【问题标题】:How do I export output to csv?如何将输出导出到 csv?
【发布时间】:2019-04-04 16:03:23
【问题描述】:

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

我尝试了那个和 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 从未创建,它只显示终端中的输出。

【问题讨论】:

  • 你关闭了作者吗?
  • 是否有理由不写出与打印相同的输出?在循环之前打开编写器;打印并写入i 到您的输出目的地。
  • 我看到此代码存在多个问题。这段代码根本不起作用,甚至不应该运行,因为它至少有一个我可以看到的语法错误。 1) 什么是 data.csv?那是您要输出到的文件名吗?如果是这样,它需要在引号中。 2) 您使用“i”迭代 comb,但随后您也在该循环之外使用“i”。那看起来不对。 3) 对于 writer.writerow([i]) 行,你的意思是要创建一个新列表吗?
  • 是的@tripleee,我意识到在我点击 并修复它之后。感谢您的评论。

标签: python csv export-to-csv


【解决方案1】:

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

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 在他的答案中添加了一些很好的 cmets,它们在这里同样适用,因为它们与您的原始代码对话。我们猜测您希望 data.csv 成为文字文件名,而不是名为 data 的未定义对象的属性 csv。不管怎样,你必须先打开一个文件,这样你就有一个类似文件的对象,然后将它传递给 csv.writer();为了提高效率,没有理由将整个组合列表扩展到内存中(这是 list() 调用会做的事情),而是让 combine() 方法在我们循环时生成我们的数据。

【讨论】:

  • ...你打败了我,也许你想在我删除之前从我的答案中复制一些评论?
  • 是的,你的 cmets 很棒。我开始提供类似的 cmets,但是代码有很多问题,我放弃了,并决定新代码可以自己说话。例如,即使他在 "data.csv" 周围加上引号,csv.writer 也会使用文件句柄,而不是文件名。你可以做任何你认为最好的事情。对于 OP 来说,解释 list() 的事情似乎太多了。如果您愿意,可以编辑我的答案。
  • 我会将您的 cmets 添加到我的答案中。
  • 哇,谢谢你们的帮助和建议!您对可读性和我仍在学习的 data.csv 完全正确,所以这两个 cmets 对我的理解都非常有帮助!
猜你喜欢
  • 2015-01-17
  • 2022-01-21
  • 2021-10-24
  • 1970-01-01
  • 2015-05-25
  • 1970-01-01
  • 1970-01-01
  • 2015-02-01
  • 2017-01-02
相关资源
最近更新 更多