据我所知,re
提出以下边界匹配。
^
在一行开头匹配。$
在一行末尾匹配。\A
匹配输入的开头。\Z
匹配输入的结尾。你能否给我一个具体的例子,显示^
,$
和\A
,\Z
之间真正的区别?
答案 0 :(得分:13)
只有在使用re.M
or re.MULTILINE
multiline flag:
>>> 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
其中^
在行的开头匹配(在换行符之后)。 $
匹配在一行的末尾:
>>> 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
来自文档:
re.M
re.MULTILINE
指定时,模式字符
'^'
匹配字符串的开头和每行的开头(紧跟在每个换行符之后);模式字符'$'
在字符串的末尾和每行的末尾(紧接在每个换行符之前)匹配。默认情况下,'^'
仅匹配字符串的开头,'$'
仅匹配字符串的结尾,紧接在字符串末尾的换行符(如果有)之前。
\A
总是匹配字符串的开头,无论\Z
总是在最后。