- 寫(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ò)誤
關(guān)鍵是:寫(xiě)一個(gè)正則匹配0-255
0-9:\d
10-99:[1-9]\d
100-199:1\d{2}
200-249:2[0-4]\d
250-255:25[0-5]
0-255: \d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]
x.x.x.x
(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5]\.){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])
re_str = r'((\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.){3}(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])'
str1 = '250.78.78.10'
if re.fullmatch(re_str, str1):
print('是IP地址')
else:
print('不是IP地址')
- 計(jì)算一個(gè)字符串中所有的數(shù)字的和
例如:字符串是:‘hello90abc 78sjh12.5’ 結(jié)果是90+78+12.5 = 180.5
import re
num=0
str = 'hello90abc 78sjh12.5'
re_str = r'[1-9][0-9][.][0-9]|[1-9][0-9]'
result=re.search(re_str,str)
while result:
print(result.group())
a = result.group()
num = float(a)+num
end = result.end()
str = str[end:]
result = re.search(re_str,str)
print(num)
老師方法:
re_str = r'[+-]?\d+\.\d+|[+-]?\d+'
all_number = re.findall(re_str, 'h+10ello90abc 78sjh12.5')
sum1 = 0
for num_str in all_number:
sum1 += float(num_str)
print(sum1)
- 驗(yàn)證輸入的內(nèi)容只能是漢字
str1 = input('請(qǐng)輸入漢字:')
# re_str = r'[一-?]+'
re_str = r'[\u4E00-\u9FA5]+'
if re.fullmatch(re_str, str1):
print('全是漢字')
else:
print('不全是漢字')
- 電話(huà)號(hào)碼的驗(yàn)證
phone = input('請(qǐng)輸入電話(huà)號(hào)碼')
re_str = '1[0-9]{10}|[0-9]{4}-[0-9]{7}'
result = fullmatch(re_str,phone)
print(result)
if result != None:
print('輸入正確')
else:
print('輸入錯(cuò)誤')
- 簡(jiǎn)單的身份證號(hào)的驗(yàn)證
方法;
1.前六位是數(shù)字: \d{6}
2.八位是年月日:
年:1900-2018 ---- 1900-1999:19\d{2}
2000-2009:200\d
2010-2018:201[0-8]
月:00-12:01-09:0[1-9]
10-12:1[0-2]
日:00-31:01-09:0[1-9]
10-29: [1-2]\d
30-31:3[01]
3.三位數(shù)字: \d{3}
4.最后一位是數(shù)字或者是X: [\dXx]
\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]
"""
# re_str = r'(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)'
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]'
if re.fullmatch(re_str, '500234200004238767'):
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)容的大寫(xiě)變成小寫(xiě)
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”