1. 写一个正则表达式判断一个字符串是否是ip地址
规则:一个ip地址由4个数字组成,每个数字之间用.连接。每个数字的大小是0-255
255.189.10.37 正确
256.189.89.9 错误
from re import *
def test_ip(ip: str):
"""判断一个字符串是否是ip地址
(2(5[0-5]|[0-4]\d)): 250-255|200-249
([1]\d{1,2})|([1-9]\d)|\d : 100-199|10-99|0-9
"""
is_ip = compile(
r'((2(5[0-5]|[0-4]\d))|([1]\d{1,2})|([1-9]\d)|\d)(\.((2(5[0-5]|[0-4]\d))|([1]\d{1,2})|([1-9]\d)|\d)){3}')
if is_ip.fullmatch(ip):
return True
return False
print(test_ip('255.189.10.37')) # True
print(test_ip('256.189.89.9')) # False
2. 计算一个字符串中所有的数字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 结果是90+78+12.5 = 180.5
def sum_digit(str1: str):
"""计算一个字符串中所有的数字的和"""
# [-+]?([1-9]\d*|0)(\.\d+)?
is_digit = compile(r'[-+]?([1-9]\d*|0)(\.\d+)?')
return sum(float(num.group()) for num in is_digit.finditer(str1))
3. 验证输入的内容只能是汉字
def verify_chinese():
"""验证输入的内容只能是汉字"""
is_chinese = compile(r'[\u4e00-\u9fa5]+')
while True:
str1 = input("请输入汉字:")
if is_chinese.fullmatch(str1):
return str1
else:
print("输入错误,请输入汉字")
4. 电话号码的验证
def tel_num_verify(tel: str):
"""
正则:手机号(精确)2019.1
移动:134 135 136 137 138 139 147(上网卡) 150 151 152 157 158 159 165
172 178(4G) 182 183 184 187 188 1440(物联网) 148(物联网) 198
联通:130 131 132 145(上网卡) 155 156 171 175 176(4G) 185 186 146(物联网) 166
电信:133 149 153 173 174 177(4G) 180 181 189 191 全球星:1349 1410(物联网) 199
虚拟运营商:170 171
"""
is_tel = compile(r"[1](([3][0-9])|([4][5-9])|([5][0-3,5-9])|([6][5,6])|([7][0-8])|([8][0-9])|([9][1,8,9]))[0-9]{8}")
# is_tel = compile(r'1[3-9]\d{9}')
if is_tel.fullmatch(tel):
return True
return False
print(tel_num_verify('18810998988')) # True
print(tel_num_verify('14110998988')) # False
5. 验证输入用户名和QQ号是否有效并给出对应的提示信息
要求:
用户名必须由字母、数字或下划线构成且长度在6~20个字符之间
QQ号是5~12的数字且首位不能为0
def valid_qq(user_name: str, qq_num: str):
"""验证输入用户名和QQ号是否有效并给出对应的提示信息"""
test_user = compile(r'[a-zA-Z\d_]{6,20}')
if not test_user.fullmatch(user_name):
print('用户名无效')
return False
test_qq = compile(r'[^0]\d{4,11}')
if not test_qq.fullmatch(qq_num):
print('QQ号码无效')
return False
print('用户名与QQ号码合法!')
return True
6. 拆分长字符串:将一首诗的中的每一句话分别取出来
poem = '窗前明月光,疑是地上霜。举头望明月,低头思故乡。'
def get_substr(poem: str):
"""将一首诗的中的每一句话分别取出来"""
is_sentence = compile(r'([\u4e00-\u9fa5]{5,7})(?:[,。]?)')
return is_sentence.findall(poem)
二、不定项选择题
1. 能够完全匹配字符串“(010)-62661617”和字符串“01062661617”的正则表达式包括( A, B ,D)
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d”
D. “[(]?\d[)-]\d*”
C(
-
在两个字符中间,没有转义)
2. 能够完全匹配字符串“c:\rapidminer\lib\plugs”的正则表达式包括( B,C )
A. “c:\rapidminer\lib\plugs”
B. “c:\rapidminer\lib\plugs”
C. “(?i)C:\RapidMiner\Lib\Plugs” ?i:将后面的内容的大写变成小写
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:单行匹配
A(
\
没有转义)
D(字母有大写)
3. 能够完全匹配字符串“back”和“back-end”的正则表达式包括(A,B,C,D )
A. “\w{4}-\w{3}|\w{4}”
B. “\w{4}|\w{4}-\w{3}”
C. “\S+-\S+|\S+”
D. “\w\b-\b\w|\w*”
4. 能够完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正则表达式包括(A, D)
A. “\b(\w+)\b\s+\1\b”
B. “\w{2,5}\s*\1”
C. “(\S+) \s+\1”
D. “(\S{2,5})\s{1,}\1”
B(没有捕获组,不能使用反向引用)
C((\S+)
后面多了一个空格符)
5. 能够在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正则表达式包括(B,C )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”
A(非贪婪模式匹配 任意个a后加b)
D(非贪婪模式匹配 aab aaab)