在2级列表中形成所有可能的字符串

时间:2013-02-26 06:45:06

标签: python

我有两个这样的列表:

[['Demonstrative-Pronoun', 'Personal-Pronoun', 'Adjective', 'Noun', 'Noun', 'Indefinite-Pronouns'], ['Verb', 'Adjective', 'Adverb', 'Noun', 'Noun'], ['Verb', 'Verb', 'Verb', 'Verb', 'Adjective', 'Noun', 'Noun', 'Verb'], ['Verb', 'Verb', 'Verb', 'Verb', 'Verb', 'Verb', 'Noun']]

我想从这些列表中形成所有可能的字符串,如:

  1. Demonstrative-Pronoun Verb Verb Verb
  2. 指示代词形容词动词动词 等等。
  3. 有没有更快的方法在python中执行此操作或快速方法?此列表是硬编码的,但实际上可能包含任意数量的元素和子元素

    谢谢!

1 个答案:

答案 0 :(得分:6)

使用itertools.product基本上构成一堆嵌套的for循环:

import itertools

items = [...]

for grouping in itertools.product(*items):
    print ' '.join(grouping)

这将为您提供所有1680种组合。

来自评论:“你可以用地图(集合,项目)替换项目,它将删除重复项。这会使计数减少到120.”