web-dev-qa-db-ja.com

Pythonは最初の文字だけを大文字にする

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

この

1bob
5sandy

これに

1Bob
5Sandy
156
user1442957

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

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

機能が欲しいなら、数字を取り除いて、'2'.isdigit()を使って各文字をチェックすることができます。

>>> s = '123sa'
>>> for i, c in enumerate(s):
...     if not c.isdigit():
...         break
... 
>>> s[:i] + s[i:].capitalize()
'123Sa'
207
Ali Afshar

他の誰もそれを言及していないという理由だけで:

>>> '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'ではそうです。

217
DSM

これは@ Anonの答えに似ていますが、reモジュールを必要とせずに、文字列の大文字と小文字の区別をそのままにします。

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のおかげで、私は質問に答えませんでした!それを修正

35
pinkwerks

これは最初の文字を大文字にし、それ以降の文字はすべて大文字にするワンライナーです。

import re

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

これはWordsWithOtherUppercaseLettersという結果になります。

11
Anon

見ているように こちら 陳Houwuが答えて、それは文字列パッケージを使用することが可能です:

import string
string.capwords("they're bill's friends from the UK")
>>>"They're Bill's Friends From The Uk"
4
Fábio

私はこれを思い付きました:

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
1
Prasanth

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

1
Gürol Canbek

正規表現を使用して各Wordの最初の文字(preceded by a digit)を置き換えることができます。

re.sub(r'(\d\w)', lambda w: w.group().upper(), '1bob 5sandy')

output:
 1Bob 5Sandy
1
zety