
作為一個概念而言,正則運算式對于Python來說并不是獨有的,但是,Python中的正則運算式在實際使用程序中還是有一些細小的差別,
本文是一系列關于Python正則運算式文章的其中一部分,在這個系列的第一篇文章中,我們將重點討論如何使用Python中的正則運算式并突出Python中一些獨有的特性,
我們將介紹Python中對字串進行搜索和查找的一些方法,然后我們講討論如何使用分組來處理我們查找到的匹配物件的子項,
另外注意:光理論是不夠的,這里順便免費送大家一套2020最新python入門到高級專案實戰視頻教程,可以去小編的Python交流.裙 :七衣衣九七七巴而五(數字的諧音)轉換下可以找到了,還可以跟老司機交流討教!
我們有興趣使用的Python中正則運算式的模塊通常叫做‘re',
>>> import re
1. Python中的原始型別字串
Python編譯器用‘'(反斜杠)來表示字串常量中的轉義字符,
如果反斜杠后面跟著一串編譯器能夠識別的特殊字符,那么整個轉義序列將被替換成對應的特殊字符(例如,‘ '將被編譯器替換成換行符),
但這給在Python中使用正則運算式帶來了一個問題,因為在‘re'模塊中也使用反斜杠來轉義正則運算式中的特殊字符(比如*和+),
這兩種方式的混合意味著有時候你不得不轉義轉義字符本身(當特殊字符能同時被Python和正則運算式的編譯器識別的時候),但在其他時候你不必這么做(如果特殊字符只能被Python編譯器識別),
與其將我們的心思放在去弄懂到底需要多少個反斜杠,我們可以使用原始字串來替代,
原始型別字串可以簡單的通過在普通字串的雙引號前面加一個字符‘r'來創建,當一個字串是原始型別時,Python編譯器不會對其嘗試做任何的替換,本質上來講,你在告訴編譯器完全不要去干涉你的字串,
>>> string = 'This is a normal string' >>> rawString = r'and this is a raw string' >>> print string
這是一個普通字串
>>> print rawString and this is a raw 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()回傳的“匹配物件”,實際上是一個關于匹配子串的包裝類,
先前你看到我可以通過呼叫group()方法得到匹配的子串,(我們將在下一個部分看到,事實上匹配物件在處理分組問題時非常有用),但是匹配物件還包含了更多關于匹配子串的資訊,
例如,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<last>w+), (?P<first>w+): (?P<phone>S+)', contactInfo)
我們還是可以用group()方法獲取分組的內容,但這時候我們要用我們所指定的組名而不是之前所使用的組的所在位數,
>>> match.group('last')'Doe'
>>> match.group('first')'John'
>>> match.group('phone')'555-1212'
這大大加強了代碼的明確性和可讀性,你可以想像當正則運算式變得越來越復雜,去弄懂一個分組到捕獲了什么內容將會變得越來越困難,給你的分組命名將明確的告訴了你和你的讀者你的意圖, 盡管findall()方法不回傳分組物件,它也可以使用分組,類似的,findall()方法將回傳一個元組的集合,其中每個元組中的第N個元素對應了正則運算式中的第N個分組,
>>> re.findall(r'(w+), (w+): (S+)', contactInfo)
[('Doe', 'John', '555-1212')]
但是,給分組命名并不適用于findall()方法,
在本文中我們介紹了Python中使用正則運算式的一些基礎,我們學習了原始字串型別(還有它能幫你解決的在使用正則運算式中一些頭痛的問題),我們還學習了如何適使用match(), search(), and findall()方法進行基本的查詢,以及如何使用分組來處理匹配物件的子組件,
和往常一樣,如果想查看更多關于這個主題的內容,re模塊的Python官方檔案是一個非常好的資源,
最后注意:光理論是不夠的,這里順便免費送大家一套2020最新python入門到高級專案實戰視頻教程,可以去小編的Python交流.裙 :七衣衣九七七巴而五(數字的諧音)轉換下可以找到了,還可以跟老司機交流討教!
本文的文字及圖片來源于網路加上自己的想法,僅供學習、交流使用,不具有任何商業用途,著作權歸原作者所有,如有問題請及時聯系我們以作處理,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/141173.html
標籤:Python
