- 寫一個正則表達式判斷一個字符串是否是ip地址
規(guī)則:一個ip地址由4個數(shù)字組成差导,每個數(shù)字之間用.連接。每個數(shù)字的大小是0-255
255.189.10.37 正確
256.189.89.9 錯誤
# 0-9 :\d
# 10-99 :[1-9]\d
# 100-199 :1[0-9]{2}
# 200-249 :2[0-4][0-9]
# 250-255 :25[0-5]
in_put = input('IP:')
re_str = r'(\d|[1-9]\d|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.\d|[1-9]\d|1[0-9]{2}|2[0-4][0-9]|25[0-5]'
result = fullmatch(re_str,in_put)
if result:
print('ip地址正確')
else:
print('ip地址不正確')
- 計算一個字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
str1='hello90abc 78sjh12.5'
re_str=r'\d+[.]\d+|\d+'
search1=search(re_str,str1)
sum=float(search1.group())
while True:
str1=str1[search1.end():]
search1=search(re_str,str1)
if not search1:
break
sum+=float(search1.group())
print(sum)
- 驗證輸入的內(nèi)容只能是漢字
str1 = input('請輸入漢字:')
re_str = r'[一-禧]+'
result = fullmatch(re_str, str1)
print(result)
if result:
print('全是漢字')
else:
print('不全是漢字')
- 電話號碼的驗證
in_put = input('電話號碼:')
re_str = r'1[34578]\d{9}'
result = fullmatch(re_str,in_put)
if result:
print('電話號碼正確')
else:
print('電話號碼不正確')
- 簡單的身份證號的驗證
# 前6位 :\d{6}
# 年 :1900--2018
# 1900-1999 :19\d\d
# 2000-2009 :200\d
# 2010-2018 :201\d
# 月 01-12
# 01-09 :0[1-9]
# 10-12 :1[0-2]
# 日 01--31
# 01-09 :0[1-9]
# 10-29 :[12]\d
# 30-31 :3[01]
# 三位數(shù)字 :\d{3}
# 數(shù)字/x: [\dx]
re_str = r'\d{6}(19\d\d|200\d|201\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])\d{3}[\dx]'
sesult = fullmatch(re_str,in_put)
if result:
print('身份證號碼正確')
else:
print('身份證號碼不正確')
二、不定項選擇題
- 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達式包括( ABD )
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d”
D. “[(]?\d[)-]\d*”
能夠完全匹配字符串“c:\rapidminer\lib\plugs”的正則表達式包括( 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:單行匹配能夠完全匹配字符串“back”和“back-end”的正則表達式包括( ABCD )
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”的正則表達式包括(AD )
:\1就是重復(fù)前面第一個()/組合里面的內(nèi)容
:\2就是重復(fù)前面第二個()/組合里面的內(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”的正則表達式包括( BC )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”