正则修饰符的使用 | 手把手教你入门Python之八十七

上一篇:Re.Match类的介绍 | 手把手教你入门Python之八十六
下一篇:正则表达式模式 | 手把手教你入门Python之八十八

本文来自于千锋教育在阿里云开发者社区学习中心上线课程《Python入门2020最新大课》,主讲人姜伟。

正则修饰符的使用

正则修饰符的使用 | 手把手教你入门Python之八十七
示例:

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'))

配套视频

上一篇:Android自定义View之圆形进度条总结


下一篇:如何保护工业物联网(IIoT)安全