[英]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 为零时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.