Я знаю .capitalize() заглавные буквы первой буквы строки, но что, если первый символ является целым числом?
это
1bob
5sandy
к этому
1bob
5sandy
Я знаю .capitalize() заглавные буквы первой буквы строки, но что, если первый символ является целым числом?
это
1bob
5sandy
к этому
1bob
5sandy
Если первый символ является целым числом, он не будет использовать первую букву.
>>> '2s'.capitalize()
'2s'
Если вам нужна функциональность, отмените цифры, вы можете использовать '2'.isdigit()
для проверки каждого символа.
>>> s = '123sa'
>>> for i, c in enumerate(s):
... if not c.isdigit():
... break
...
>>> s[:i] + s[i:].capitalize()
'123Sa'
Только потому, что никто не упомянул об этом:
>>> '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'
, поэтому meh.
Это похоже на ответ @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 за указание, что я не ответил на вопрос! -fixed что
Вот один лайнер, который будет заглатывать первую букву и оставить случай всех последующих букв:
import re
key = 'wordsWithOtherUppercaseLetters'
key = re.sub('([a-zA-Z])', lambda x: x.groups()[0].upper(), key, 1)
print key
Это приведет к WordsWithOtherUppercaseLetters
Как видите здесь ответил Чэнь Хоуу, можно использовать пакет string:
import string
string.capwords("they're bill friends from the UK")
>>>"They're Bill Friends From The Uk"
Я придумал это:
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
Вы можете заменить первую букву (preceded by a digit
) каждого слова с помощью регулярного выражения:
re.sub(r'(\d\w)', lambda w: w.group().upper(), '1bob 5sandy')
output:
1Bob 5Sandy
однострочник: ' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))