Подтвердить что ты не робот

Использование регулярного выражения для замены повторений букв в верхнем регистре в python с помощью одной строчной буквы

Я пытаюсь заменить любые экземпляры прописных букв, которые повторяются дважды в строке с одним экземпляром этой буквы в нижнем регистре. Я использую следующее регулярное выражение, и он способен сопоставлять повторяющиеся буквы верхнего регистра, но я не уверен, как сделать письмо, которое заменяется в нижнем регистре.

import re
s = 'start TT end'
re.sub(r'([A-Z]){2}', r"\1", s)
>>> 'start T end'

Как я могу сделать "\ 1" нижний регистр? Должен ли я использовать регулярное выражение для этого?

4b9b3361

Ответ 1

Передайте функцию в качестве аргумента repl. MatchObject передается этой функции, а .group(1) - первая подгруппа в скобках:

import re
s = 'start TT end'
callback = lambda pat: pat.group(1).lower()
re.sub(r'([A-Z]){2}', callback, s)

ИЗМЕНИТЬ
И да, вы должны использовать ([A-Z])\1 вместо ([A-Z]){2}, чтобы не совпадать, например. AZ. (См. @bobince ответ.)

import re
s = 'start TT end'
re.sub(r'([A-Z])\1', lambda pat: pat.group(1).lower(), s) # Inline

дает:

'start t end'

Ответ 2

Вы не можете изменить регистр в заменяющей строке. Вам понадобится функция замены:

>>> def replacement(match):
...     return match.group(1).lower()
... 
>>> re.sub(r'([A-Z])\1', replacement, 'start TT end')
'start t end'

Ответ 3

Вы можете сделать это с помощью регулярного выражения, просто передайте функцию в качестве замены, например . Проблема заключается в вашей схеме.

Как бы то ни было, ваш шаблон соответствует прогонам любых двух заглавных букв. Я оставлю фактический шаблон вам, но он начинается с AA|BB|CC|.

Ответ 4

Параметр "repl", который идентифицирует замену, может быть либо строкой (как у вас здесь), либо функцией. Это сделает то, что вы пожелаете:

import re

def toLowercase(matchobj):
   return matchobj.group(1).lower()

s = 'start TT end'
re.sub(r'([A-Z]){2}', toLowercase, s)
>>> 'start t end'

Ответ 5

Попробуйте следующее:

def tol(m):
   return m.group(0)[0].lower()

s = 'start TTT AAA end'
re.sub(r'([A-Z]){2,}', tol, s)

Обратите внимание, что это не заменяет верхние буквы singe. Если вы хотите это сделать, используйте r'([A-Z]){1,}'.

Ответ 6

Внимание! Этот пост не имеет права на запрос. Продолжайте свою собственную ответственность!

Я не знаю, насколько возможны угловые случаи, но это то, как обычный Python выполняет мою наивную кодировку.

import string
s = 'start TT end AAA BBBBBBB'
for c in string.uppercase:
    s = s.replace(c+c,c.lower())
print s
""" Output:
start t end aA bbbB
"""