1、re.match()的用法
re.match()方法是从起始位置开始匹配一个模式,匹配成功返回一个对象,未匹配成功返回None。
语法:
- re.match(pattern, string, flags=0)
参数说明:
- pattern:匹配的正则表达式;
- string:要匹配的字符串;
- flags:标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等;
示例如下:
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import re
-
- if __name__ == '__main__':
- # 匹配模式
- test_pattern = r"\d{2}年"
- # 待匹配的字符串
- test = "18年2019年2020年"
- print(re.match(test_pattern, test).group())
输出:
18年
Process finished with exit code 0
若将匹配模式改成:
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import re
-
- if __name__ == '__main__':
- # 匹配模式
- test_pattern = r"\d{4}年"
- # 待匹配的字符串
- test = "18年2019年2020年"
- print(re.match(test_pattern, test))
则返回结果为:
None
Process finished with exit code 0
这是因为re.match()仅从头开始匹配,由于起始位置处未找到符合匹配模式的内容,返回None。
2、re.search()的用法
re.search()方法是扫描整个字符串内进行模式匹配,只要找到第一个匹配就返回,如果字符串没有匹配,则返回None。
语法:
- re.search(pattern, string, flags=0)
参数说明:
- pattern:匹配的正则表达式;
- string:要匹配的字符串;
- flags:标志位,用于控制正则表达式的匹配方式,如:是否区分大小写,多行匹配等等;
示例如下:
- #!/usr/bin/env python
- # -*- coding:utf-8 -*-
- import re
-
- if __name__ == '__main__':
- # 匹配模式
- test_pattern = r"\d{4}年"
- # 待匹配的字符串
- test = "18年2019年2020年"
- print(re.search(test_pattern, test).group())
输出:
2019年
Process finished with exit code 0
这是因为re.search()扫描整个字符串,找到符合匹配模式的第一个匹配就返回了。
3、re.match()与re.search()的区别
re.match()方法要求必须从字符串的开头进行匹配,如果字符串开头不符合模式规则,整个匹配就失败了,函数返回None;
re.search()并不要求必须从字符串的开头进行匹配,而是扫描整个字符串,直到找到第一个匹配。
到此这篇关于python正则表达式之re.match()与re.search()的用法及区别的文章就介绍到这了,更多相关python re.match()与re.search()内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!