本文主要講正則表達式的基本用法
python中導入模塊:import? re
【1】字符:^? ?.? ? *? ? $
^表示以什么字符開頭的字符串;
.表示任意字符
*代表前面的字符可以出現任意多次,包括0次
regex_str = "^b.*"? ?#^以‘b’開頭的任意字符串
regex_str1 = ".*3$" # $以3結尾任意字符串
regex_str2 = "^b.3$" #‘b’字符開頭,以3結尾,b和3之間可以是一個任意字符,只是匹配了三個字符的字符串
【2】字符:問號?? 非貪婪匹配,就是取消貪婪匹配(貪婪匹配與非貪婪匹配可以參考:正則表達式之 貪婪與非貪婪模式詳解)
(1)
line2 = “aaaboooobbbb123”
regex_str3 = ".*?(b.*?b).*"? ?
match_object =?re.match(regex_str3,line2)
if match_object :
? ? print(match_object.group(1))? ?#輸出結果boooob ,regex_str3表達式括號里面的才是要輸出的值;
(2)
line=“study in 清華大學”
regex_str =".*?([\u4E00-\u9FA5])"+大學"? #這個[\u4E00-\u9FA5]是指匹配任意連續的中文字符,加號就是匹配在”大學“前面的一個或者多個的字符;
#如果不加?,就是貪婪模式,括號里面就這是會匹配到”華“,”清“字當成是前面的*匹配掉,后面就只能匹配一個字了,加?號后,取消貪婪匹配,后面就能匹配到”清華“
【3】字符:+加號,字符至少出現一次,限定前面的字符出現至少一次,*限定前面的字符出現0次到多次都行
line3= “aaaboooobaabbb123”
regex_str4=".*(b.+b).*"? #括號里面是要截取的內容,括號前面的可以是0位到多位的任意字符,從第一個b開始匹配,中間是一個字符至少有一位以上,然后又到右邊的一個b
match_object =?re.match(regex_str4,line3)
if match_object :
print(match_object.group(1))? ?#取得是括號里的內容,輸出結果baab ;
【4】字符:{},有三種模式? {2}和{2,}限定前面的字符自少出現多少次;{1,2}?限定前面的字符自少出現1次,最多等于2次
表達式:".*(b.{2}b).*"? ? 針對字符串“aaaboooobaabbb123”? 輸出?baab
【5】字符| 是或的意思
字符串:“boby123”
表達式“(body|body123)”? ?匹配body或者body123都行,要加括號才能打印出來,?print(match_object.group(1)) 打印出boby123
表達式“((body|boddy)123)” 匹配的是body123或者boddy123 ,.group(1)是指外面的括號,打印是完整的body123;;.group(2)是指里面的括號,打印是里面匹配的body
【6】中括號[ ],有三種用法:
? ? ? ? 【3,7,8】中括號里面的任意字符都行
? ? ? ? 【0-9】,【A-Za-z0-9_】表示區間,在這個區間的就行
? ? ? ? ?【^6】反義,不等于6就行
表達式:"(1[378][0-9]{9})" #字符串要求第一位是1,第二位是3/7/8,第三位到第9位是0到9區間出現9位({9}表示前面的那個區間的數據出現9次,剛剛好就是9位數字);注意小括號也一定要是英文的
【7】\s,\S,\w,\W?
? ? ? ?\s 表示一個空格字符串
? ? ? ?\S表示非空格的任意一個字符串
? ? ? \w表示【A-Za-z0-9_】這個里面的任意一個字符串
? ? ? \W表示不在【A-Za-z0-9_】這個區間內的任意一個字符串都行
【8】[\u4E00-\u9FA5]? 匹配連續的中文
表達式"[\u4E00-\u9FA5]+"? ?可以匹配到"中文s"這類的字符串,但是不能匹配到"中? 文"這樣字符串的后面一個‘文’字,只能是‘中’
【9】\d? 匹配連續的數字
line = "xxx出生2001年"
提取年份
reg_str = ".*?(\d+)年"
mo = re.match(reg_str,line)
if mo:
? ? print(mo.group(1))