import re
from re import fullmatch,search
- 寫一個(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ò)誤
寫一個(gè)正則表達(dá)式旦签,用來(lái)判斷一個(gè)字符是否是IP地址
result = r'((25[0-5]|2[0-4]\d|1\d{2}|[1-9]\d|\d)\.){3}(25[0-5]|2[0-4]\d|1\d{2}|[1-9]\d|\d)'
ip = re.fullmatch(result, '255.78.78.10')
if ip:
print('是IP地址')
else:
print('不是IP地址')
- 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
re_str = r'[+-]?\d+\.\d+|[+-]?\d+'
str1 = 'hello90abc 78sjh12.5'
str2 = re.search(re_str, str1)
count = 0
while str2:
count += float(str2.group())
end = str2.end()
str1 = str1[end:]
str2 = re.search(re_str, str1)
print(count)
- 驗(yàn)證輸入的內(nèi)容只能是漢字
#re_str = r'[^A-Za-z\s\s]'
#result = fullmatch(re_str,'%')
#print(result)
匹配漢字文字:
[\u4e00-\u9fa5]
# 匹配非漢字字符:
[^\u4e00-\u9fa5]
# 匹配雙字節(jié)字符(漢字而咆、中文標(biāo)點(diǎn)符號(hào)等):
[^\x00-\xff]
str1 = input('請(qǐng)輸入漢字:')
# str1 = r'[一-禧]+'
search = re.search('[^\u4e00-\u9fa5]+', str1)
if search:
print('不全是漢字')
else:
print('全是漢字')
- 電話號(hào)碼的驗(yàn)證
tel = '17640171329'
# re_str = r'1[0-9]{10}'
re_str = r'1\d{2,10}'
phone = fullmatch(re_str,tel)
if not phone:
print('不是電話號(hào)碼')
else:
print('是電話號(hào)碼')
- 簡(jiǎn)單的身份證號(hào)的驗(yàn)證
re_str = r're_str = r'\d{6}(19\d{2}|200\d|201[0-8])(0[1-9]|1[0-2])(0[1-9]|[1-2]\d|3[01])\d{3}[\dxX]''
ID = fullmatch(re_str,'513723199609301258')
if not phone:
print('不是身份證號(hào)碼')
else:
print('是身份證號(hào)碼')
二摇肌、不定項(xiàng)選擇題
- 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括(A,B,D)
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:?jiǎn)涡衅ヅ?/p>能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括( A,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*”能夠完全匹配字符串“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á)式包括( B,C )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”