利用正则表达式完成下面的操作:
一、不定项选择题
-
能够完全匹配字符串"(010)-62661617"和字符串"01062661617"的正则表达式包括(ABD)
A.
r"\(?\d{3}\)?-?\d{8}"
B.r"[0-9()-]+"
C.r"[0-9(-)]*\d*"
D.r"[(]?\d*[)-]*\d*"
-
能够完全匹配字符串"back"和"back-end"的正则表达式包括(ABCD)
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”的正则表达式包括(AD)
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"的正则表达式包括(CB)
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 checking(text: str, regular: str):
if fullmatch(regular, text) != None:
return True
else:
return False
name=input('请输入用户名')
regular=r'[a-zA-Z_]\w{5,15}'
checking(name,regular)
- 密码匹配
要求: 1.不能包含!@#¥%^&*这些特殊符号
2.必须以字母开头
3.⻓度在 6 到 12 位范围内
password=input('请输入密码')
regular=r'(?i)[a-z][^!@#¥%^&*]{5,11}'
checking(password,regular)
- ipv4 格式的 ip 地址匹配
提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
ip='200.200.2.0'
regular=r'([1-9]?\d\.|1\d{1,2}\.|2([0-4]\d|5[0-5])\.){3}([1-9]?\d|1\d{1,2}|2([0-4]\d|5[0-5]))'
checking(ip,regular)
- 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
# 1
from re import findall
num = findall(r'(-?(\d+\.\d+|\d+))', str1)
num = [float(i[0]) for i in num]
sum1 = sum(num)
# 2)
def sum_up(text, key=lambda x: x):
list1 = []
for i in text:
list1.append(key(x=i))
return sum(list1)
num = findall(r'(-?(\d+\.\d+|\d+))', str1)
sum1 = sum_up(num,key=lambda x:float(x[0]))
# 3)
from functools import reduce
num = findall(r'(-?(\d+\.\d+|\d+))', str1)
sum1 = reduce(lambda x2,x1:float(x1[0])+x2,num,0)
- 验证输入内容只能是汉字
chinese_characters=input('请输入')
regular=r'[\u4e00-\u9fa5]+'
checking(chinese_characters,regular)
- 匹配整数或者小数(包括正数和负数)
number=input('请输入')
regular=r'[-+]?(0|[1-9]\d*)(\.\d+)?'
checking(number,regular)
-
验证输入用户名和QQ号是否有效并给出对应的提示信息
要求:
用户名必须由字母、数字或下划线构成且长度在6~20个字符之间
QQ号是5~12的数字且首位不能为0
name = input('请输入用户名(字母、数字或下划线构成且长度在6~20个字符之间)')
QQ = input('请输入QQ号(5~12的数字且首位不能为0)')
regular=r'\w{6,20}'
checking(name,regular)
regular=r'[1-9]\d{4,11}'
checking(QQ,regular)
-
拆分长字符串:将一首诗的中的每一句话分别取出来
poem = ‘窗前明月光,疑是地上霜。举头望明月,低头思故乡。’
from re import split
poen = '窗前明月光,疑是地上霜。举头望明月,低头思故乡。'
poen = split('[。,]', poen)[0:-1]