生成范围内的连续字符串

时间:2014-08-26 13:47:43

标签: python python-2.7

我想生成从"aaa""zzz"的所有字符串。目前,我正在使用3 for循环这样做,有更多的pythonic方式吗?

key_options = []
for n1 in range(ord('a'), ord('z')+1):
    for n2 in range(ord('a'), ord('z')+1):
        for n3 in range(ord('a'), ord('z')+1):
             key_options.append(chr(n1) + chr(n2) + chr(n3))

3 个答案:

答案 0 :(得分:4)

使用itertools.product和列表理解:

>>> from itertools import product
>>> from string import ascii_lowercase
>>> [''.join(p) for p in product(ascii_lowercase, repeat=3)]
['aaa', 'aab', 'aac', 'aad', 'aae', ..., 'zzv', 'zzw', 'zzx', 'zzy', 'zzz']

答案 1 :(得分:2)

itertools模块是进行此类循环的更好方法。您可以使用product函数:

  

<强> itertools.product(*iterables[, repeat])

     

输入迭代的笛卡尔积。

     

等效于生成器表达式中的嵌套for循环。例如,product(A, B)返回与((x,y) for x in A for y in B)相同的内容。

string可以提供ASCII小写字母而不使用range

  

<强> string.ascii_lowercase

     

小写字母'abcdefghijklmnopqrstuvwxyz'。此值不依赖于语言环境,不会更改。

因此,你有

from itertools import product
from string import string

key_options = [''.join(n) for n in product(ascii_lowercase, repeat=3)]

答案 2 :(得分:1)

>>> letters = [chr(i) for i in range(ord('a'), ord('z')+1)]
>>> 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']

import itertools
["".join(i) for i in itertools.product(letters,letters,letters)]

输出

['aaa', 'aab', 'aac', ... 'zzy', 'zzz']