Python day20正则表达式和re方法
元字符
6个函数以及几个元字符
1.'.'通配符
2.'^'以什么开头
3.'$'以什么结尾
4.'*'紧挨着的字符0~∞次
5.'+'紧挨着的字符1~∞次
6.'?'紧挨的字符0次或1次
7.'{}' {0,}==* {0,1}==? {6}==6次
8.'*?'惰性匹配,就0次 '*?'就1次
9.[]字符集中间是任意一个字符,除了'-','^','\'
10.'\d'数字,相当于[0-9] '\D'非数字字符,相当于[^0-9]
11.'\s'任何空白字符,相当于[\t\n\r\f\v] '\S'任何非空白字符
12.'\w'任何数字字母字符,相当于[0-9a-zA-Z] '\W'任何非数字字母字符
13.'\b'任何一个字符边界,比如空格,&,#
import re print(re.findall("a.h","ashdo,abhex")) print(re.findall("^h.d","hjdhid")) print(re.findall("h.d$","hjdhid")) print(re.findall("d+","ddddlddfdddg")) print(re.findall("ddddl?","ddddlddfdddg")) print(re.findall("ddddv?","ddddlddfdddg")) print(re.findall("d{1,4}","ddddlddfdddg")) print(re.findall("d*?","ddddlddfdddg")) print(re.findall("www[oldboy baidu]","wwwlbaidu")) print(re.findall("q[a-z]","qk")) print(re.findall("q[^A-Z]","q55"))#非A-Z print(re.findall(r"ka|b","babha")) print(re.findall("(abc)+","abcabcabc")) print(re.search("(?P<name>[a-z]+)(?P<age>\d+)","333littlepage18").group("name")) print(re.search("(?P<name>[a-z]+)(?P<age>\d+)","333littlepage18").group("age"))
计算器eval功能讲解,首先求最内层的括号,直到没有括号,最内层括号正则\([^()]*\)
re模块的方法介绍
import re re.findall()#找到所有匹配 re.search()#找到第一个匹配 re.match()#从开始开始匹配一个,只匹配开头,可以用search替代,用的不多 re.split()#分开字符串 print(re.sub("\d","a","555dsda88p",2))#替换 re.subn()#和sub一样,但是返回是元祖,索引2是匹配数字 com=re.compile("\d+") #compile的用法 print(com.findall("asda22cka5236")) re.finditer()#匹配结果返回在迭代器里面