- 寫(xiě)一個(gè)正則表達(dá)式判斷一個(gè)字符串是否是ip地址
規(guī)則:一個(gè)ip地址由4個(gè)數(shù)字組成,每個(gè)數(shù)字之間用.連接。每個(gè)數(shù)字的大小是0-255
255.189.10.37 正確
56.189.89.9 錯(cuò)誤
from re import fullmatch
ip_str = r'([01]?[0-9]?\d|2([0-4]?\d|5[0-5]))(\.([01]?[0-9]?\d|2([0-4]?\d|5[0-5]))){3}'
str = '211.168.17.9'
print(fullmatch(ip_str, str))
- 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
from re import findall
str1 = 'hello90abc 78sjh12.5'
n = r'[+-]?[1-9]\d*\.?\d*|[+-]?0\.\d*'
sum = 0
fin = findall(n, str1)
sum += float(fin[0])
print('結(jié)果是',sum,end='')
for i in fin[1:]:
print('+'+i,end='')
sum += float(i)
print('=',sum)
- 驗(yàn)證輸入的內(nèi)容只能是漢字
import re
chinese = input('請(qǐng)輸入您要驗(yàn)證的漢字:')
verification = r'[\u4E00-\u9FA5]+'
if re.fullmatch(verification, chinese):
print('輸入合格杨刨!')
else:
print('輸入錯(cuò)誤锣夹!')
- 電話號(hào)碼的驗(yàn)證
import re
tel_str = r'^[1-9][0-9]{10}$'
str2 = input('輸入電話號(hào)碼:')
if re.fullmatch(tel_str, str2):
print('輸入合格浪南!')
else:
print('輸入不合格')
- 簡(jiǎn)單的身份證號(hào)的驗(yàn)證
import re
id = input('請(qǐng)輸入身份證號(hào)碼進(jìn)行驗(yàn)證:')
verification = r'^([1-9]\d{5}[12]\d{3}(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])\d{3}[0-9xX])$'
if re.fullmatch(verification, id):
print('驗(yàn)證成功父款!')
else:
print('輸入不合格!')
二斩松、不定項(xiàng)選擇題
- 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括( abd )
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d”
D. “[(]?\d[)-]\d*”
能夠完全匹配字符串“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)容的大寫(xiě)變成小寫(xiě)
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:?jiǎn)涡衅ヅ?/p>能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括( acd)
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*”能夠完全匹配字符串“go go”和“kitty kitty”伶唯,但不能完全匹配“go kitty”的正則表達(dá)式包括( ad)
:\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”能夠在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正則表達(dá)式包括( bc )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”