python仅将首字母大写


178

我知道.capitalize()将字符串的第一个字母大写,但是如果第一个字符是整数怎么办?

这个

1bob
5sandy

对此

1Bob
5Sandy

Answers:


233

如果第一个字符是整数,则不会大写第一个字母。

>>> '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 2012年

16
我会使用if c.isalpha()而不是c.isdigit()
njzk2 2012年

1
@ Jan-PhilipGehrcke对读者来说是一个练习。您可以看到在这种情况下,s永远不会为空,它始终是'123sa':D
Ali Afshar

2
@ Jan-PhilipGehrcke:在这种情况下,next((i for i,e in enumerate(test) if not e.isdigit()), '0')可以解决空字符串的情况
njzk2 2014年

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

这与@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指出我没有回答问题!-固定


2
非常有用,但需要一个len(x) == 0分支。
2015年

由于python 2.5,空的情况仍然可以在一行上处理: return x[0].upper() + x[1:] if len(x) > 0 else x
danio

答案非常有用,因为capitalizetitle首先将整个字符串小写,然后仅将第一个字母大写。
Jonas Libbrecht

5
有用。只需使用a[:1].upper() + a[1:],这将解决len(X)==0特殊情况。
normanius

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

正如陈厚武在这里回答的那样,可以使用字符串包:

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

1

单线: ' '.join(sub[:1].upper() + sub[1:] for sub in text.split(' '))


我想你是说这不是吗?''.join(sub [:1] .upper()+ sub [1:] for sub in text.split(''))
Michael,

已更正。感谢@迈克尔
GürolCanbek
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.