2

私は次のPythonコードを持っています。これは文字列を循環し、各文字を大文字にします。

str = 'abcd'
l  = list(str)
for i in range(len(l)):
    rl = list(str)
    cap_char = l[i].capitalize()
    rl[i] = cap_char
    str1 = ''.join(rl)
    print str1

生成するもの:

Abcd aBcd abCd abcD

このコードを拡張して、大文字と小文字を区別する連続する文字の数をlen(l)-1に達するまでインクリメントして、次のようにします。

Abcd aBcd abCd abcD    >> - 1 char capitalized
ABcd aBCd abCD AbcD    >> - 2 chars capitalized
ABCd aBCD AbCD ABcD    >> - 3 chars capitalized

インデックス演算を実行すると、「インデックスが範囲外」エラーが発生します。idicesはラップする必要があることを理解していますが、エレガントなコードを生成できないようです;(

4

3 に答える 3

3
import itertools
x = 'abcd'
n = len(x)
for i in xrange(1,n):
  combinations = itertools.combinations(range(n), i)
  for c in combinations:
    print ''.join([k if m not in c else k.upper() for m,k in enumerate(x)]),
  print '    >> - {0} char(s) capitalized'.format(i)

出力:

Abcd aBcd abCd abcD     >> - 1 char(s) capitalized
ABcd AbCd AbcD aBCd aBcD abCD     >> - 2 char(s) capitalized
ABCd ABcD AbCD aBCD     >> - 3 char(s) capitalized
于 2011-09-02T00:39:06.770 に答える
2

インデックス番号の計算中にモジュロ演算子を使用します。

idx = idx % len(str)

strところで、 Python で変数名として使用しないでください。理由を理解するには、これを試してください:

print str(4)
str = 'foo'
print str(4)
于 2011-09-02T00:33:18.420 に答える
2

wim の質問に対する回答に応じて、 wim の回答または次のいずれかが必要です。

>>> def upper_case(str_, start, end):
...  substr = str_[start:end].upper()
...  return str_[:start] + substr + str_[end:]
... 
>>> def raise_combinations(str_, length):
...  for x in xrange(len(str_) - length + 1):
...   print(upper_case(str_, x, x + length))
... 
>>> raise_combinations('abcdefghi', 1)
Abcdefghi
aBcdefghi
abCdefghi
abcDefghi
abcdEfghi
abcdeFghi
abcdefGhi
abcdefgHi
abcdefghI
>>> raise_combinations('abcdefghi', 4)
ABCDefghi
aBCDEfghi
abCDEFghi
abcDEFGhi
abcdEFGHi
abcdeFGHI

編集:そしてもちろん、これをループしたい場合:

>>> str_ = "abcd"
>>> for x in xrange(1, len(str_) + 1):
...  raise_combinations(str_, x)
... 
Abcd
aBcd
abCd
abcD
ABcd
aBCd
abCD
ABCd
aBCD
ABCD
>>> 
于 2011-09-02T00:51:08.980 に答える