您好,登錄后才能下訂單哦!
正則表達式很神奇啊
# -*- coding:utf-8 -*- import re def print_match_res(res): """打印匹配對象內容""" if res is not None: print(res.group()) else: print(None) # 兩種匹配方式: pattern="[A-Z][a-z]+" # 一、使用re模塊函數進行匹配 res=re.match(pattern,"Tom is a good boy") # 匹配,返回匹配對象 print(type(res)) print(res.group()) # 二、使用預編譯后的正則表達式對象的方法進行匹配 obj_pattern=re.compile(pattern) # 預編譯,返回正則表達式對象 print(type(obj_pattern)) res=obj_pattern.match("Tom is a good boy") # 匹配,返回匹配對象 print(type(res)) print(res.group()) # 匹配對象的group()和groups()方法 pattern="\d{3}-\d{5}" obj_pattern=re.compile(pattern) res=obj_pattern.search("家庭電話:000-88886") print(res.group()) # 返回整個匹配或特定子組 print(res.groups()) # 返回包含全部子組的元組 # match():從起始部分開始匹配,如果成功,返回匹配對象;失敗,返回None。只匹配一次 pattern="my" # res=re.compile(pattern).match("my name is li") res=re.match(pattern,"my name is li") print_match_res(res) # search(): 從任意位置開始匹配,如果成功,返回匹配對象;失敗,返回None。只匹配一次 pattern="my" # res=re.compile(pattern).search("it's my dog") res=re.search(pattern,"my name is li") print_match_res(res) # 查找全部 # findall(),finditer() res=re.findall(r"th\w+","This and that",re.I) print(res) res=re.finditer(r"th\w+","This and that",re.I) print(res) print(next(res).group(),next(res).group()) # 替換 # sub(),subn() res=re.sub("funny","fool","You are so funny") print(res) res=re.subn("funny","fool","You are so funny") print(res) # 分割 # splite() res=re.split("\.","Mr.Smith") print(res) print("#"*50) # 擇一匹配符號 a|b pattern="I|You|She" res=re.compile(pattern,flags=re.IGNORECASE).match("i love you") print_match_res(res) res=re.compile(pattern,flags=re.I).search("who love you") print_match_res(res) # 匹配任意單個字符 . pattern="w{3,}\..+\.com" res=re.match(pattern,"wwww.google.com/index.html",re.I) print_match_res(res) # 字符集 [abc] [a-z0-9] pattern="[A-Za-z0-9_]*\." res=re.match(pattern,"Python3.?") print_match_res(res) # 特殊字符 \d \w \s \b \\ # 重復 + ? * {N,} {N,M} # 分組 (...) pattern="\w+@(\w{1,10}\.)*([a-z]*)" res=re.match(pattern,"li@gmail.com") print_match_res(res) res=re.match(pattern,"li@qq.vip.org") print_match_res(res) print(res.group(0),res.group(1),res.group(2),sep="\t") print(res.groups()) # 匹配字符串的起始和結尾,單詞邊界 ^a z$ \A \Z \b \B pattern=r"^the" # pattern=r"\Athe" res=re.search(pattern,"The end of the world") print_match_res(res) res=re.search(pattern,"they smile") print_match_res(res) pattern=r"cry$" # pattern=r"cry\Z" res=re.search(pattern,"they cry") print_match_res(res) res=re.search(r"\bthe","bit the dog") print_match_res(res) res=re.search(r"\Bhe","bit the dog") print_match_res(res)
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。