- 寫一個(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ò)誤
re_str = r'^(25[0-5].|2[0-4]\d.|1\d\d.|\d\d.|\d.){3}(25[0-5]|2[0-4]\d|1\d\d|\d\d|\d)$'
ip = '253.34.4.53'
print(re.fullmatch(re_str,ip))
- 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
def sum_d(str1):
re_str = r'[^a-z]+'
result1 = re.findall(re_str,str1)
print(result1)
sum1=0
for item in result1:
item = float(item)
sum1+=item
return sum1
str1='hello90abc 78sjh12.5'
print(sum_d(str1))
- 驗(yàn)證輸入的內(nèi)容只能是漢字
def if_chinese(str1):
re_str = r'[\u4E00-\u9fa5]+'
while True:
str1 = input('請輸入內(nèi)容:')
result = re.fullmatch(re_str,str1)
if not result:
print('輸入內(nèi)容只能是漢字')
continue
else:
print('驗(yàn)證通過')
break
if_chinese(str1)
- 電話號(hào)碼的驗(yàn)證
def istel():
re_str = r'1[3-9]\d{9}'
while True:
str2 = input('請輸入11位手機(jī)號(hào)碼:')
result = re.fullmatch(re_str,str2)
if not result:
print('請輸入正確手機(jī)號(hào)')
continue
else:
print('驗(yàn)證成功')
istel()
- 簡單的身份證號(hào)的驗(yàn)證
#未寫完
def isid():
re_str = r'\d{6}(1|2)\d{3}(10|11|12|[1-9])([0-2]\d|3[0-1])\d{3}([0-9]|X'
str3 = input('請輸入身份證號(hào)碼:')
result = re.fullmatch(re_str, str3)
check()#驗(yàn)證最后一位驗(yàn)證碼函數(shù)是否合法
if not:
print('請輸入正確號(hào)碼')
else:
pass
二、不定項(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á)式包括(B C )
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”的正則表達(dá)式包括(A CD )
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á)式包括(A D)
:\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”