作业:
利用正则表达式完成下面的操作:
一、不定项选择题
- 能够完全匹配字符串
"(010)-62661617"
和字符串"01062661617"
的正则表达式包括( ABD)
A.r"\(?\d{3}\)?-?\d{8}"
B. r"[0-9()-]+"
C.r"[0-9(-)]*\d*"
D.r"[(]?\d*[)-]*\d*"
- 能够完全匹配字符串“c:\rapidminer\lib\plugs”的正则表达式包括( BC)
A. “c:\rapidminer\lib\plugs”
B. “c:\rapidminer\lib\plugs”
C. “(?i)C:\RapidMiner\Lib\Plugs” ?i:将后面的内容的大写变成小写
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:单行匹配 - 能够完全匹配字符串“back”和“back-end”的正则表达式包括( AB)
A. “\w{4}-\w{3}|\w{4}”
B. “\w{4}|\w{4}-\w{3}”
C. “\S±\S+|\S+”
D. “\w*\b-\b\w*|\w*” - 能够完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正则表达式包括(A )
A. “\b(\w+)\b\s+\1\b”
B. “\w{2,5}\s*\1”
C. “(\S+) \s+\1”
D. “(\S{2,5})\s{1,}\1” - 能够在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正则表达式包括( B)
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”
二、编程题
1.用户名匹配
要求: 1.用户名只能包含数字 字母 下划线
2.不能以数字开头
3.⻓度在 6 到 16 位范围内
def input_username():
while 1:
name=input('请输入用户姓名:')
re_str=r'(?i)[a-z_]\w{5,15}'
result=fullmatch(re_str,name)
if result:
print("姓名合法!")
return name
else:
print('姓名不合法')
结果:
- 密码匹配
要求: 1.不能包含!@#¥%^&*这些特殊符号
2.必须以字母开头
3.⻓度在 6 到 12 位范围内
def input_code():
while 1:
code=input('请设置密码:')
re_str=r'(?i)[a-z]\w{5,11}'
result=fullmatch(re_str,code)
if result:
print("密码合法!")
return code
else:
print('密码不合法!')
input_code()
结果:
- ipv4 格式的 ip 地址匹配
提示: IP地址的范围是 0.0.0.0 - 255.255.255.255
def input_ipv4():
while 1:
ip=input('请输入域名:')
re_str=r'([0-2]?[0-5]?[0-5]?\.?){4}'
result=fullmatch(re_str,ip)
if result:
print("域名合法!")
return ip
else:
print('域名不合法!')
input_ipv4()
结果:
- 提取用户输入数据中的数值 (数值包括正负数 还包括整数和小数在内) 并求和
例如:“-3.14good87nice19bye” =====> -3.14 + 87 + 19 = 102.86
def sum_str(str1:str):
result = findall(r'-?\d*\.\d*|-?\d*', str1)
return reduce(lambda x, item1: x + item1, [float(i) for i in result if i != ''], 0)
- 验证输入内容只能是汉字
def must_CH(ch:str):
if fullmatch(r'[\u4e00-\u9fa5]*', ch):
return 1
return 0
- 匹配整数或者小数(包括正数和负数)
def num1(num:str):
if fullmatch(r'-??\d*\.\d*|\d', num):
-
验证输入用户名和QQ号是否有效并给出对应的提示信息
要求:
用户名必须由字母、数字或下划线构成且长度在6~20个字符之间
QQ号是5~12的数字且首位不能为0
def qq_name(qqnum:str, uname:str):
if fullmatch(r'[1-9]\d{4,11}', qqnum) and fullmatch(r'\w{6,20}', uname):
return 1
return 0
-
拆分长字符串:将一首诗的中的每一句话分别取出来
poem = ‘窗前明月光,疑是地上霜。举头望明月,低头思故乡。’
def poetry_out(poem: str):
result = findall(r'[\u4e00-\u9fa5]*,|[\u4e00-\u9fa5]*。', poem)
return result