繁体   English   中英

在Python中使用re.sub获取组匹配

[英]Get Group Match in re.sub in Python

在Perl中,我可以进行替换并同时捕获组匹配。 例如

my $string = "abcdef123";
$string =~ s/(\d+)//;
my $groupMatched = $1; # $groupMatched is 123

在Python中,我可以使用re.sub函数进行替换,如下所示。 但是,我找不到一种方法来捕获\\ d +组匹配而不调用另一个函数re.match并执行其他操作。

string = "abcdef123"
string = re.sub("(\d+)", "", string)

有谁知道如何将“\\ d +”匹配值作为一个单独的变量从同一个re.sub操作中捕获? 我尝试了以下命令,但它不起作用。

print r'\1'

你可以作弊并将函数传递给re.sub

results = []
def capture_and_kill(match):
    results.append(match)
    return ""
string = "abcdef123"
string = re.sub("(\d+)", capture_and_kill, string)
results[0].group(1)
# => '123'

您可以执行以下操作:

sub_str = re.search("(\d+)", str).group(1)

会找到“123”部分。

然后你替换它:

str = str.replace(sub_str, "")

请注意,如果序列超过[0-9],则需要使用findall并在所有匹配项上手动迭代。

下面在python 3.6下测试的代码。

test = "abcdef123"
resp = re.sub(r'\w+[A-Za-z](\d+)',r'\1',test)
print (resp)

123

要建立Marouns答案,您还可以执行以下操作:

str = "foobarzoo"
match = re.search(r"foo(bar)", str)

然后用完整的匹配“foobar”替换它:

str = str.replace(match.group(0), "")

然后可以通过以下方式访问第一组(括号内)“bar”:

match.group(1)

使用这种方法str最终将等于“动物园”

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM