繁体   English   中英

Python 组合生成器 - 存储到 .txt 文件

[英]Python Combination Generator - Store to .txt file

所以基本上,我有一个组合生成器脚本......它可以工作......它的工作方式是它生成组合,然后我将它们复制/粘贴到一个文本文件中,这很难考虑到 6 位数字有 14 亿个排列..而且在大约 130 万之后它崩溃了? 那么我如何做到这一点,当它进行组合时,它将它存储到 .txt 文件中,如果它崩溃了......它可以从 .txt 文件脚本中的最后一行重新启动:

import itertools
from itertools import *

lower_a = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',  'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
num = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']

all = []
all = lower_a + num

def com():
    for x in range(2):
        for s in itertools.product(all, repeat=x):
            print(''.join(s))

print(com())

您显示的代码不是您正在运行的代码。 例如,此段不能像您描述的那样运行:

for x in range(2):
    for s in itertools.product(all, repeat=x):
        print(''.join(s))

这应该在两种情况下为所有成员显示笛卡尔积:

  • 当 x 为 0
  • 当 x 为 1

当 x 为零时itertools.product(any_list_at_all, repeat=0)只有一个零元素的组合,即空集。 当 z 为 1 时,组合数等于输入列表的长度。 在您的情况下,这使 36 个字符的总共len(all)组合一次取 1 个,即 36 组。

由于在笛卡尔积中,输出集的基数是输入集基数的乘积(对于有限集),这意味着product(all, range=6)返回了大约 22 亿个集,那么 1.4 在哪里亿从哪里来?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM