我有一个看起来像这样的列表:获取从n个非零长度的所有可能组合列出
[["0"], ["1", "2"], ["4"]]
,我希望得到所有可能的排列具有非零长度以不超过该列表中的每个列表中的一个元素或者甚至仅仅是排列的数量。所以上面列表的结果是:
[["0"], ["1"], ["2"], ["4"], ["0", "1"], ["0", "2"], ["1", "4"], ["2", "4"], ["0", "4"], ["0", "1", "4"], ["0", "2", "4"]]
子列表中的元素都是字符串。
我试过使用itertools.products,但它只返回使用所有子列表的结果。
>>> import itertools
>>> l = [["0"], ["1", "2"], ["4"]]
>>> list(itertools.product(*l))
[('0', '1', '4'), ('0', '2', '4')]