Python:洗牌字符串以获取所有可能的字符串组合

7

我正在寻找一个Python脚本,它可以接收一些字符串,并返回由原始字符串中所有字符的所有可能组合构成的所有可能字符串。

我找到了一些可以随机打乱字符串中字符顺序的脚本,但它们只返回一种随机组合方式,而我需要的是所有可能的组合方式...

例如:

script.py "abc"
abc
acb
bac
bca
cab
cba

谢谢!

2个回答

12

itertools.permutations


该代码片段中的链接指向Python官方文档中的itertools.permutations函数。
>>> import itertools
>>> import pprint
>>> pprint.pprint(list(itertools.permutations("spam")))
[('s', 'p', 'a', 'm'),
 ('s', 'p', 'm', 'a'),
 ('s', 'a', 'p', 'm'),
 ('s', 'a', 'm', 'p'),
 ('s', 'm', 'p', 'a'),
 ('s', 'm', 'a', 'p'),
 ('p', 's', 'a', 'm'),
 ('p', 's', 'm', 'a'),
 ('p', 'a', 's', 'm'),
 ('p', 'a', 'm', 's'),
 ('p', 'm', 's', 'a'),
 ('p', 'm', 'a', 's'),
 ('a', 's', 'p', 'm'),
 ('a', 's', 'm', 'p'),
 ('a', 'p', 's', 'm'),
 ('a', 'p', 'm', 's'),
 ('a', 'm', 's', 'p'),
 ('a', 'm', 'p', 's'),
 ('m', 's', 'p', 'a'),
 ('m', 's', 'a', 'p'),
 ('m', 'p', 's', 'a'),
 ('m', 'p', 'a', 's'),
 ('m', 'a', 's', 'p'),
 ('m', 'a', 'p', 's')]

(pprint 只是为了使输出结果更整洁。) 或者,如果您喜欢,

>>> list(map("".join, itertools.permutations("spam")))
['spam', 'spma', 'sapm', 'samp', 'smpa', 'smap', 'psam', 'psma', 'pasm', 'pams', 'pmsa', 'pmas', 'aspm', 'asmp', 'apsm', 'apms', 'amsp', 'amps', 'mspa', 'msap', 'mpsa', 'mpas', 'masp', 'maps']

5

itertools.permutations 可以实现这个功能。

>>> import itertools
>>> for s in itertools.permutations('banana'):
...     print ''.join(s)
... 
banana
banaan
bannaa
bannaa
# many, many more...

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接