Python正規表示式的7個使用典範

2021-09-27 01:52:22 字數 4411 閱讀 5044

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

將介紹python中對字串進行搜尋和查詢的一些方法,討論如何使用分組來處理我們查詢到的匹配物件的子項。

使用的python中正規表示式的模組通常叫做『re』。

>>> import re
1. python中的原始型別字串

python編譯器用『』(反斜槓)來表示字串常量中的轉義字元。

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

但這給在python中使用正規表示式帶來了乙個問題,因為在『re』模組中也使用反斜槓來轉義正規表示式中的特殊字元(比如*和+)。

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

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

原始型別字串可以簡單的通過在普通字串的雙引號前面加乙個字元『r』來建立。當乙個字串是原始型別時,python編譯器不會對其嘗試做任何的替換。本質上來講,你在告訴編譯器完全不要去干涉你的字串。

'''

'''>>> string = 'this is a\nnormal string'

>>> rawstring = r'and this is a\nraw string'

>>> print string

這是乙個普通字串

>>> print rawstring

and this is a\nraw string

這是乙個原始型別字串。

在python中使用正規表示式進行查詢

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

•re.match()

•re.search()

•re.findall()

每乙個方法都接收乙個正規表示式和乙個待查詢匹配的字串。讓我們更詳細的檢視這每乙個方法從而弄明白他們是如何工作的以及他們各有什麼不同。

2. 使用re.match查詢 – 匹配開始

讓我們先來看一下match()方法。match()方法的工作方式是只有當被搜尋字串的開頭匹配模式的時候它才能查詢到匹配物件。

舉個例子,對字串『dog cat dog』呼叫mathch()方法,查詢模式『dog』將會匹配:

'''

'''>>> re.match(r'dog', 'dog cat dog')

<_sre.sre_match object at 0xb743e720<

>>> match = re.match(r'dog', 'dog cat dog')

>>> match.group(0)

'dog'

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

我還暫且略過了返回的sre_match物件,我們很快也將會討論到它。

但是,如果我們對同乙個字串呼叫math()方法,查詢模式『cat』,則不會找到匹配。

>>> re.match(r'cat', 'dog cat dog')

>>>

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

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

search(r'cat', 'dog cat dog')

>>> match.group(0)

'cat'

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

>>> match = re.search(r'dog', 'dog cat dog')

>>> match.group(0)

'dog'

4. 使用 re.findall – 所有匹配物件

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

'''

'''['dog', 'dog']

>>> re.findall(r'cat', 'dog cat dog')

['cat']

5. 使用 match.start 和 match.end 方法

那麼,先前search()和match()方法先前返回給我們的『match』物件」到底是什麼呢?

和只簡單的返回字串的匹配部分不同,search()和match()返回的「匹配物件」,實際上是乙個關於匹配子串的包裝類。

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

'''

'''>>> match = re.search(r'dog', 'dog cat dog')

>>> match.start()

>>> match.end()

知道這些資訊有時候非常有用。

6. 使用 mathch.group 通過數字分組

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

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

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

>>> contactinfo = 'doe, john: 555-1212'
>>> re.search(r'\w+, \w+: \s+', contactinfo)

<_sre.sre_match object at 0xb74e1ad8<

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

>>> match = re.search(r'(\w+), (\w+): (\s+)', contactinfo)
這些分組可以通過用分組物件的group()方法得到。它們可以通過其在正規表示式中從左到右出現的數字順序來定位(從1開始):

'''

'''>>> match.group(1)

'doe'

>>> match.group(2)

'john'

>>> match.group(3)

'555-1212'

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

>>> match.group(0)

'doe, john: 555-1212'

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

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

>>> match = re.search(r'(?p\w+), (?p\w+): (?p\s+)', contactinfo)
我們還是可以用group()方法獲取分組的內容,但這時候我們要用我們所指定的組名而不是之前所使用的組的所在位數。

'''

'''>>> match.group('last')

'doe'

>>> match.group('first')

'john'

>>> match.group('phone')

'555-1212'

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

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

Python 正規表示式 7

常見問題 1 使用正規表示式雖說通吃,但有的時候直接使用字串的方法也是個不錯的選擇。2 match 只會報告一次成功的匹配,並且匹配的位置必須是從字串的第乙個字元開始 search 函式遍歷整個字串,並報告它找到的第乙個匹配 3 貪婪vs非貪婪 當重複乙個正規表示式時,如果使用a 那麼結果是盡可能多...

python基礎 正規表示式 python使用正則

在學習python中如何使用正規表示式,我們先來了解下正規表示式 正規表示式本身也和python沒有什麼關係,就是匹配字串內容的一種規則。官方定義 正規表示式是對字串操作的一種邏輯公式,就是用事先定義好的一些特定字元 及這些特定字元的組合,組成乙個 規則字串 這個 規則字串 用來表達對字串的一種過濾...

python正規表示式元字元 正規表示式

字元 描述將下乙個字元標記為乙個特殊字元 或乙個原義字元 或乙個 向後引用 或乙個八進位制轉義符。例如,n 匹配字元 n n 匹配乙個換行符。序列 匹配 而 則匹配 匹配輸入字串的開始位置。如果設定了 regexp 物件的 multiline 屬性,也匹配 n 或 r 之後的位置。匹配輸入字串的結束...