我正在尝试匹配模式:
<--Header Title-->
some body text
以下仅匹配第一次出现的情况:
string1 = """<-- Option 1 -->
Nice text
<--Final stuff-->
Listing all
of
the
text
"""
regex = re.compile(r"<--([\w\s]+)-->([\s\S]*?)(?=\n<--|$)")
m = regex.search(string1)
print m.groups()
结果是:
(' Option 1 ', '\nNice text')
Final%20stuff–%3E%0AListing%20all%0Aof%0Athe%0Atext&ignorecase=0&multiline=0&dotall=0&verbose=0)。
我究竟做错了什么?
重新搜索仅匹配字符串中的第一个匹配项。您需要finditer还是findall。
研究
扫描字符串以查找正则表达式模式产生匹配项的 第一个位置
,然后返回相应的MatchObject实例。如果字符串中没有位置与模式匹配,则返回None;否则,返回None。请注意,这与在字符串中的某个点找到零长度匹配不同。
Finditer返回目标字符串中所有位置的匹配对象,从而产生一个迭代器,而findall返回所有匹配项的子字符串。
>>> import re
>>> re.findall('a', 'ababababa')
['a', 'a', 'a', 'a', 'a']
>>> x = list(re.finditer('a', 'ababababa'))
>>> x
[<_sre.SRE_Match object; span=(0, 1), match='a'>,
<_sre.SRE_Match object; span=(2, 3), match='a'>,
<_sre.SRE_Match object; span=(4, 5), match='a'>,
<_sre.SRE_Match object; span=(6, 7), match='a'>,
<_sre.SRE_Match object; span=(8, 9), match='a'>]
>>> x[0].group()
'a'
问题内容: 我有一个字符串,其结构类似于:。每次来自外部源的字符串都可能有所不同。 我只想替换第一次出现的而不是其他的。可能吗? 问题答案: preg_replace的可选第四个参数是:
不经过验证的regex将如下所示-,确保它是10个字符。
根据下面的示例,我有一个正则表达式模式。 但是,作为一个一次性的派生,如果只有一个模式(匹配第一个实例的空白行&模式上方的一个空格),我可以让下面的内容匹配。 http://regex101.com/r/ey0ic7 但是,如果模式位于第一行,则没有匹配。
我如何定义一个regex来实现这一点? 提前谢了。
我正在写一个求解方程求解方法。方法将是递归的;搜索所有外括号,当找到时,重新求解括号内的值,当没有找到括号时返回值。 Regex.Replace(...)替换指定模式的所有匹配项。我希望能够匹配到多个场景,并用不同的输出替换每个场景