Как проверить, является ли символ верхним регистром в Python?
У меня есть строка, подобная этой
>>> x="Alpha_beta_Gamma"
>>> words = [y for y in x.split('_')]
>>> words
['Alpha', 'beta', 'Gamma']
Я хочу, чтобы вывод, говорящий, что X не соответствует, поскольку второй элемент слова списка начинается с нижнего регистра, а если строка x = "Alpha_Beta_Gamma"
, то она должна печатать строку согласованно
Ответы
Ответ 1
Возможно, вы хотите str.istitle
>>> help(str.istitle)
Help on method_descriptor:
istitle(...)
S.istitle() -> bool
Return True if S is a titlecased string and there is at least one
character in S, i.e. uppercase characters may only follow uncased
characters and lowercase characters only cased ones. Return False
otherwise.
>>> "Alpha_beta_Gamma".istitle()
False
>>> "Alpha_Beta_Gamma".istitle()
True
>>> "Alpha_Beta_GAmma".istitle()
False
Ответ 2
Чтобы проверить, что все слова начинаются с верхнего регистра, используйте это:
print all(word[0].isupper() for word in words)
Ответ 3
words = x.split("_")
for word in words:
if word[0] == word[0].upper() and word[1:] == word[1:].lower():
print word, "is conformant"
else:
print word, "is non conformant"
Ответ 4
Вы можете использовать этот код:
def is_valid(string):
words = string.split('_')
for word in words:
if not word.istitle():
return False, word
return True, words
x="Alpha_beta_Gamma"
assert is_valid(x)==(False,'beta')
x="Alpha_Beta_Gamma"
assert is_valid(x)==(True,['Alpha', 'Beta', 'Gamma'])
Таким образом, вы знаете, является ли оно допустимым и какое слово неверно
Ответ 5
Вы можете использовать это регулярное выражение:
^[A-Z][a-z]*(?:_[A-Z][a-z]*)*$
Пример кода:
import re
strings = ["Alpha_beta_Gamma", "Alpha_Beta_Gamma"]
pattern = r'^[A-Z][a-z]*(?:_[A-Z][a-z]*)*$'
for s in strings:
if re.match(pattern, s):
print s + " conforms"
else:
print s + " doesn't conform"
Как видно на codepad
Ответ 6
x="Alpha_beta_Gamma"
is_uppercase_letter = True in map(lambda l: l.isupper(), x)
print is_uppercase_letter
>>>>True
Итак, вы можете написать его в 1 строке
Ответ 7
Используйте список (str), чтобы разбить на символы, а затем импортировать строку и использовать string.ascii_uppercase для сравнения.
Проверьте строковый модуль:
http://docs.python.org/library/string.html