上一篇:Re.Match类的介绍 | 手把手教你入门Python之八十六
下一篇:正则表达式模式 | 手把手教你入门Python之八十八
本文来自于千锋教育在阿里云开发者社区学习中心上线课程《Python入门2020最新大课》,主讲人姜伟。
正则修饰符的使用
示例:
import re
# 正则修饰符是对正则表达式进行修饰
# . 表示除了换行以外的任意字符
# x = re.search(r'm.*a', 'sdfmo\nejoasd1')
# print(x) # None
# re.S:让点 . 匹配换行
x = re.search(r'm.*a', 'sdfmo\nejoasd1', re.S)
print(x)
# re.I 忽略大小写
y = re.search(r'x', 'good Xyz', re.I)
print(y) # None
# \w:表示的是字母数字和_ +:出现一次以上 $: 以指定的内容结尾
# re.M: 让 $ 能够匹配到换行
z = re.findall(r'\w+$', 'i am boy\n you are girl\n he is man', re.M)
print(z) # ['boy', 'girl', 'man']
print(re.search(r'L','hello')) # None
print(re.search(r'L', 'hello', re.I)) # 不区分⼤⼩写<re.Match object; span=(2, 3),
match='l'>
# \w+$ 表示匹配以⼀个或者多个字⺟结尾
# re.M 可以进⾏多⾏匹配,每个换⾏都认为是⼀个结尾
print(re.findall(r'\w+$','i am boy\n you are girl\n he is man',re.M)) # ['boy', 'g
irl', 'man']
# 不实⽤re.M修饰符,只会匹配到最后的 man
print(re.findall(r'\w+$','i am boy\n you are girl\n he is man')) # ['man']
print(re.search(r'.','\n')) # None . 匹配除了 \n 以外的所有字符
print(re.search(r'.','\n',re.S)) # '\n' 匹配到了 \n
正则匹配规则
1.数字和字母都表示它本身,⼀个正则表达式模式中的字⺟和数字匹配同样的字符串。
re.search(r'H','Hello') # 这⾥的 H 表示的就是字⺟ H ⾃身,代表有特殊含义
2.多数字⺟和数字前加⼀个反斜杠 时会拥有不同的含义。
ret = re.search(r'\d','he12ms90') # 这⾥的 \d 表示的是匹配数字
3.标点符号只有被转义时才匹配⾃身,否则它们表示特殊的含义。
ret = re.search(r'.','hello') # 这⾥的 . 表示的是匹配任意字符
ret = re.search(r'\.','he.llo') # 这⾥的 \. 进⾏了转义,才表示标点符号⾃身。
4.反斜杠本身需要使⽤反斜杠转义。由于正则表达式通常都包含反斜杠,所以你最好使⽤原始字符串来表示它们。模式元素(如 r'\t'
,等价于 \\t
)匹配相应的特殊字符
示例:
import re
# 字母x表示它本身
re.search(r'x', 'hello xyz')
re.search(r'5', '23r49534')
print(re.search(r'd', 'good')) # 字母d是普通的字符
print(re.search(r'\d', 'good')) # \d 有特殊含义,不再表示字母 d
print(re.search(r'\d', 'wsdfk4sdfj1')) # <re.Match object; span=(5, 6), match='4'>
# re.search('+','1+2') # 不能直接使用,+ 有特殊含义
print(re.search(r'\+', '1+2'))