正则表达式
一,认识正则表达式
正则表达式: 解决字符串问题的工具(让复杂的字符串问题变得简单的一个工具)
二,匹配类符号
1. re模块
re模块是python用来支持正则表达式的一个模块
re模块中提供了各种和正则相关的函数:fullmatch、search、findall、match、split、sub等等
fullmatch(正则表达式, 字符串) - 判断整个字符串是否完全符号正则表达式描述的规则。如果不符合返回值是None
python中提供正则表达式的方式:r'正则表达式'
js中提供正则表达式的方式:/正则表达式/
2. 匹配类符号 - 一个正则符号表示一类字符
匹配类符号在正则中的作用:用来要求字符串中某个位置必须是什么样的字符
1)普通符号 - 在正则表达式中表示这个符号本身,对应字符串中的字符的要求就是符号本身。
2) . - 匹配一个任意字符
3)\d - 匹配一个任意数字
4)\s - 匹配任意一个空白字符(空白字符包括:空格、\n、\t)
5)\w - 匹配任意一个数字、字母或者下划线或者中文
6)\大写字母 - 与相应的小写字母的功能相反
7) [字符集] - 匹配字符集中任意一个字符
[多个普通符号] - 例如:[abc12], 在'a'、'b'、'c'、'1'、'2'五个符号中任意一个可以匹配
[包含\开头的特殊符号] - 例如:[mn\d]、[m\dn]、[\dmn], 要求是m或者n或者任意一个数字
[字符1-字符2] - 例如:[a-z],要求是任意一个小写字母
[a-zA-Z],要求是任意一个字母
[2-9a-z],要求是2到9或者是任意一个小写字母
[\u4e00-\u9fa5],要求是任意一个中文
[\u4e00-\u9fa5\dabc]
注意:[]中如果-不在两个字符之间,就不能表示谁到谁,那它就是个普通符号
8) ^字符集 - 匹配不在字符集中的任意一个字符
三,匹配次数
1. * - 匹配0次或者多次(任意次数)
a* - a出现任意次数
\d* - 任意多个\d -> 任意多个数字
[abc]* - 任意多个[abc] -> 任意多个(a或者b或者c)
2. + - 匹配1次或者多次(至少1次)
3. ? - 0次或1次
4. {}
{N} - N次
{M,N} - M到N次
{M,} - 至少M次
{,N} - 最多N次
* == {0,}
+ == {1,}
? == {0,1}
5. 贪婪和非贪婪
在匹配次数不确定的时候,匹配模式分为贪婪和非贪婪两种,默认是贪婪的。
匹配次数不确定:*、+、?、{M,N}、{M,}、{,N}
贪婪和非贪