208

.capitalize()は文字列の最初の文字を大文字にしますが、最初の文字が整数の場合はどうなりますか?

これ

1bob
5sandy

これに

1Bob
5Sandy
4

10 に答える 10

282

誰もそれについて言及していないという理由だけで:

>>> 'bob'.title()
'Bob'
>>> 'sandy'.title()
'Sandy'
>>> '1bob'.title()
'1Bob'
>>> '1sandy'.title()
'1Sandy'

しかし、これはまた

>>> '1bob sandy'.title()
'1Bob Sandy'
>>> '1JoeBob'.title()
'1Joebob'

つまり、最初の英字を大文字にするだけではありません。しかし、.capitalize()少なくともその点では同じ問題があり'joe Bob'.capitalize() == 'Joe bob'ます。

于 2012-09-13T16:18:06.857 に答える
254

最初の文字が整数の場合、最初の文字は大文字になりません。

>>> '2s'.capitalize()
'2s'

機能が必要な場合は、数字を取り除き、'2'.isdigit()各文字を確認するために使用できます。

>>> s = '123sa'
>>> for i, c in enumerate(s):
...     if not c.isdigit():
...         break
... 
>>> s[:i] + s[i:].capitalize()
'123Sa'
于 2012-09-13T15:56:40.733 に答える
40

これは、 re モジュールを必要とせずに、文字列の残りの大文字と小文字をそのまま保持するという点で、@Anonの回答に似ています。

def sliceindex(x):
    i = 0
    for c in x:
        if c.isalpha():
            i = i + 1
            return i
        i = i + 1

def upperfirst(x):
    i = sliceindex(x)
    return x[:i].upper() + x[i:]

x = '0thisIsCamelCase'

y = upperfirst(x)

print(y)
# 0ThisIsCamelCase

@Xanが指摘したように、関数はより多くのエラーチェックを使用できます(xがシーケンスであることをチェックするなど-ただし、テクニックを説明するためにエッジケースを省略しています)

@normanius コメントごとに更新 (ありがとう!)

私が質問に答えなかったことを指摘してくれた@GeoStoneMartenに感謝します!-それを修正

于 2015-08-26T17:15:07.950 に答える
17

これは、最初の文字を大文字にし、後続のすべての文字の大文字と小文字を区別するワンライナーです。

import re

key = 'wordsWithOtherUppercaseLetters'
key = re.sub('([a-zA-Z])', lambda x: x.groups()[0].upper(), key, 1)
print key

これにより、WordsWithOtherUppercaseLetters

于 2014-07-22T21:26:39.627 に答える
4

ワンライナー:' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))

于 2018-02-25T10:23:38.640 に答える
1

私はこれを思いついた:

import re

regex = re.compile("[A-Za-z]") # find a alpha
str = "1st str"
s = regex.search(str).group() # find the first alpha
str = str.replace(s, s.upper(), 1) # replace only 1 instance
print str
于 2012-09-13T16:06:03.383 に答える