- 寫一個(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ò)誤
from re import fullmatch
re_str = r'((\d|[1-9]\d|1\d{2}|2[0-5]{2})\.){3}(\d|[1-9]\d|1\d{2}|2[0-5]{2})'
print('正確' if fullmatch(re_str, '255.189.10.37') else '錯(cuò)誤')
- 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
re_str = r'\d+\.\d+|\d+'
list_result = findall(re_str, 'h3.el.3lo90abc 78sjh12.5')
sum1 = 0
print(list_result)
for x in list_result:
sum1 += float(x)
print('和:', sum1)
- 驗(yàn)證輸入的內(nèi)容只能是漢字
str1 = input('請輸入漢字:')
print('驗(yàn)證成功' if fullmatch(r'[\u4e00-\u9fa5]+', str1) else '驗(yàn)證失敗')
- 電話號(hào)碼的驗(yàn)證
str1 = input('請輸入電話號(hào)碼:')
print('驗(yàn)證成功' if fullmatch(r'1[3-9]\d{9}', str1) else '驗(yàn)證失敗')
- 驗(yàn)證輸入用戶名和QQ號(hào)是否有效并給出對應(yīng)的提示信息
要求:
用戶名必須由字母、數(shù)字或下劃線構(gòu)成且長度在6~20個(gè)字符之間
QQ號(hào)是5~12的數(shù)字且首位不能為0
str1 = input('請輸入用戶名:')
if 6 <= len(str1) <= 20:
if fullmatch(r'[a-zA-Z\d_]{6,20}', str1):
if not len(findall(r'\d', str1)):
print('用戶名缺少數(shù)字')
pass
elif not len(findall(r'_', str1)):
print('用戶名缺少下劃線')
elif not len(findall(r'[a-zA-Z]', str1)):
print('用戶名缺少字母')
else:
print('輸入正確')
else:
print('用戶名只能含有數(shù)字、字母、下劃線')
else:
print('用戶名長度不在6~20范圍內(nèi)')
str2 = input('請輸入QQ號(hào):')
if 5 <= len(str2) <= 12:
if fullmatch(r'\d{5,12}', str2):
if fullmatch(r'0\d{4,11}', str2):
print('QQ號(hào)首位不能為0')
else:
print('QQ號(hào)輸入正確')
else:
print('QQ號(hào)只能包含數(shù)字')
else:
print('QQ號(hào)長度不在5~12范圍內(nèi)')
- 拆分長字符串:將一首詩的中的每一句話分別取出來
poem = '窗前明月光,疑是地上霜。舉頭望明月,低頭思故鄉(xiāng)。'
for str1 in findall(r'[\u4e00-\u9fa5]+\,|[\u4e00-\u9fa5]+\。', poem):
print(str1)
二、不定項(xiàng)選擇題
- 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括( A, B )
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d”
D. “[(]?\d[)-]\d”
2.能夠完全匹配字符串“c:\rapidminer\lib\plugs”的正則表達(dá)式包括( 搞不懂 )
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:單行匹配
3.能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括(A,B,C,D )
A. “\w{4}-\w{3}|\w{4}”
B. “\w{4}|\w{4}-\w{3}”
C. “\S+-\S+|\S+”
D. “\w\b-\b\w|\w”
4.能夠完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正則表達(dá)式包括(A, D)
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á)式包括(B,C )
A. “a?b”
B. “a{2}b”
C. “aa??b”
D. “aaa??b”