Я знаю, что .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'
next((i for i,e in enumerate(test) if not e.isdigit()), '0')
решает его для случая пустой строки
. capitalize
также преобразует другие символы в нижние. Из официальных документов: «Вернуть titlecased версии S, т.е. слова начинаются с заголовком буквами, все остальные обсаженных символы имеют нижний регистр. »
Только потому, что никто не упомянул об этом
>>> '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'
, так что.
Это похоже на ответ @ 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 за указание я не ответил на вопрос! исправлено
len(x) == 0
ветка.
return x[0].upper() + x[1:] if len(x) > 0 else x
capitalize
& title
сначала строчная вся строка, а затем заглавная только первая буква.
a[:1].upper() + a[1:]
, это позаботится о len(X)==0
углу дела.
Вот строка, состоящая из одной строки, которая будет заглавной буквой первой буквы и оставит регистр всех последующих букв:
import re
key = 'wordsWithOtherUppercaseLetters'
key = re.sub('([a-zA-Z])', lambda x: x.groups()[0].upper(), key, 1)
print key
Это приведет к WordsWithOtherUppercaseLetters
однострочник: ' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))