from re import *
1. 寫(xiě)一個(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ò)誤
"""4個(gè)數(shù)字
每個(gè)數(shù)字用 . 連接
數(shù)字大小0~255
要完全匹配"""
ip = '249.199.8.255'
re_str = r'((\d|[1-9]\d|(1\d\d|(2[0-4]\d|25[0-5])))\.){3}(\d|[1-9]\d|(1\d\d|(2[0-4]\d|25[0-5])))'
print(fullmatch(re_str, ip))
2. 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
"""取數(shù)字是連在一起取
數(shù)字的長(zhǎng)度是不定長(zhǎng)"""
str1 = 'hello90abc 78sjh12.5.as1'
re_str = r'[0-9]+\.?[0-9]+|\d'
result = findall(re_str, str1)
sum1 = 0
for x in result:
sum1 +=float(x)
print(sum1)
3. 驗(yàn)證輸入的內(nèi)容只能是漢字
str1 = input('請(qǐng)輸入一個(gè)字符串:')
re_str = r'[\u4e00-\u9fa5]+'
if bool(fullmatch(re_str, str1)):
print('內(nèi)容合法')
else:
print('不合法')
4. 電話號(hào)碼的驗(yàn)證
re_str = r'1[3-9]\d{9}'
print(fullmatch(re_str, '13887445302'))
5. 驗(yàn)證輸入用戶(hù)名和QQ號(hào)是否有效并給出對(duì)應(yīng)的提示信息
要求:
用戶(hù)名必須由字母咳燕、數(shù)字或下劃線構(gòu)成且長(zhǎng)度在6~20個(gè)字符之間
QQ號(hào)是5~12的數(shù)字且首位不能為0
user_name = r'[a-zA-Z_]{6,20}'
print(fullmatch(user_name, '928adaq'))
qq_num = r'[1-9]\d{4,11}'
print(fullmatch())
6. 拆分長(zhǎng)字符串:將一首詩(shī)的中的每一句話分別取出來(lái)
```Python
poem = '窗前明月光勿决,疑是地上霜。舉頭望明月招盲,低頭思故鄉(xiāng)剥险。'
```
poem = '窗前明月光,疑是地上霜宪肖。舉頭望明月表制,低頭思故鄉(xiāng)。'
re_str = r'[\u4e00-\u9fa5]+控乾。|[\u4e00-\u9fa5]+么介,'
print(findall(re_str, poem))
- 能夠完全匹配字符串“(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)容的大寫(xiě)變成小寫(xiě)
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:?jiǎn)涡衅ヅ?/p>能夠完全匹配字符串“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*”能夠完全匹配字符串“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”能夠在字符串中匹配“aab”蜕衡,而不能匹配“aaab”和“aaaab”的正則表達(dá)式包括(B,C )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”