[英]Python: all possible combinations of “dynamic” list
我真的找不到这个。 我尝试使用itertools,尝试了所有类型的循环,但仍然无法实现我想要的。 这就是我需要的:
我有这样的清单:
list = [("car", 2), ("plane", 3), ("bike", 1)]
这个列表每次都不同,每次可以有5个不同的项目,我需要的是得到这样的东西:
car1, plane1, bike1
car1, plane2, bike1
car1, plane3, bike1
car2, plane1, bike1
car2, plane2, bike1
car2, plane3, bike1
我真的迷路了。 很明显它可能很简单,但我无法解决它。
你可以使用itertools.product()
:
my_list = [("car", 2), ("plane", 3), ("bike", 1)]
a = itertools.product(*([name + str(i + 1) for i in range(length)]
for name, length in my_list))
for x in a:
print x
版画
('car1', 'plane1', 'bike1')
('car1', 'plane2', 'bike1')
('car1', 'plane3', 'bike1')
('car2', 'plane1', 'bike1')
('car2', 'plane2', 'bike1')
('car2', 'plane3', 'bike1')
试试这个:
L = [("car", 2), ("plane", 3), ("bike", 1)]
O = []
N = []
for each in L:
O.append(each[0])
N.append(each[1])
for each in O:
strin = ""
for item in N:
strin = strin + item + each + ","
print strin[:-1]
由于您的列表最多只包含五个项目,因此这是一个合理的解决方案。
您可以使用递归函数实现它:
def combis(ls):
if not ls:
yield []
return
(name, limit) = ls[-1]
for start in combis(ls[:-1]):
for c in range(1, limit+1):
yield start + [(name, c)]
为了实现这样的事情,程序的复杂性将非常高。 尝试重新设计逻辑,以便减少复杂性..
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.