match()函数只检测RE是不是在string的开始位置匹配, search()会扫描整个string查找匹配, 也就是说match()只有在0位置匹配成功的话才有返回,如果不是开始位置匹配成功的话,match()就返回none
例如:
1
2
3
4
5
6
7
8
9
10
11
|
#! /usr/bin/env python # -*- coding=utf-8 -*- import re text = 'pythontab' m = re.match(r "\w+" , text) if m: print m.group( 0 ) else : print 'not match' |
结果是:pythontab
而:
1
2
3
4
5
6
7
8
9
10
11
12
|
#! /usr/bin/env python # -*- coding=utf-8 -*- # import re text = '@pythontab' m = re.match(r "\w+" , text) if m: print m.group( 0 ) else : print 'not match' |
结果是:not match
search()会扫描整个字符串并返回第一个成功的匹配
例如:
1
2
3
4
5
6
7
8
9
10
11
12
|
#! /usr/bin/env python # -*- coding=utf-8 -*- # import re text = 'pythontab' m = re.search(r "\w+" , text) if m: print m.group( 0 ) else : print 'not match' |
结果是:pythontab
那这样呢:
1
2
3
4
5
6
7
8
9
10
11
12
|
#! /usr/bin/env python # -*- coding=utf-8 -*- # import re text = '@pythontab' m = re.search(r "\w+" , text) if m: print m.group( 0 ) else : print 'not match' |
结果是:pythontab
更多关于python正则函数请查看下面的相关文章
原文链接:https://www.pythontab.com/html/2013/pythonjichu_0201/199.html