为了账号安全,请及时绑定邮箱和手机立即绑定

如何将输出导出到 csv?

如何将输出导出到 csv?

阿晨1998 2021-12-29 10:58:02
我正在尝试导出组合列表的输出,但我似乎无法正确执行?有人可以帮忙吗?我尝试了那个和 numpy 以及我能找到的任何解决方案import csvfrom itertools import combinationscomb = 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 回答

?
临摹微笑

TA贡献1982条经验 获得超2个赞

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


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() 调用会做的),而是让组合 () 方法在我们循环时生成我们的数据。


查看完整回答
反对 回复 2021-12-29
  • 1 回答
  • 0 关注
  • 217 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信