Je suis conscient que .capitalize () met en majuscule la première lettre d'une chaîne mais que se passe-t-il si le premier caractère est un entier?
cette
1bob
5sandy
pour ça
1Bob
5Sandy
Si le premier caractère est un entier, la première lettre ne sera pas mise en majuscule.
>>> '2s'.capitalize()
'2s'
Si vous voulez utiliser cette fonctionnalité, supprimez les chiffres, vous pouvez utiliser '2'.isdigit()
pour vérifier chaque caractère.
>>> s = '123sa'
>>> for i, c in enumerate(s):
... if not c.isdigit():
... break
...
>>> s[:i] + s[i:].capitalize()
'123Sa'
Seulement parce que personne ne l'a mentionné:
>>> 'bob'.title()
'Bob'
>>> 'sandy'.title()
'Sandy'
>>> '1bob'.title()
'1Bob'
>>> '1sandy'.title()
'1Sandy'
Cependant, cela donnerait aussi
>>> '1bob sandy'.title()
'1Bob Sandy'
>>> '1JoeBob'.title()
'1Joebob'
c’est-à-dire que le premier caractère alphabétique n'est pas mis en majuscule. Mais alors .capitalize()
a le même problème, du moins dans cette 'joe Bob'.capitalize() == 'Joe bob'
, alors meh.
Ceci est similaire à la réponse de @ Anon en ce sens que le reste de la chaîne est conservé tel quel, sans avoir besoin du module 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
Comme @Xan l'a fait remarquer, la fonction pourrait utiliser davantage de vérifications d'erreur (comme vérifier que x est une séquence - cependant, j'omets des cas Edge pour illustrer la technique).
Mis à jour par commentaire @normanius (merci!)
Merci à @GeoStoneMarten de souligner que je n'ai pas répondu à la question! -fixé que
Voici une ligne qui majuscule la première lettre et laisse le cas de toutes les lettres suivantes:
import re
key = 'wordsWithOtherUppercaseLetters'
key = re.sub('([a-zA-Z])', lambda x: x.groups()[0].upper(), key, 1)
print key
Cela aura pour résultat WordsWithOtherUppercaseLetters
En tant que ici répondu par Chen Houwu, il est possible d'utiliser un paquet de chaînes:
import string
string.capwords("they're bill's friends from the UK")
>>>"They're Bill's Friends From The Uk"
Je suis venu avec ceci:
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
une ligne: ' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))
Vous pouvez remplacer la première lettre (preceded by a digit
) de chaque mot en utilisant regex:
re.sub(r'(\d\w)', lambda w: w.group().upper(), '1bob 5sandy')
output:
1Bob 5Sandy