0

我有一个字母列表:

>>> alphabet = "A B C D E F G H I J K L M N O P Q R S T U V W X Y Z"
>>> letters = alphabet.lower().split()    
>>> letters
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

我想生成一个字符串列表,如下所示:

a b c d ... z aa ab ac ... az ba bb bc bd ... zx zy zz ... aaa aab ... zzzzz

换句话说,我想列出每个长度小于或等于该 alhabet 的五个字符的组合的单词。

我必须编写 5 个循环还是使用递归?实现它的最pythonic方式是什么?你有什么建议?

4

1 回答 1

4

使用itertools.product

>>> from string import ascii_lowercase as al
>>> from itertools import product
>>> lis = ["".join(p) for i in xrange(1,6) for p in product(al, repeat = i)]
于 2013-08-04T09:30:01.043 回答