Match对象的常用属性包括group()获取匹配字符串、start()/end()定位位置、span()返回坐标元组、string和re回溯原始输入与正则对象,支持组号或命名调用,组合使用可高效提取验证文本。

Python中正则匹配后返回的 Match 对象,是提取和验证文本内容的关键载体。掌握它的常用属性,能让你快速获取匹配结果、定位位置、还原上下文,避免反复调用 re.search() 或手动切片。
match.group():获取实际匹配到的字符串
这是最常用的属性,不带参数时等价于 group(0),返回整个匹配内容;传入数字(如 group(1))可获取对应捕获组的内容。若组未参与匹配(比如用了 ? 且未出现),返回 None。
-
match.group()→ 完整匹配串 -
match.group(1)→ 第一个括号内的子串 -
match.group(1, 3)→ 返回元组,含第1和第3个捕获组 - 建议优先用命名组(
(?P<name>...)</name>),再用match.group('name'),语义更清晰
match.start() 和 match.end():定位匹配在原文中的位置
这两个属性返回整数索引,分别表示匹配起始和结束位置(左闭右开,即 s[match.start():match.end()] == match.group())。对调试、高亮或截取上下文非常实用。
-
match.start()和match.end()默认作用于整个匹配(组号 0) - 支持传入组号或组名,例如
match.start(1)或match.start('year') - 若某组未匹配成功,对应
start()和end()会抛出IndexError
match.span():一步获取起止坐标
span() 是 start() 和 end() 的组合,返回二元元组 (start, end)。省去两次调用,代码更简洁。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~