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