python学习之re模块
这几天玩爬虫已经使用了很多次的re模块,算是比较熟悉了,这里梳理一下。
首先,关于正则表达式的概念,这里有最好的教程。
对于正则表达式,我们可以先用compile方法编译为pattern对象,再调用相关的方法进行模式匹配,也可以直接进行匹配。
对于第一种,示例如下:
1 | import re |
对于第二种,相应代码为:
1 | import re |
返回结果和第一种一样,使用方法也有明显的规律,就是把正则表达式放在第一个参数位置。
值得注意的是,在第一种的re.compile()和第二种的方法中,都可以附加一个额外的参数用来标明匹配模式,放在最后面。
可选值有:
re.I(全拼:IGNORECASE): 忽略大小写(括号内是完整写法,下同)
re.M(全拼:MULTILINE): 多行模式,改变’^’和’$’的行为(参见上图)
re.S(全拼:DOTALL): 点任意匹配模式,改变’.’的行为
re.L(全拼:LOCALE): 使预定字符类 \w \W \b \B \s \S 取决于当前区域设定
re.U(全拼:UNICODE): 使预定字符类 \w \W \b \B \s \S \d \D 取决于unicode定义的字符属性
re.X(全拼:VERBOSE): 详细模式。这个模式下正则表达式可以是多行,忽略空白字符,并可以加入注释。
可以使用类似re.I | re.M
形式,使这两种模式同时生效。