使用 python 向排列添加规则?
Add rules to permutations using python?
因为有些日子我需要创建一长串长度为 14 的随机字符串,其中仅包含大写和小写字母,不重复,到目前为止一切顺利,我只是使用 itertools 排列并打印到文件
import itertools
for coma in itertools.permutations(Alphabet, 14):
s="".join(coma)
#write to file code
抛开技术限制(我知道这是大量的组合,space 记录它们,花费时间等,我知道,无需指出。)
现在我必须添加另一个有助于减少组合数量的规则,所有字符串必须至少有 6 个大写字母,最多 8 个,我一直在思考如何添加这个规则,因为我所有的想法要求程序生成字符串,检查是否符合条件,如果不符合则丢弃,但重点是避免做出根本不符合条件的组合。
您可以生成小写字符串,然后使用 random
模块选择要设置为大写的字母的数量和索引:
import random, string
for i in range(500):
number_uppercase = random.randint(6,8)
idx_uppercase = random.sample(range(14), number_uppercase)
letter_list = random.sample(string.ascii_lowercase, 14)
for i in idx_uppercase:
letter_list[i] = letter_list[i].upper()
s="".join(letter_list)
如果您希望所有可能的排列都没有重复,那么您可以尝试下面的代码(内联记录)
alphabet = "abcdefghijklmnopqrstuvwxyz"
# All possible number of uppers
for i in range(6, 9):
# All possible permutations of 'n' uppers
for upper_str in permutations(alphabet, i):
# All possible permutations of 14-n lowers
for lower_str in permutations(alphabet, 14-i):
# format the string
upper_lower_str = "".join(upper_str).upper()+"".join(lower_str)
# All possible permutations of the formatted string
for s in permutations(upper_lower_str, 14):
print ("".join(s))
因为有些日子我需要创建一长串长度为 14 的随机字符串,其中仅包含大写和小写字母,不重复,到目前为止一切顺利,我只是使用 itertools 排列并打印到文件
import itertools
for coma in itertools.permutations(Alphabet, 14):
s="".join(coma)
#write to file code
抛开技术限制(我知道这是大量的组合,space 记录它们,花费时间等,我知道,无需指出。)
现在我必须添加另一个有助于减少组合数量的规则,所有字符串必须至少有 6 个大写字母,最多 8 个,我一直在思考如何添加这个规则,因为我所有的想法要求程序生成字符串,检查是否符合条件,如果不符合则丢弃,但重点是避免做出根本不符合条件的组合。
您可以生成小写字符串,然后使用 random
模块选择要设置为大写的字母的数量和索引:
import random, string
for i in range(500):
number_uppercase = random.randint(6,8)
idx_uppercase = random.sample(range(14), number_uppercase)
letter_list = random.sample(string.ascii_lowercase, 14)
for i in idx_uppercase:
letter_list[i] = letter_list[i].upper()
s="".join(letter_list)
如果您希望所有可能的排列都没有重复,那么您可以尝试下面的代码(内联记录)
alphabet = "abcdefghijklmnopqrstuvwxyz"
# All possible number of uppers
for i in range(6, 9):
# All possible permutations of 'n' uppers
for upper_str in permutations(alphabet, i):
# All possible permutations of 14-n lowers
for lower_str in permutations(alphabet, 14-i):
# format the string
upper_lower_str = "".join(upper_str).upper()+"".join(lower_str)
# All possible permutations of the formatted string
for s in permutations(upper_lower_str, 14):
print ("".join(s))