Python正則表達式的7個使用典範(推薦)

概述

作為一個概念而言,正則表達式對於Python來說並不是獨有的。但是,Python中的正則表達式在實際使用過程中還是有一些細小的差別。

將介紹Python中對字符串進行搜索和查找的一些方法,討論如何使用分組來處理我們查找到的匹配對象的子項。

使用的Python中正則表達式的模塊通常叫做‘re'。

>>> import re

Python中的原始類型字符串

Python編譯器用‘'(反斜槓)來表示字符串常量中的轉義字符。

如果反斜槓後面跟著一串編譯器能夠識別的特殊字符,那麼整個轉義序列將被替換成對應的特殊字符(例如,‘\n'將被編譯器替換成換行符)。

但這給在Python中使用正則表達式帶來了一個問題,因為在‘re'模塊中也使用反斜槓來轉義正則表達式中的特殊字符(比如*和+)。

這兩種方式的混合意味著有時候你不得不轉義轉義字符本身(當特殊字符能同時被Python和正則表達式的編譯器識別的時候),但在其他時候你不必這麼做(如果特殊字符只能被Python編譯器識別)。

與其將我們的心思放在去弄懂到底需要多少個反斜槓,我們可以使用原始字符串來替代。

原始類型字符串可以簡單的通過在普通字符串的雙引號前面加一個字符‘r'來創建。當一個字符串是原始類型時,Python編譯器不會對其嘗試做任何的替換。本質上來講,你在告訴編譯器完全不要去幹涉你的字符串。

Python正則表達式的7個使用典範(推薦)

這是一個普通字符串

Python正則表達式的7個使用典範(推薦)

這是一個原始類型字符串。

在Python中使用正則表達式進行查找

‘re'模塊提供了幾個方法對輸入的字符串進行確切的查詢。我們將會要討論的方法有:

•re.match()

•re.search()

•re.findall()

每一個方法都接收一個正則表達式和一個待查找匹配的字符串。讓我們更詳細的查看這每一個方法從而弄明白他們是如何工作的以及他們各有什麼不同。


使用re.match查找 – 匹配開始

讓我們先來看一下match()方法。match()方法的工作方式是隻有當被搜索字符串的開頭匹配模式的時候它才能查找到匹配對象。

舉個例子,對字符串‘dog cat dog'調用mathch()方法,查找模式‘dog'將會匹配:

Python正則表達式的7個使用典範(推薦)

我們稍後將更多的討論group()方法。現在,我們只需要知道我們用0作為它的參數調用了它,group()方法返回查找到的匹配的模式。

我還暫且略過了返回的SRE_Match對象,我們很快也將會討論到它。

但是,如果我們對同一個字符串調用math()方法,查找模式‘cat',則不會找到匹配。

Python正則表達式的7個使用典範(推薦)


使用re.search查找 – 匹配任意位置

search()方法和match()類似,不過search()方法不會限制我們只從字符串的開頭查找匹配,因此在我們的示例字符串中查找‘cat'會查找到一個匹配:

Python正則表達式的7個使用典範(推薦)

然而search()方法會在它查找到一個匹配項之後停止繼續查找,因此在我們的示例字符串中用searc()方法查找‘dog'只找到其首次出現的位置。

Python正則表達式的7個使用典範(推薦)


使用 re.findall – 所有匹配對象

目前為止在Python中我使用的最多的查找方法是findall()方法。當我們調用findall()方法,我們可以非常簡單的得到一個所有匹配模式的列表,而不是得到match的對象(我們會在接下來更多的討論match對象)。對我而言這更加簡單。對示例字符串調用findall()方法我們得到:

Python正則表達式的7個使用典範(推薦)


使用 match.start 和 match.end 方法

那麼,先前search()和match()方法先前返回給我們的‘match'對象”到底是什麼呢?

和只簡單的返回字符串的匹配部分不同,search()和match()返回的“匹配對象”,實際上是一個關於匹配子串的包裝類。

先前你看到我可以通過調用group()方法得到匹配的子串,(我們將在下一個部分看到,事實上匹配對象在處理分組問題時非常有用),但是匹配對象還包含了更多關於匹配子串的信息。

例如,match對象可以告訴我們匹配的內容在原始字符串中的開始和結束位置:

Python正則表達式的7個使用典範(推薦)

知道這些信息有時候非常有用。


使用 mathch.group 通過數字分組

就像我之前提到的,匹配對象在處理分組時非常得心應手。

分組是對整個正則表達式的特定子串進行定位的能力。我們可以定義一個分組做為整個正則表達式的一部分,然後單獨的對這部分對應匹配到的內容定位。

讓我們來看一下它是怎麼工作的:

>>> contactInfo = 'Doe, John: 555-1212'

我剛才創建的字符串類似一個從某人的地址本里取出來的一個片段。我們可以通過這樣一個正則表達式來匹配這一行:

Python正則表達式的7個使用典範(推薦)

通過用圓括號來(字符‘('和‘)')包圍正則表達式的特定部分,我們可以對內容進行分組然後對這些子組做單獨處理。

>>> match = re.search(r'(\w+), (\w+): (\S+)', contactInfo)

這些分組可以通過用分組對象的group()方法得到。它們可以通過其在正則表達式中從左到右出現的數字順序來定位(從1開始):

Python正則表達式的7個使用典範(推薦)

組的序數從1開始的原因是因為第0個組被預留來存放所有匹配對象(我們在之前學習match()方法和search()方法到時候看到過)。

Python正則表達式的7個使用典範(推薦)


使用 match.group 通過別名來分組

有時候,特別是當一個正則表達式有很多分組的時候,通過組的出現次序來定位就會變的不現實。Python還允許你通過下面的語句來指定一個組名:

>>> match = re.search(r'(?P<last>\w+), (?P<first>\w+): (?P<phone>\S+)', contactInfo)
/<phone>/<first>/<last>

我們還是可以用group()方法獲取分組的內容,但這時候我們要用我們所指定的組名而不是之前所使用的組的所在位數。

Python正則表達式的7個使用典範(推薦)

但是,給分組命名並不適用於findall()方法。

在本文中我們介紹了Python中使用正則表達式的一些基礎,學習了原始字符串類型(還有它能幫你解決的在使用正則表達式中一些頭痛的問題)。還學習瞭如何適使用match(), search(), and findall()方法進行基本的查詢,以及如何使用分組來處理匹配對象的子組件。


以上所述是小編給大家介紹的Python正則表達式的7個使用典範,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回覆大家的!

後面小編會分享更多運維方面的乾貨,感興趣的朋友走一波關注哩~

Python正則表達式的7個使用典範(推薦)


分享到:


相關文章: