только первая буква с большой буквы

179

Я знаю, что .capitalize () использует заглавные буквы в первой строке, но что, если первый символ является целым числом?

этот

1bob
5sandy

к этому

1Bob
5Sandy
user1442957
источник

Ответы:

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
1
@ Jan-PhilipGehrcke, это упражнение для читателя. В этом случае вы можете видеть, что s никогда не бывает пустым, это всегда '123sa': D
Али Афшар
2
@ Jan-PhilipGehrcke: в этом случае next((i for i,e in enumerate(test) if not e.isdigit()), '0')решает его для случая пустой строки
njzk2
5
Этот ответ не верен. . capitalizeтакже преобразует другие символы в нижние. Из официальных документов: «Вернуть titlecased версии 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', так что.

DSM
источник
38

Это похоже на ответ @ 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 за указание я не ответил на вопрос! исправлено

pinkwerks
источник
2
Очень полезно, но нужна len(x) == 0ветка.
Ксан
начиная с python 2.5, пустой случай все еще может обрабатываться в одной строке: return x[0].upper() + x[1:] if len(x) > 0 else x
danio
Очень полезный ответ, потому что capitalize& titleсначала строчная вся строка, а затем заглавная только первая буква.
Йонас Либбрехт
5
Полезно. Просто используйте a[:1].upper() + a[1:], это позаботится о len(X)==0углу дела.
норманиус
1
Хорошая работа, но не работает в этом случае, потому что эта функция использует только первый символ, а первый символ - цифра, а не текст. Вам нужно разделить цифру и цифру перед использованием и объединить результат в этом случае.
GeoStoneMarten
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
Prasanth
источник
1

Вы можете заменить первую букву ( preceded by a digit) каждого слова с помощью регулярных выражений:

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

output:
 1Bob 5Sandy
Kenly
источник
1

однострочник: ' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))

Гюрол Чанбек
источник
Я думаю, что вы имеете в виду это не так ли? '' .join (sub [: 1] .upper () + sub [1:] для sub в text.split (''))
Майкл,
Исправлено. Спасибо @Michael
Gürol Canbek