利用正则表达式完成下面的操作:
一、不定项选择题
-
能够完全匹配字符串"(010)-62661617"和字符串"01062661617"的正则表达式包括(A D)
A.
r"\(?\d{3}\)?-?\d{8}"
B.r"[0-9()-]+"
C.r"[0-9(-)]*\d*"
D.r"[(]?\d*[)-]*\d*"
-
能够完全匹配字符串"back"和"back-end"的正则表达式包括( B)
A.r'\w{4}-\w{3}|\w{4}'
B.r'\w{4}|\w{4}-\w{3}'
C.r'\S+-\S+|\S+'
D.r'\w*\b-\b\w*|\w*'
-
能够完全匹配字符串"go go"和"kitty kitty",但不能完全匹配“go kitty”的正则表达式包括()
A.r '\b(\w+)\b\s+\1\b'
B.r'\w{2,5}\s*\1'
C.r'(\S+) \s+\1'
D.r'(\S{2,5})\s{1,}\1'
-
能够在字符串中匹配"aab",而不能匹配"aaab"和"aaaab"的正则表达式包括(B )
A.r"a*?b"
B.r"a{,2}b"
C.r"aa??b"
D.r"aaa??b"
二、编程题
1.用户名匹配
要求: 1.用户名只能包含数字 字母 下划线
2.不能以数字开头
3.⻓度在 6 到 16 位范围内
from re import fullmatch
def user_name(x):
return fullmatch(r'\D\w{5,15}', x)
print(user_name('z8_fdd512'))
- 密码匹配
要求: 1.不能包含!@#¥%^&*这些特殊符号
2.必须以字母开头
3.⻓度在 6 到 12 位范围内
result=fullmatch(r'(?i)[a-z][^!@#¥%^&*]{5,11}', 'A1519562')
print(result)
- ipv4 格式的 ip 地址匹配
提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
result = fullmatch(r'[0-9]{3}.[0-9]{3}.[0-9]{3}.[0-9]{3}', '255.255.255.198')
print(result)
- 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
result = findall(r'\d+\.\d+|-?\d+|\+?\d+', 'adr23f1w-3w+5gw2.3')
print(result, type(result))
sum1 = 0
for i in result:
a = float(i)
sum1 += a
print(sum1)
-
验证输入内容只能是汉字
result=fullmatch(r'[\u4e00-\u9fa5]*','你好呀') print(result)
-
匹配整数或者小数(包括正数和负数)
result = fullmatch(r'(\+?|-?)(\d+\.\d+|\d+)', '-2.3') print(result)
-
验证输入用户名和QQ号是否有效并给出对应的提示信息
要求:
用户名必须由字母、数字或下划线构成且长度在6~20个字符之间
QQ号是5~12的数字且首位不能为0 -
拆分长字符串:将一首诗的中的每一句话分别取出来
poem = ‘窗前明月光,疑是地上霜。举头望明月,低头思故乡。’
def poem1(poem):
result = split(r'[, 。]', poem)[0:-1]
return result
print(poem1('窗前明月光,疑是地上霜。举头望明月,低头思故乡。'))
Day-19 正则表达式
一.类的继承
继承:让子类直接拥有父类所有的属性和方法
class 类名(父类1,父类2···)
super().init():调用当前类的父类的__init__方法
二.正则表达式
正则表达式是一种让复杂的字符串问题变得简单的一个工具
1.判断输入的内容是否是一个合法的手机号码
判断输入的内容是否是一个合法的手机号码
def is_tel2(tel_num: str):
return fullmatch(r'1[3-9]\d{9}', tel_num) != None
2.提取message中所有的数字: 28、15000、109
message = '小明今年28岁,月薪15000元;体重109斤, 每个月的生活费是3000元'
result = findall(r'(\d+)元', message)
三.匹配符号
1.re模块简介
re模块是python用来支持正则相关操作的系统模块
fullmatch(正则表达式, 字符串) - 判断正则表达式和指定的字符串是否完全匹配,不能匹配结果是None
2.匹配类符号
正则表达式是由各种各样的正则符号组合而成
1)普通符号 - 在正则中没有特殊功能和特殊意义的字符
普通字符在正则表达式中表示符号本身
2)特殊符号
a.‘.’ - 匹配一个任意字符(注意: 一个.只能匹配一个字符)
b.\d - 匹配任意一个数字字符
c.\s - 匹配任意一个空白字符(空白字符: 空格、\t、\n)
d.\D、\S
\D - 匹配任意一个非数字字符
\S - 匹配任意一个非空白字符
e.[字符集] - 匹配字符集中任意一个字符
案例:
情况一:全是普通字符; [xyz12] - 匹配x或者y或者z或者1或者1
情况二:包含\开头的匹配符号, 这个时候匹配符号的功能有效; [mn\d] == [mn0123456789]
情况三:减号在两个符号之间,表示谁到谁
[a-z] - 匹配任意一个小写字母
[A-Z] - 匹配任意一个大写字母
[a-zA-Z] - 匹配任意一个大写字母
[\u4e00-\u9fa5] - 匹配任意一个中文
[1-9]
四.匹配次数
用法:匹配符号匹配次数
1.*0次或者多次 (任意次数)
a*b - b前面有任意多个a
\d*b - b前面有任意多个数字
2. + - 1次或多次(至少1次)
3. ? - 0次或者1次
4. {}
{N} - N次
{M,N} - M到N次
{M,} - 至少M次
{,N} - 最多N次
五.贪婪和非贪婪
1. 贪婪和非贪婪
在匹配次数不确定的时候,匹配模式分为贪婪和非贪婪两种(默认是贪婪模式)
*、+、{M,N}、{M,}、{,N}、? - 贪婪
*?、+?、{M,N}?、{M,}?、{,N}?、?? - 非贪婪
注意:python中除了fullmatch以外都可能出现贪婪和非贪婪的问题
六.分组和分支
1.分组 - ()
应用场景1:将正则表达式中的部分用()括起来作为一个整体进行相关操作
应用场景2: 重复 - 可以在有分组的正则表达式中通过’\N’来重复它前面第N个分组匹配到的内容
应用场景3:捕获 - 使用findall的时候,如果正则表达式中有分组,返回数据的时候只返回分组中匹配到的内容
2.分支 - |
正则1 | 正则2 - 正则1和正则2中只要有一个能匹配成功就匹配成功
七.其他
1.转义符号 - 在本身具备特殊功能或者特殊意义的符号前加\,让其功能或者意义消失,变成一个普通符号
让符号功能消失的另外一个方法:单独一个符号有特殊功能时候可以将这个符号方法[]中让其功能消失
2.忽略大小写: 在正则的最前面加 (?!)
3.单行匹配和多行匹配:
多行匹配,匹配的时候.不能和’\n’匹配 (默认) - (?m)
单行匹配,匹配的时候.可以和’\n’匹配 - 在正则的最前面加 (?s)
4.re模块中的常用函数
1)(常用)fullmatch(正则, 字符串) - 判断整个字符串是否符合正则描述的规则(完全匹配),匹配成功返回匹配对象,匹配失败返回None
2)match(正则, 字符串) - 匹配字符串开头,匹配成功返回匹配对象,匹配失败返回None
3)search(正则, 字符串) - 获取字符串中第一个满足正则的子串,找到了返回子串对应的匹配对象,找不到返回None
4)(常用)findall(正则, 字符串) - 获取字符串中所有满足正则的子串,返回一个列表,列表中的元素是字符串或者元组
5)finditer(正则, 字符串) - 获取字符串中所有满足正则的子串,返回一个迭代器,迭代器中的元素是子串对应的匹配对象
6)(常用)split(正则, 字符串) - 将字符串中所有满足正则的子串作为切割点,对字符串进行切割,返回一个列表,列表中的元素是字符串
7) (常用)sub(正则, 字符串1, 字符串2) - 将字符串2中所有满足正则的子串都替换成字符串1,返回替换后的新字符串