1.写一个正则表达式判断一个字符串是否是ip地址
规则:一个ip地址由4个数字组成,每个数字之间用.连接。每个数字的大小是0-255
255.189.10.37 正确
256.189.89.9 错误
代码示例
from re import fullmatch
re_str = r'(2[0-5]{2}|[0-1]{,1}\d{,2})\.(2[0-5]{2}|[0-1]{,1}\d{,2})\.' \
r'(2[0-5]{2}|[0-1]{,1}\d{,2})\.(2[0-5]{2}|[0-1]{,1}\d{,2})'
ip1 = '255.189.10.37'
ip2 = '256.189.89.9'
print(fullmatch(re_str, ip1))
print(fullmatch(re_str, ip2))
运行结果
<_sre.SRE_Match object; span=(0, 13), match='255.189.10.37'>
None
2.计算一个字符串中所有的数字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 结果是90+78+12.5 = 180.5
代码示例
import re
re_str = r'\d+\.{,1}\d*'
str1 = 'hello90abc 78sjh12.5'
list1 = re.findall(re_str, str1)
sum1 = 0
for num in list1:
sum1 += float(num)
print(sum1)
运行结果
180.5
3.验证输入的内容只能是汉字
代码示例
from re import fullmatch
re_str = r'[\u4E00-\u9fa5]+'
str1 = '啊科技时代看'
print(fullmatch(re_str, str1))
运行结果
<_sre.SRE_Match object; span=(0, 6), match='啊科技时代看'>
4.电话号码的验证
区号:前面一个0,后面跟2-3位数字 : 0\d{2,3}
电话号码:7-8位数字: \d{7,8}
分机号:一般都是3位数字: \d{3,}
这样连接起来就是验证电话的正则表达式了:^((0\d{2,3})-)(\d{7,8})(-(\d{3,}))?$
手机号码前面以1开头,第二位现在是3或者5,后面是9位数字,则:^1[35]\d{9}$
验证:(^(\d{2,4}[-_-—]?)?\d{3,8}([-_-—]?\d{3,8})?([-_-—]?\d{1,7})?$)|(^0?1[35]\d{9}$)
该表达式可以验证那些不小心把连接符“-”写出“-”的或者下划线“_”的等等。
代码示例
from re import fullmatch
re_str = r'(^(\d{2,4}[-_-—]?)?\d{3,8}([-_-—]?\d{3,8})?([-_-—]?\d{1,7})?$)|(^0?1[35]\d{9}$)'
print(fullmatch(re_str, '18869713179'))
print(fullmatch(re_str, '08869713179'))
运行结果
<_sre.SRE_Match object; span=(0, 11), match='18869713179'>
<_sre.SRE_Match object; span=(0, 11), match='08869713179'>
5.简单的身份证号的验证
身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。
排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
地址码验证:地址码长6位以数字1-9开头后5位为0-9的数字所以地址码验证正则表达式为:^[1-9]\d{5}
年份码验证:年份码长4位现在人多为18,19,20年的,
所以以数字18,19或20开头剩余两位为0-9的数字所以年份码的正则表达式为:(18|19|20)\d{2}
月份码验证:月份码长2位第一位数字为0,第二位数字为1-9或者第一位数字为1,
第二位数字为0-2所以月份码正则表达式为:((0[1-9])|(1[0-2]))
日期码验证:日期码长2位第一位数字为0-2,第二位数字为1-9或者是10,20,30,31
日期码正则表达式为: (([0-2][1-9])|10|20|30|31)
顺序码验证:顺序码长3位顺序码是数字顺序码的正则表达式为:\d{3}
校验码验证:校验码长1位可以是数字,字母x或字母X校验码的正则表达式为:[0-9xX]
代码示例
re_str = r'^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2]))(([0-2][1-9])|10|20|30|31)\d{3}[0-9xX]$'
print(fullmatch(re_str, '532128199709200316'))
运行结果
<_sre.SRE_Match object; span=(0, 18), match='532128199709200316'>
选择题
1. 能够完全匹配字符串“(010)-62661617”和字符串“01062661617”的正则表达式包括(A、B、D)
A. “\(?\d{3}\)?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]*\d*”
D. “[(]?\d*[)-]*\d*”
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:单行匹配
3.能够完全匹配字符串“back”和“back-end”的正则表达式包括(A、B、C、D)
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”的正则表达式包括(A、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、C )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”