在Python中嵌套到动态深度

Jas*_*hua 3 python recursion for-loop nested

我有一个问题,我正在尝试解决这个问题,需要嵌套与列表中的项目一样多的深度.或者确切地说,在列表中迭代.

def example(arg_list):
for i in arg_list[0]:
    for j in arg_list[1]:
        for k in arg_list[2]:
            print "{} {} {}".format(i,j,k)
Run Code Online (Sandbox Code Playgroud)

只要"arg_list"是包含3个迭代的列表,例如[[1,3,4],[4,5,6],[9,3,2,1,0],上述函数就可以正常运行].如果列表中总有四个迭代,那么这也很容易.我需要弄清楚如何创建一个函数,为添加到"arg_list"参数的每个iterable添加另一个嵌套级别.似乎递归可能是要走的路,但却无法解决这个问题.

kin*_*all 6

您正在寻找的是笛卡尔积.Python的itertools模块有一个功能,可以为您完成.

from itertools import product

def example(arg_list):
    for items in product(*arg_list):
        print " ".join(str(item) for item in items)
Run Code Online (Sandbox Code Playgroud)