search 搜索
groups 打印
+ 表示1到多个字符
. 匹配所有的字符
* 0到多个所有字符
\$ 转义
? 匹配一个或0个
\D 匹配一个非数字
\w 匹配一个字符
\b 匹配一个单词的开头和结尾\b
\s 匹配一个空格
\S 匹配一个非空格
re.ignorecase 忽略大小写(flag)
‘\A‘ 只从字符开头匹配,re.search("\Aabc","alexabc") 是匹配不到的
‘\Z‘ 匹配字符结尾,同$
‘\d‘ 匹配数字0-9
‘\w‘ 匹配[A-Za-z0-9]
‘\W‘ 匹配非[A-Za-z0-9]
‘s‘ 匹配空白字符、\t、\n、\r , re.search("\s+","ab\tc1\n3").group() 结果 ‘\t‘
‘.‘ 默认匹配除\n之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行
‘^‘ 匹配字符开头,若指定flags MULTILINE,这种也可以匹配上(r"^a","\nabc\neee",flags=re.MULTILINE)
‘$‘ 匹配字符结尾,或e.search("foo$","bfoo\nsdfsf",flags=re.MULTILINE).group()也可以
‘*‘ 匹配*号前的字符0次或多次,re.findall("ab*","cabb3abcbbac") 结果为[‘abb‘, ‘ab‘, ‘a‘]
‘+‘ 匹配前一个字符1次或多次,re.findall("ab+","ab+cd+abb+bba") 结果[‘ab‘, ‘abb‘]
‘?‘ 匹配前一个字符1次或0次
‘{m}‘ 匹配前一个字符m次
‘{n,m}‘ 匹配前一个字符n到m次,re.findall("ab{1,3}","abb abc abbcbbb") 结果‘abb‘, ‘ab‘, ‘abb‘]
‘|‘ 匹配|左或|右的字符,re.search("abc|ABC","ABCBabcCD").group() 结果‘ABC‘
‘(...)‘ 分组匹配,re.search("(abc){2}a(123|456)c", "abcabca456c").group() 结果 abcabca456c
r 表示我的这个正则表达式里面的字符串,在Python里面不再进行转义处理了。
re.compile(re.verbose###这个flag表示可加注释) ###编译正则表达式
search 找到第一个就会停下来
findall 找到还会往下找
finditer 返回迭代器
正则表达式语法:
{m} 匹配多少次
通配符:
(d\)(d\)\2(数字) 数字与后面的对应
\d 例:print (re.search(r‘\d{3}-\d{4}-\d{4}‘,"the num is 123-4567-8907")).group()
#print (re.match(r‘.*‘,‘abc\nedf‘,re.DOTALL)).group() ###此处表示这个点不仅代表字符串,还代表换行符
#print (re.findall(r‘^abc‘,‘abc\nedf‘,re.MULTILINE))
#print (re.findall(r‘abc\d$‘,‘abc1\nabc2‘,re.MULTILINE)) ###如果没有MULTILINE这个标志表示以字符串结束,如果有则以列表结束
print (re.match(‘ab?.‘,‘abb‘)).group()
####greedy /no-greedy ###贪婪模式和非贪婪模式,用?可变成非贪婪模式
print (re.search(r‘\d{3}-\d{4}-\d{4}‘,"the num is 123-4567-8907")).group()
‘(?P<name>...)‘
分组匹配 re.search("(?P<province>[0-9]{4})(?P<city>[0-9]{2})(?P<birthday>[0-9]{4})","371481199306143242").groupdict("city")
结果{‘province‘: ‘3714‘, ‘city‘: ‘81‘, ‘birthday‘: ‘1993‘}