python正则表达式提取字符串前后都一样中间的_只提取两个正则表达式模式之间的字符串部分...

我看了this question,虽然答案解决了OP的问题,但实际上并没有回答问题。当只有相关部分前后的模式已知时,如何提取给定字符串的一部分?在

例如,如果我有一个这样的字符串:

"Hi, this is a string where only values = { 000.10, 2.00, 5.0, 10.0 } are important

对于这个字符串,我需要特别提取000.10, 2.00, 5.0, 10.0。我不知道会有多少个数字或它们的格式,甚至不知道它们之间有多少空格,但我知道values = {和{}将在开头和结尾。在

使用正则表达式,我可以通过以下操作找到values = { 000.10, 2.00, 5.0, 10.0 }:import re

string = "Hi, this is a string where only values = { 000.10, 2.00, 5.0, 10.0 } are important"

match = re.search(r'values\s=\s\{.+}\s', string)

if match:

print match.group()

else:

print "Could not find a match..."

哪些输出:

values = { 000.10, 2.00, 5.0, 10.0 }

那么如何才能只得到模式r'values\s=\s\{和\}\s之间的文本呢?在

我知道我可以用这样的空字符串替换起始和结束模式:

match.group().replace('values = { ', '').replace(' } ', '')

但是有没有一种方法可以合并这样一个事实:我只需要正则表达式本身中两个模式之间的结果?在

希望这个问题有意义。如有任何答复,将不胜感激。在

已标记关键词 清除标记
表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2020 CSDN 皮肤主题: 游动-白 设计师:白松林 返回首页