我的正则表达式模式是这样的
<xxxx location="file path/level1/level2" xxxx some="xxx">
我只对分配给位置的引号中的部分感兴趣。如果没有贪婪开关,它不应该像下面这样简单吗?
/.*location="(.*)".*/
似乎并不奏效。
我的正则表达式模式是这样的
<xxxx location="file path/level1/level2" xxxx some="xxx">
我只对分配给位置的引号中的部分感兴趣。如果没有贪婪开关,它不应该像下面这样简单吗?
/.*location="(.*)".*/
似乎并不奏效。
当前回答
还有另一种方法。
这是你要的。这是懒惰[\s\ s]*?
第一项: [\ s \ s] *(?:位置 ="[^"]*")[\ s \] *替换为:1美元
解释:https://regex101.com/r/ZcqcUm/2
为了完整起见,这里得到最后一个。这是贪婪的[\s\ s]*
最后一项:[\ s \ s] *(?:位置 ="([^"]*)")[\ s \] * 替换为:$1
解释:https://regex101.com/r/LXSPDp/3
这两个正则表达式之间只有一个区别,那就是?
其他回答
使用惰性量词?没有全局标志就是答案。
Eg,
如果你有全局flag /g,它会匹配所有最小长度的匹配,如下所示。
如何
.*location="([^"]*)".*
这避免了使用.*进行无限搜索,并将精确匹配第一个引号。
Location ="(.*)"将从" after Location ="直到" after some="xxx匹配,除非你让它是非贪婪的。
所以你需要。*?(即通过添加?使其非贪婪),或者更好地将.*替换为[^"]*。
[^"]匹配除" <引号>以外的任何字符 更通用:[^abc] -匹配除a, b或c之外的任何字符
还有另一种方法。
这是你要的。这是懒惰[\s\ s]*?
第一项: [\ s \ s] *(?:位置 ="[^"]*")[\ s \] *替换为:1美元
解释:https://regex101.com/r/ZcqcUm/2
为了完整起见,这里得到最后一个。这是贪婪的[\s\ s]*
最后一项:[\ s \ s] *(?:位置 ="([^"]*)")[\ s \] * 替换为:$1
解释:https://regex101.com/r/LXSPDp/3
这两个正则表达式之间只有一个区别,那就是?
import regex
text = 'ask her to call Mary back when she comes back'
p = r'(?i)(?s)call(.*?)back'
for match in regex.finditer(p, str(text)):
print (match.group(1))
输出: 玛丽