字符串的所有可能组合

6 投票
3 回答
3389 浏览
提问于 2025-04-16 21:50

我想写一个程序,用Python来生成一个字符串的所有可能的大写小写组合。比如,给定字符串'abcedfghij',我希望程序能生成这样的结果:

Abcdefghij
ABcdef..
.
.
aBcdef..
.
ABCDEFGHIJ

还有很多其他组合。现在我在寻找一个快速的方法来实现这个功能,但我不知道该从哪里开始。

3 个回答

0
import itertools

def comb_gen(iterable):
    #Generate all combinations of items in iterable
    for r in range(len(iterable)+1):
        for i in itertools.combinations(iterable, r):
            yield i 


def upper_by_index(s, indexes):
     #return a string which characters specified in indexes is uppered
     return "".join(
                i.upper() if index in indexes else i 
                for index, i in enumerate(s)
                )

my_string = "abcd"

for i in comb_gen(range(len(my_string))):
    print(upper_by_index(my_string, i))

输出:

abcd Abcd aBcd abCd abcD ABcd AbCd AbcD aBCd aBcD abCD ABCd ABcD AbCD aBCD ABCD
10

这个方法和Dan的解决方案类似,但要简单很多:

>>> import itertools
>>> def cc(s):
...     return (''.join(t) for t in itertools.product(*zip(s.lower(), s.upper())))
...
>>> print list(cc('dan'))
['dan', 'daN', 'dAn', 'dAN', 'Dan', 'DaN', 'DAn', 'DAN']
7
from itertools import product, izip
def Cc(s):
    s = s.lower()
    for p in product(*[(0,1)]*len(s)):
      yield ''.join( c.upper() if t else c for t,c in izip(p,s))

print list(Cc("Dan"))

输出:

['dan', 'daN', 'dAn', 'dAN', 'Dan', 'DaN', 'DAn', 'DAN']

撰写回答