2018-10-23正則表達(dá)式作業(yè)

1. 寫一個(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ò)誤

  • 分析IP地址的組成特點(diǎn):250-255、200-249、0-199
import re
re_str = r'((25[0-5]|2[0-4]\d|[0-1]?\d?\d)\.(25[0-5]|2[0-4]\d|[0-1]?\d?\d)){3}'

while True:
    ip = input('請(qǐng)輸入IP地址(00.00.00.00):')
    if re.fullmatch(re_str, ip):
        print('%s 正確' % ip)
        break
    else:
        print('不符合ip地址規(guī)范!')
        continue

2. 計(jì)算一個(gè)字符串中所有的數(shù)字的和

  • 例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
import re
str1 = 'hello90abc 78sjh12.5'
result = re.findall(r'[\d | \d\.\d]+', str1)
print(result)
sum1 = 0
for num in result:
    sum1 += float(num)
print('和:', sum1)

3. 驗(yàn)證輸入的內(nèi)容只能是漢字

import re
str1 = input('請(qǐng)輸入用戶名(只能是漢字):')

while True:
    if re.findall(r'[\u4E00-\u9FBF]{4,6}', str1):
        print('%s 可用' % str1)
        break
    else:
        print('輸入錯(cuò)誤!')
        str1 = input('請(qǐng)輸入用戶名(只能是漢字):')
        continue

4. 電話號(hào)碼的驗(yàn)證

import re

while True:
    # print(re.findall(r'\d{11}', tel))
    tel = input('請(qǐng)輸入電話(只能是11位數(shù)字):')
    if re.fullmatch(r'\d{11}', tel):
        print('%s 可用' % tel)
        break
    else:
        print('輸入錯(cuò)誤!')
        continue

5. 簡(jiǎn)單的身份證號(hào)的驗(yàn)證

import re
while True:
    card = input('請(qǐng)輸入身份證號(hào)(只能是18位數(shù)字):')
    if re.fullmatch(r'\d{17}[\d |x]', card):
        print('%s 可用' % card)
        break
    else:
        print('輸入錯(cuò)誤!')
        continue

二、不定項(xiàng)選擇題

1.能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括( ABD )
A. “(?\d{3})?-?\d{8}”
B. “[0-9()-]+”
C. “[0-9(-)]\d
D. “[(]?\d[)-]\d*”

2.能夠完全匹配字符串“c:\rapidminer\lib\plugs”的正則表達(dá)式包括( 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:?jiǎn)涡衅ヅ?/p>

  1. 能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括( 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*”
  1. 能夠完全匹配字符串“go go”和“kitty kitty”,但不能完全匹配“go kitty”的正則表達(dá)式包括(AD )
    :\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”
  1. 能夠在字符串中匹配“aab”,而不能匹配“aaab”和“aaaab”的正則表達(dá)式包括(BC)
    A. “a*?b”
    B. “a{,2}b”
    C. “aa??b”
    D. “aaa??b”

注意:

  • 幾種常用的非貪婪匹配模型:
語法 意義
*? 重復(fù)任意次,但盡可能少重復(fù)
+? 重復(fù)1次或更多次,但盡可能少重復(fù)
?? 重復(fù)0次或1次,但盡可能少重復(fù)
{n,m}? 重復(fù)n到m次,但盡可能少重復(fù)
{n,}? 重復(fù)n次以上,但盡可能少重復(fù)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容