使用正则表达式在Python中将重复的大写字母替换为单个小写字母

41 投票
7 回答
50180 浏览
提问于 2025-04-16 06:51

我想把字符串中连续出现的两个大写字母替换成一个小写字母。现在我用的正则表达式可以找到这些重复的大写字母,但我不知道怎么把替换后的字母变成小写。

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

我该怎么把“\1”变成小写呢?我是不是不应该用正则表达式来做这个?

7 个回答

1
def replace(s):
    return " ".join(re.findall(r"[A-Z]){2}", s)).lower()

我想这就是你想要的。

10

在替换字符串中,你无法直接改变字母的大小写。你需要使用一个替换函数来实现这个功能:

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

可以把一个函数作为 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'

撰写回答