Мне дано предложение Моя команда — команда BeST на турнире. в качестве тестового примера для создания функции
def case_insensitivity(sentence):
return new_sentence
который проверяет данное предложение на наличие слова без учета регистра и заменяет слово без учета регистра на XXX_
.
то есть
print(case_insensitivity('My team is the BeST team at the tournament'))
result
'My team is the XXX_ team at the tournament'
Как лучше всего это сделать? casefold()
Предполагая, что мы определяем целевые слова как имеющие как строчные, так и прописные буквы после первого символа, мы можем попробовать использовать re.sub
для параметра регулярного выражения:
def case_insensitivity(sentence):
return re.sub(r'\w+(?:[A-Z]\w*[a-z]|[a-z]\w*[A-Z])\w*', 'XXX_', sentence)
print(case_insensitivity('My team is the BeST team at the tournament'))
Это печатает:
My team is the XXX_ team at the tournament
Это мое решение (надеюсь, я хорошо понимаю вашу проблему):
вы разбиваете предложение на вводные слова.
ты перебираешь все слова
вы перебираете буквы слов, начиная со второй буквы каждого слова.
проверьте, есть ли заглавные буквы
если вы найдете заглавную букву, вы присваиваете 1 переменной have_to_replace.
ты делаешь замену
txt = 'My team is the BeST team at the tournament'
x = txt.split()
for w in x:
have_to_replace = False
for l in w[1:]:
if l != l.casefold():
have_to_replace = True
if have_to_replace:
txt = txt.replace(w, 'XXX_', 1)
print(txt)
По какой-то причине блокировка кода не работает должным образом для первых 3 строк (и последней). Простите за это.
Ты прав. Это должно быть логическое значение (True/False). Я исправил это.
почему вы используете int для логической переменной?