Сочетание всех возможных случаев строки

Я пытаюсь создать программу для генерации всех возможных случаев капитализации строки в python. Например, учитывая «abcedfghij», мне нужна программа для генерации: Abcdefghij ABcdef … , aBcdef … ABCDEFGHIJ

И так далее. Я пытаюсь найти быстрый способ сделать это, но я не знаю, с чего начать.

3 Solutions collect form web for “Сочетание всех возможных случаев строки”

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'] 

Подобно решению Дэна, но гораздо проще:

 >>> 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'] ' 
 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 
  • f.read, приходящий пустой
  • У Tesseract есть проблемы с чтением этой чрезвычайно простой строки чисел
  • нетехнические преимущества наличия неизменяемого типа строки
  • Строка заменить на обратную косую черту в Python
  • Передача нескольких аргументов из bash в python
  • Обратить строку без использования reverse () или ?
  • Проверка начала строки с XXXX
  • Разделение букв из чисел внутри строки
  •  
    Interesting Posts for Van-Lav
    Python - лучший язык программирования в мире.