import re
# 1. 写一个正则表达式判断一个字符串是否是ip地址
# 规则:一个ip地址由4个数字组成,每个数字之间用.连接。每个数字的大小是0-255
# 255.189.10.37 正确
# 256.189.89.9 错误
# \1{3}
ip_re = r'((1?\d\d?|2[0-4]\d|25[0-5])\.){3}(1?\d\d?|2[0-4]\d|25[0-5])'
result =re.fullmatch(ip_re, '1.0.0.0')
print(result)
# 2. 计算一个字符串中所有的数字的和
# 例如:字符串是:‘hello90abc 78sjh12.5’ 结果是90+78+12.5 = 180.5
sum_re = r'\d+\.*\d*'
result = re.findall(sum_re, 'hello90abc 78sjh12.5')
sum = 0
for item in result:
sum += float(item)
print(sum)
#3. 验证输入的内容只能是汉字
chinese_re = r'[一-龥]*'
result = re.fullmatch(chinese_re, '123')
print(result)
result = re.fullmatch(chinese_re, '张俊吉')
print(result)
#4. 电话号码的验证
tel_re = r'1[35679]\d{9}'
result = re.fullmatch(tel_re, '15208364324')
print(result)
result = re.fullmatch(tel_re, '11208364324')
print(result)
#5. 简单的身份证号的验证
id_re = r'[1-9]\d{5}[12]\d{3}( (0[13578]0[1-9])|(0[13578][12][0-9])|(0[13578]3[01])|(0[2]0[1-9])|(0[2][12][0-9])|(0[469]0[1-9])|(0[469][12][0-9])|(0[469]30)|(11[0][1-9])|(11[12][0-9])|(11[3]0)|(12[0][1-9])|(12[12][0-9])|(11[3][12]))\d{3}[0-9x]'
result = re.fullmatch(id_re, '51012419960430019x')
print(result)
二、不定项选择题
1. 能够完全匹配字符串“(010)-62661617”和字符串“01062661617”的正则表达式包括( A )
A. “\(?\d{3}\)?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]*\d*”
D. “[(]?\d*[)-]*\d*”
2. 能够完全匹配字符串“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:单行匹配
3. 能够完全匹配字符串“back”和“back-end”的正则表达式包括(A B )
A. “\w{4}-\w{3}|\w{4}” match->back,back-end fullmatch-> back,back-end
B. “\w{4}|\w{4}-\w{3}” match-> back, back fullmatch-> back,back-end
C. “\S+-\S+|\S+”
D. “\w*\b-\b\w*|\w*”
4. 能够完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正则表达式包括( D)
:\1就是重复前面第一个()/组合里面的内容
:\2就是重复前面第二个()/组合里面的内容
A. “\b(\w+)\b\s+\1\b”
B. “\w{2,5}\s*\1”
C. “(\S+) \s+\1”
D. “(\S{2,5})\s{1,}\1”
5. 能够在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正则表达式包括( B )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”