正则表达式

Posted FRESHMANS

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了正则表达式相关的知识,希望对你有一定的参考价值。

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‘}

以上是关于正则表达式的主要内容,如果未能解决你的问题,请参考以下文章

markdown 正则表达式模式片段

正则表达式匹配特定的 URL 片段而不是所有其他 URL 可能性

循环通过 python 正则表达式匹配

asp.net 使用正则表达式验证包含打开/关闭括号片段的属性字符串

攻破难啃的骨头-正则表达式(转)

正则表达式的贪婪和非贪婪模式