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ò)誤
ipaddr = input('請(qǐng)輸入:')
re_str = r'([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5])[.]([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5])[.]([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5])[.]([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-5][0-5])'
result = re.fullmatch(re_str,ipaddr)
print(result)
if result:
print('正確')
else:
print('錯(cuò)誤')
請(qǐng)輸入:255.145.235.142
<_sre.SRE_Match object; span=(0, 15), match='255.145.235.142'>
正確
請(qǐng)輸入:256.1.23.45
None
錯(cuò)誤
2. 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
re_str = r'\d*[.]\d+|\d+'
result = re.findall(re_str,'hello90abc 78sjh12.5')
sum1 =0
for item in result:
sum1 += float(item)
print(sum1)
180.5
3. 驗(yàn)證輸入的內(nèi)容只能是漢字
word = input('請(qǐng)輸入:')
re_str = r'[\u4e00-\u9fa5]+'
result = re.fullmatch(re_str,word)
if result:
print(result)
else:
print('請(qǐng)輸入漢字')
4. 電話號(hào)碼的驗(yàn)證
number = input('輸入電話號(hào)碼:')
re_str = r'1[358]\d{9}'
result = re.fullmatch(re_str,number)
if result:
print(result)
else:
print('電話號(hào)碼錯(cuò)誤渔期!')
- 簡(jiǎn)單的身份證號(hào)的驗(yàn)證
id_card = input('輸入身份證號(hào):')
re_str =r'^([1-9]\d{5}[12]\d{3}(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])\d{3}[0-9xX])$'
result = re.fullmatch(re_str,id_card)
if result:
print(result)
else:
print('輸入錯(cuò)誤')
二郑口、不定項(xiàng)選擇題
1. 能夠完全匹配字符串“(010)-62661617”和字符串“01062661617”的正則表達(dá)式包括( A竿屹、D )
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)容的大寫(xiě)變成小寫(xiě)
D. “(?s)C:\RapidMiner\Lib\Plugs” ?s:?jiǎn)涡衅ヅ?/p>
3. 能夠完全匹配字符串“back”和“back-end”的正則表達(dá)式包括(A 、B 妇穴、C)
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*”
4. 能夠完全匹配字符串“go go”和“kitty kitty”爬虱,但不能完全匹配“go kitty”的正則表達(dá)式包括(C、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”
5. 能夠在字符串中匹配“aab”腾它,而不能匹配“aaab”和“aaaab”的正則表達(dá)式包括(B跑筝、 C )
A. “a*?b”
B. “a{,2}b”
C. “aa??b”
D. “aaa??b”