1.1 字符与字符类
以上特殊字符要想使用字面值,必须使用进行转义
1. 包含在中的一个或者多个字符被称为字符类,字符类在匹配时如果没有指定量词则只会匹配其中的一个。
3. 左方括号后跟随一个,表示否定一个字符类,比如[0-9]表示可以匹配一个任意非数字的字符。
5. 字符类内部可以使用速记法,比如d s w
. 可以匹配除换行符之外的任何字符,如果有re.DOTALL标志,则匹配任意字符包括换行
D 匹配Unicode非数字
S 匹配Unicode非空白
W 匹配Unicode非单子字符
1. ?匹配前面的字符0次或1次
3. +匹配前面的字符1次或者多次
5. {m,}匹配前面表达式至少m次
7. {m,n}匹配前面的正则表达式至少m次,最多n次
以上量词都是贪婪模式,会尽可能多的匹配,如果要改为非贪婪模式,通过在量词后面跟随一个?来实现
1 的作用:
2. 将正则表达式的一部分内容进行组合,以便使用量词或者|
1. 通过组号反向引用
2. 通过组名反向引用前面小括号内捕获的内容
3 注意点:
1.4 断言与标记
1 常用断言:
2. B 匹配非单词边界,受ASCII标记影响
4. ^在起始处匹配,如果有MULTILINE标志,则在每个换行符后匹配
6. $在结尾处匹配,如果有MULTILINE标志,则在每个换行符前匹配
8. (?!e)负前瞻
10.(?<!e)负回顾
前瞻:exp1(?=exp2) exp1后面的内容要匹配exp2
后顾: (?<=exp2)exp1 exp1前面的内容要匹配exp2
例如:我们要查找hello,但是hello后面必须是world,正则表达式可以这样写:"(hello)s+(?=world)",用来匹配"hello wangxing"和"hello world"只能匹配到后者的hello
(?(id)yes_exp|no_exp):对应id的子表达式如果匹配到内容,则这里匹配yes_exp,否则匹配no_exp
1. 正则表达式的标志有两种使用方法
2. 通过在正则表达式前面添加(?标志)的方法给正则表达式添加标志,如(?ms)#[da-z]{6}
re.A或者re.ASCII, 使 B s S w W d D都假定字符串为假定字符串为ASCII
re.M或者re.MULTILINE 多行匹配,使每个^在每个回车后,每个$在每个回车前匹配
re.X或者re.VERBOSE 这样可以在正则表达式跨越多行,也可以添加注释,但是空白需要使用s或者来表示,因为默认的空白不再解释。如:
<imgs +)#标签的开始
src=#src属性的开始
(?P<quote>["'])#左引号
(?P=quote)#右括号
2. Python正则表达式模块
1. 匹配 查看一个字符串是否符合正则表达式的语法,一般返回true或者false
3. 替换查找字符串中符合正则表达式的文本,并用相应的字符串替换
2.2 Python中re模块使用正则表达式的两种方法
2. re模块中对正则表达式对象的每个对象方法都有一个对应的模块方法,唯一不同的是传入的第一个参数是正则表达式字符串。此种方法适合于只使用一次的正则表达式。
1. rx.findall(s,start, end):
如果正则表达式中有分组,则列表中的每个元素是一个元组,元组中包含子分组中匹配到的内容,但是没有返回整个正则表达式匹配的内容
返回一个可迭代对象
3. rx.search(s, start, end):
search方法只匹配一次就停止,不会继续往后匹配
如果正则表达式在字符串的起始处匹配,就返回一个匹配对象,否则返回None
返回一个字符串。每一个匹配的地方用x进行替换,返回替换后的字符串,如果指定m,则最多替换m次。对于x可以使用/i或者/g<id>id可以是组名或者编号来引用捕获到的内容。
6. rx.subn(x, s, m):
7. rx.split(s, m):分割字符串
用正则表达式匹配到的内容对字符串进行分割
rx = re.compile(r"(d)[a-z]+(d)")
result = rx.split(s)
8. rx.flags:正则表达式编译时设置的标志
2.4 匹配对象的属性与方法
返回编号或者组名匹配到的内容,默认或者0表示整个表达式匹配到的内容,如果指定多个,就返回一个元组
返回一个字典。字典的键是所有命名的组的组名,值为命名组捕获到的内容
03. m.groups(default)
04. m.lastgroup
05. m.lastindex
06. m.start(g):
07. m.end(g)
08. m.span
09. m.re
10. m.string
11. m.pos
12. m.endpos
2.5 总结
2. 对于正则表达式的搜索功能,如果只搜索一次可以使用search或者match方法返回的匹配对象得到,对于搜索多次可以使用finditer方法返回的可迭代对象来迭代访问
4. 对于正则表达式的分割功能,可以使用正则表达式对象的split方法,需要注意如果正则表达式对象有分组的话,分组捕获的内容也会放到返回的列表中
*声明:本文于网络整理,版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜。
