1. 寫一個(gè)正則表達(dá)式判斷一個(gè)字符串是否是ip地址
規(guī)則:一個(gè)ip地址由4個(gè)數(shù)字組成照激,每個(gè)數(shù)字之間用.連接另假。每個(gè)數(shù)字的大小是0-255
255.189.10.37 正確
256.189.89.9 錯(cuò)誤
"""
0-9:\d
10-99:[1-9]\d
100-199:1\d{2}
200-249:2[0-4]\d
250--255:25[0-5]
"""
IP_address=input('請(qǐng)輸入IP地址:')
re_str=r'((\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]).){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])'
result=re.fullmatch(re_str,IP_address)
if result:
print('IP地址正確<⒆贰8俚丁!')
else:
print('IP地址錯(cuò)誤>邸H蕖!')
2. 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
str1 = 'hello90abc 78sjh12.5'
re_str = r'[1-9]\d*[.]?\d*'
result = re.findall(re_str, str1)
sum1 = 0
for num in result:
sum1 += float(num)
print(sum1) #180.5
3. 驗(yàn)證輸入的內(nèi)容只能是漢字
chinese=input('請(qǐng)輸入內(nèi)容:')
re_str=r'[\u4e00-\u9fa5]'
result=re.fullmatch(re_str,chinese)
if result:
print('是漢字U琢U人!')
else:
print('不是漢字W匣省N堪病!')
4. 電話號(hào)碼的驗(yàn)證
"""
13\d
15[0-3] 15[5-9]
17[6-8]
18[0-9]
"""
re_str=r'1(3\d|5[0-35-9]|7[6-8]|8[0-9])\d{8}'
tel='15288446770'
print(re.fullmatch(re_str,tel))
5. 簡(jiǎn)單的身份證號(hào)的驗(yàn)證
"""
前6位是數(shù)字:\d{6}
年 1900-1999:19[0-9]\d
2000-2009: 20[0-9]\d
2010-2018: 201[0-8]
月01-09: 0[1-9]
10-12 : 1[0-2]
日01-09: 0[1-9]
10-29: [12]\d
30-31: 3[01]
后四位
有三位是數(shù)字\d{3}
最后一位可能是數(shù)字也可能是x
\d|x
"""
re_str=r'\d{6}(19[0-9]\d|20[0-9]\d|201[0-8])(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}(\d|x)'
number='530324199807131530'
print(re.fullmatch(re_str,number))
二聪铺、不定項(xiàng)選擇題
1. 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括(a bd )
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d”
D. “[(]?\d[)-]\d*”
2. 能夠完全匹配字符串“c:\rapidminer\lib\plugs”的正則表達(dá)式包括( bc )
A. “c:\rapidminer\lib\plugs”
B. “c:\rapidminer\lib\plugs”
C. “(?i)C:\RapidMiner\Lib\Plugs” ?i:將后面的內(nèi)容的大寫變成小寫
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:?jiǎn)涡衅ヅ?/p>
3. 能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括(a )
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á)式包括(b )
:\1就是重復(fù)前面第一個(gè)()/組合里面的內(nèi)容
:\2就是重復(fù)前面第二個(gè)()/組合里面的內(nèi)容
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”的正則表達(dá)式包括( ac )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”