字符串中的大写字母后接小写字母



如何检查字符串是否有一个字母序列,上面是1,后面是1,依此类推?

我可以使用re.search((来验证这一点吗?最好的方法是什么?

text1 = "AbAb" -> return True 
text2 = "aBaB" -> return True
text3 = "ABaB" -> return False
text4 = "abAb" -> return False

您可以使用regex。你可以在这里试试

def check(str_):
pattern = re.compile("(?:[A-Z][a-z]|[a-z][A-Z])*")
return pattern.match(str_).group(0) == str_
check("AbAb")
output: True
check("aBaB")
output: True
check("ABaB")
output: False
check("abAb")
output: False

使用re.search():

import re
[*map(lambda x: True if re.search(r'[A-Z][a-z][A-Z][a-z]|[a-z][A-Z][a-z][A-Z]', x) else False, 
[text1, text2, text3, text4])]

最新更新