Python 正則表示式:findall
阿新 • • 發佈:2018-11-09
本文以匹配×××IP為例,介紹re模組的findall的用法: 返回值->列表
複雜匹配 = re.compile(正則表示式): 將正則表示式例項化
+
re.findall(要匹配的字串): 從字串開頭 開始匹配,尋找完整個字串後,將結果以 列表 返回
簡單匹配 = re.findall(正則表示式,要匹配的字串): 從字串開頭 開始匹配,尋找完整個字串後,將結果以 列表 返回
懶癌,配上模組函式解釋好消化
re.match(pattern, string, flags)第一個引數是正則表示式,如果匹配成功,則返回一個列表,否則返回一個空列表; 第二個引數表示要匹配的字串; 第三個引數是標誌位,用於控制正則表示式的匹配方式,如:是否區分大小寫,多行匹配等等。 需要特別注意的是,這個方法並不是完全匹配。它僅僅決定在字串開始的位置是否匹配。所以當pattern結束時若還有剩餘字元,仍然視為成功。想要完全匹配,可以在表示式末尾加上邊界匹配符'$' 例如: findall(‘p’,’python’)返回值為['p']; findall(‘p’,’p.python.p’)返回值為['p','p','p']
方法一:
物件名1 = re.compile(正則表示式)
物件名2 = re.findall(物件名1, 要比配的字串)
#!/usr/bin/python #! -*- coding:utf-8 -*- import re; pattern = r"([0-9]{3}(\.[0-9]{1,3}){3})" string = "192.168.1.1 192.100.0.0" com_pat = re.compile(pattern) result = re.findall(com_pat, string) if result == None: print("None") else: print("Match:",result) pattern1 = r"a" string1 = "abd cad" com_pat1 = re.compile(pattern1) result1 = re.findall(com_pat1, string1) print("Match:",result1)
執行結果:
Match: [('192.168.1.1', '.1'), ('192.100.0.0', '.0')] Match: ['a', 'a']
求大佬告訴我:為什麼匹配到的result列表會有'.1'和'.0'這個雜項????
re.search 與 re.match 與 re.findall 的區別:
相同點:
re.search 與 re.match 與 re.findall都是從字串開頭 開始匹配。
不同點:
re.search 按順序從頭到尾匹配,任意位置搜尋到合適的字串則匹配成功。
re.match 按順序從頭到尾匹配,若開頭第一個位置匹配失敗,立即返回失敗。
re.findall 按順序從頭到尾匹配,一直匹配到字串末尾結束,用 列表 返回尋找到 所有 匹配到的結果。