-
能够完全匹配字符串"(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-bw*|w*' -
能够完全匹配字符串"go go"和"kitty kitty",但不能完全匹配“go kitty”的正则表达式包括(AD)
A.r'b(w+)bs+1b'
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.|1d{1,2}.|2([0-4]d|5[0-5]).){3}([1-9]?d|1d{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]



