由于您没有展示您自己的代码,我只是给您一些想法。如果您需要更多详细信息,请编辑您的问题以添加更多您自己的工作,然后询问详细信息。
当我查看您想要的列表时,您似乎想要列表 a 中的 3 个项目,不重复,以及列表 b 中的两个项目,可能重复,并将两个列表中的项目交错。我还将假设列表b 中的项目数比给定列表a 的长度少一。 (如果这些假设不是您想要的,请在您的问题中明确说明。)
具有不同顺序且不重复的“组合”称为排列。您可以使用表达式获取列表a 的所有排列
itertools.permutations(a)
因此列表b中所有可能的项目集合与重复
itertools.product(b, repeat=len(a)-1)
对于每个集合中的每对项目,您可以通过对两个集合使用zip() 操作来交错这些项目。由于第一个集合比第二个集合长 1,因此最后一项将被忽略,但您可以将其添加到结果中。
我可以向您展示一个可以实现这种交错的单线,但我应该留下一些事情让您去做。使用这些想法来尝试您自己的代码。如果您没有完全成功,请向我们展示一下尝试,我很乐意向您展示一些最终代码。
请注意,遵循我的想法会导致列表的顺序与您显示的不同。我会得到的列表将从
开始
test1_test2_test3
test1_test3_test2
test2_test1_test3
test2_test3_test1
test3_test1_test2
test3_test2_test1
test1_test2-test3
test1_test3-test2
test2_test1-test3
test2_test3-test1
test3_test1-test2
test3_test2-test1
test1_test2.test3
等等。此顺序修复分隔符,然后排列列表 a 中的项目。当然,你也可以反过来做,得到不同的顺序。
现在您已经展示了自己的一些工作,这是我的代码。这假定列表 a 和 b 没有重复。这也有助于简化对比分隔符多一个项目的问题的处理——我只是将空分隔符 "" 添加到分隔符元组的末尾。然后两个长度(项目和分隔符)相等,每个字符串末尾的空分隔符什么都不做。
import itertools
a = ["test1", "test2", "test3"]
b = ["_", "-", ".", ""]
for separators in itertools.product(b, repeat=len(a) - 1):
for items in itertools.permutations(a):
print("".join(v for pair in zip(items, separators + ("",)) for v in pair))
这段代码给出了打印输出
test1_test2_test3
test1_test3_test2
test2_test1_test3
test2_test3_test1
test3_test1_test2
test3_test2_test1
test1_test2-test3
test1_test3-test2
test2_test1-test3
test2_test3-test1
test3_test1-test2
test3_test2-test1
test1_test2.test3
test1_test3.test2
test2_test1.test3
test2_test3.test1
test3_test1.test2
test3_test2.test1
test1_test2test3
test1_test3test2
test2_test1test3
test2_test3test1
test3_test1test2
test3_test2test1
test1-test2_test3
test1-test3_test2
test2-test1_test3
test2-test3_test1
test3-test1_test2
test3-test2_test1
test1-test2-test3
test1-test3-test2
test2-test1-test3
test2-test3-test1
test3-test1-test2
test3-test2-test1
test1-test2.test3
test1-test3.test2
test2-test1.test3
test2-test3.test1
test3-test1.test2
test3-test2.test1
test1-test2test3
test1-test3test2
test2-test1test3
test2-test3test1
test3-test1test2
test3-test2test1
test1.test2_test3
test1.test3_test2
test2.test1_test3
test2.test3_test1
test3.test1_test2
test3.test2_test1
test1.test2-test3
test1.test3-test2
test2.test1-test3
test2.test3-test1
test3.test1-test2
test3.test2-test1
test1.test2.test3
test1.test3.test2
test2.test1.test3
test2.test3.test1
test3.test1.test2
test3.test2.test1
test1.test2test3
test1.test3test2
test2.test1test3
test2.test3test1
test3.test1test2
test3.test2test1
test1test2_test3
test1test3_test2
test2test1_test3
test2test3_test1
test3test1_test2
test3test2_test1
test1test2-test3
test1test3-test2
test2test1-test3
test2test3-test1
test3test1-test2
test3test2-test1
test1test2.test3
test1test3.test2
test2test1.test3
test2test3.test1
test3test1.test2
test3test2.test1
test1test2test3
test1test3test2
test2test1test3
test2test3test1
test3test1test2
test3test2test1