正则表达式与re模块

正则表达式在线测试工具: http://tool.chinaz.com/regex/
本文大量参考:https://www.cnblogs.com/Eva-J/articles/7228075.html#_label10
正则表达式(regular expression)描述了一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串、将匹配的子串替换或者从某个串中取出符合某个条件的子串等。

一、字符组:[字符组]

在同一个位置可能出现的各种的字符组成了一个字符串,在正则表达式中用[ ]表示,字符分为很多类,比如数字、字母、标点等等。
例如你现在要求在一个位置上“只能出现一个数字”,那么这个位置上的字符只能是0、1、2…9这10个数之一。

正则 待匹配字符 匹配结果 说明
[0123456789] 8 True 8出现在字符组内,可以匹配
[0123456789] a False a不在在字符组内,不能匹配
[0-9] 7 True 简化写法,用-表示范围
[a-z] s True [a-z]表示匹配任意一个小写字母
[0-9a-fA-F] e True 可以匹配数字,大小写形式的a~f,用来验证十六进制字符
二、元字符
元字符 匹配内容
. 匹配除换行符一维的任意字符
\w 匹配字母或数字或下划线
\s 匹配任意的空白字符
\d 匹配数字
\W 匹配非字母或数字或下划线
\D 匹配非数字
\S 匹配非空白符
\n 匹配一个换行符
\t 匹配一个制表符
\b 匹配一个单词的结尾
^ 匹配字符串的开始
$ 匹配字符串的结尾
a b
() 匹配括号内的表达式,也表示一个组
[…] 匹配字符组中的字符
^… 匹配除了字符组中字符的所有字符
三、量词
量词 用法说明
重复零次或一次
+ 重复一次或者多次
* 重复零次或者多次
{n} 重复n次
{n,} 重复n次货更多次
{n,m} 重复n到m次

正则表达式与re模块_第1张图片

一些例子

. ^ $

正则 待匹配字符 匹配结果
小. 小杰小海小梅 小杰 小海 小梅
^小. 小杰小海小梅 小杰
小.$ 小杰小海小梅 小梅

* + ? {}

正则 待匹配字符 匹配结果
小.? 小杰和小海龟和小梅大大 小杰 小海龟 小梅大大
小.* 小杰和小海龟和小梅大大 小杰和小海龟和小梅大大
小.+ 小杰和小海龟和小梅大大 小杰和小海龟和小梅大大
小.{1,2} 小杰和小海龟和小梅大大 小杰和 小海龟 小梅大

注意,前面的 *,+,?等量词都是默认贪婪匹配,量词后面加?可以将其变成惰性匹配。

正则 待匹配字符 匹配结果
小.&? 小杰和小海龟和小梅大大 小 小 小

字符集[ ] [ ^ ]

正则 待匹配字符 匹配结果
小[杰海龟梅大大]* 小杰和小海龟和小梅大大 小杰 小海龟 小梅大大
小[^和]* 小杰和小海龟和小梅大大 小杰 小海龟 小梅大大
[\d] 520acdh5 5 2 0 5
[\d]+ 520acdh5 520 5

分组()与 | [^]
身份证号码是一个长度为15或者18个字符的字符串,如果是15位那么全部都由数字组成,首位不能为0;如果是18位,那么前17位全部是数字,末位可能是数字或者x,下面用正则来表示:

正则 说明
^[1-9]\d{13,16}[0-9x]$ 可以匹配一个正确的身份证,但是16、17位的错误身份证也会被匹配
^[1-9]\d{14}{\d{2}[0-9x]}?$ 完美匹配,()表示分组,整体约束\d{2}[0-9x]出现的次数为0-1次
^([1-9]\d{16}[0-9x]|[1-9]\d{14})$ 表示先匹配[1-9]\d{16}[0-9x]如果没有匹配上就匹配[1-9]\d{14}
四、转义符 \

在正则表达式中,有很多有特殊意义的是元字符,比如\n和\s等,如果要在正则中匹配正常的"\n"而不是"换行符"就需要对""进行转义,变成’\’。

在python中,无论是正则表达式,还是待匹配的内容,都是以字符串的形式出现的,在字符串中\也有特殊的含义,本身还需要转义。所以如果匹配一次"\n",字符串中要写成’\n’,那么正则里就要写成"\\n",这样就太麻烦了。这个时候我们就用到了r’\n’这个概念,此时的正则是r’\n’就可以了。

正则 待匹配字符 匹配结果 说明
\n \n False 因为在正则表达式中\是有特殊意义的字符,所以要匹配\n本身,用表达式\n无法匹配
\\n \n True 转义\之后变成\,即可匹配
‘\\\\n’ ‘\\n’ True 如果在python中,字符串中的’‘也需要转义,所以每一个字符串’'又需要转义一次
r’\\n’ r’\n’ True 在字符串之前加r,让整个字符串不转义
五、贪婪匹配

贪婪匹配:在满足匹配时,匹配尽可能长的字符串,默认情况下,采用贪婪匹配

正则 待匹配字符 匹配结果 说明
<.*>

你可能感兴趣的:(python)