pythonは最初の文字のみ大文字にします


179

.capitalize()が文字列の最初の文字を大文字にすることは知っていますが、最初の文字が整数の場合はどうなりますか?

この

1bob
5sandy

これに

1Bob
5Sandy

回答:


234

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

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

機能が必要な場合は、数字を削除して、'2'.isdigit()各文字をチェックするために使用できます。

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

5
そして、それがこの答えがやっていることです
njzk2

16
私はc.isalpha()ではなく、c.isdigit()ではなく使用します
njzk2 '13

1
@ Jan-PhilipGehrckeは読者のための演習です。D:あなたは、それは常に「123sa」で、空にされることはありませんよ、その場合には見ることができます
アリAfshar

2
@ Jan-PhilipGehrcke:この場合、next((i for i,e in enumerate(test) if not e.isdigit()), '0')空の文字列の場合にそれを解決します
njzk2

5
この答えは正しくありません。. capitalize他の文字も小文字に変換します。公式ドキュメントから:「タイトルケースバージョンのSを返します。つまり、単語はタイトルケース文字で始まり、残りのすべてのケース文字は小文字になります。
karantan

246

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

>>> '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'ます。


38

これは、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が質問に答えなかったことを指摘してくれてありがとう!-それを修正


2
非常に便利ですが、len(x) == 0ブランチが必要です。
Xan

:Pythonの2.5ので、空の場合は、まだ一行に扱うことができる return x[0].upper() + x[1:] if len(x) > 0 else x
ダニオ

capitalize&はtitle最初に文字列全体を小文字にしてから、最初の文字だけを大文字にするため、非常に便利な回答です。
Jonas Libbrecht 2016年

5
有用。を使用するだけでa[:1].upper() + a[1:]、これはlen(X)==0コーナーケースを処理します。
ノルマニウス2018年

1
この関数は最初の文字だけを大文字にし、最初の文字は数字ではなくテキストであるため、この場合はうまくいきません。この場合、使用する前に数値と数字を分割し、結果を結合する必要があります。
GeoStoneMarten 2018

13

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

import re

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

これは WordsWithOtherUppercaseLetters


4

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

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

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

1

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

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

output:
 1Bob 5Sandy

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.