据我所知,re建议以下边界匹配.
^ 匹配在一行的开头.$ 匹配在一行的末尾.\A 匹配输入的开头.\Z 匹配输入的结尾.你能给我一个形而下例子呈现出真正的差异之间^,$并且\A,\Z?
Mar*_*ers 15
只有在使用re.M或多re.MULTILINE行标志时才会出现差异:
>>> re.search(r'^word', 'Line one\nword on line two\n', flags=re.M)
<_sre.SRE_Match object at 0x10124f578>
>>> re.search(r'\Aword', 'Line one\nword on line two\n', flags=re.M) is None
True
Run Code Online (Sandbox Code Playgroud)
在一行^的开头匹配(在换行符之后).在一行的末尾匹配:$
>>> re.search(r'word$', 'Line one word\nLine two\n', flags=re.M)
<_sre.SRE_Match object at 0x10123e1d0>
>>> re.search(r'word\Z', 'Line one word\nLine two\n', flags=re.M) is None
True
Run Code Online (Sandbox Code Playgroud)
从文档:
re.M
re.MULTILINE指定时,模式字符
'^'匹配字符串的开头和每行的开头(紧跟在每个换行符之后); 并且模式字符'$'在字符串的末尾和每行的末尾(紧接在每个换行符之前)匹配.默认情况下,'^'仅匹配字符串的开头,并且'$'仅匹配字符串的结尾,紧接在字符串末尾的换行符(如果有)之前.
\A 总是在字符串的开头匹配,\Z总是在最后.
| 归档时间: |
|
| 查看次数: |
3491 次 |
| 最近记录: |