Python正則表達(dá)式的7個(gè)使用典范_第1頁(yè)
已閱讀5頁(yè),還剩4頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、python正則表達(dá)式的7個(gè)使用典范作為一個(gè)概念而言,正則表達(dá)式對(duì)于python來(lái)說(shuō)并不是獨(dú)有的。但是,python中的正則表達(dá)式在實(shí)際用法過(guò)程中還是有一些細(xì)小的差別。 將介紹python中對(duì)字符串舉行搜尋和查找的一些辦法,研究如何用法分組來(lái)處理我們查找到的匹配對(duì)象的子項(xiàng)。 用法的python中正則表達(dá)式的模塊通常叫做‘re’。 1. python中的原始類型字符串 python編譯器用‘’(反斜杠)來(lái)表示字符串常量中的轉(zhuǎn)義字符。 假如反斜杠后面跟著一串編譯器能夠識(shí)別的特別字符,那么囫圇轉(zhuǎn)義序列將被替換成對(duì)應(yīng)的特別

2、字符(例如,‘n’將被編譯器替換成換行符)。 但這給在python中用法正則表達(dá)式帶來(lái)了一個(gè)問(wèn)題,由于在‘re’模塊中也用法反斜杠來(lái)轉(zhuǎn)義正則表達(dá)式中的特別字符(比如*和+)。 這兩種方式的混合意味著有時(shí)候你不得不轉(zhuǎn)義轉(zhuǎn)義字符本身(當(dāng)特別字符能同時(shí)被python和正則表達(dá)式的編譯器識(shí)別的時(shí)候),但在其他時(shí)候你不必這么做(假如特別字符只能被python編譯器識(shí)別)。 與其將我們的心思放在去弄懂到底需要多少個(gè)反斜杠,我們可以用法原始字符串來(lái)替代。 原始類型字符串可以容易的通過(guò)在一般字符串的雙引號(hào)前面加一個(gè)字符&l

3、squo;r’來(lái)創(chuàng)建。當(dāng)一個(gè)字符串是原始類型時(shí),python編譯器不會(huì)對(duì)其嘗試做任何的替換。本質(zhì)上來(lái)講,你在告知編譯器徹低不要去干涉你的字符串。 這是一個(gè)一般字符串 這是一個(gè)原始類型字符串。 在python中用法正則表達(dá)式舉行查找 ‘re’模塊提供了幾個(gè)辦法對(duì)輸入的字符串舉行確切的查詢。我們將會(huì)要研究的辦法有: 每一個(gè)辦法都接收一個(gè)正則表達(dá)式和一個(gè)待查找匹配的字符串。讓我們更具體的查看這每一個(gè)辦法從而弄明了他們是如何工作的以及他們各有什么不同。 2. 用法re.match查找 – 匹配開(kāi)頭 讓我們先來(lái)看一下matc

4、h()辦法。match()辦法的工作方式是惟獨(dú)當(dāng)被搜尋字符串的開(kāi)始匹配模式的時(shí)候它才干查找到匹配對(duì)象。 舉個(gè)例子,對(duì)字符串‘dog cat dog’調(diào)用mathch()辦法,查找模式‘dog’將會(huì)匹配: 我們稍后將更多的研究group()辦法?,F(xiàn)在,我們只需要知道我們用0作為它的參數(shù)調(diào)用了它,group()辦法返回查找到的匹配的模式。 我還暫且略過(guò)了返回的sre_match對(duì)象,我們很快也將會(huì)研究到它。 但是,假如我們對(duì)同一個(gè)字符串調(diào)用math()辦法,查找模式‘cat’,則

5、不會(huì)找到匹配。 3. 用法re.search查找 – 匹配隨意位置 search()辦法和match()類似,不過(guò)search()辦法不會(huì)限制我們只從字符串的開(kāi)始查找匹配,因此在我們的示例字符串中查找‘cat’會(huì)查找到一個(gè)匹配: 然而search()辦法會(huì)在它查找到一個(gè)匹配項(xiàng)之后停止繼續(xù)查找,因此在我們的示例字符串中用searc()辦法查找‘dog’只找到其首次浮現(xiàn)的位置。 4. 用法 re.findall – 全部匹配對(duì)象 目前為止在python中我用法的最多的查找辦法是f

6、indall()辦法。當(dāng)我們調(diào)用findall()辦法,我們可以十分容易的得到一個(gè)全部匹配模式的列表,而不是得到match的對(duì)象(我們會(huì)在接下來(lái)更多的研究match對(duì)象)。對(duì)我而言這越發(fā)容易。對(duì)示例字符串調(diào)用findall()辦法我們得到: 5. 用法 match.start 和 match.end 辦法 那么,從前search()和match()辦法從前返回給我們的‘match’對(duì)象到底是什么呢? 和只容易的返回字符串的匹配部分不同,search()和match()返回的匹配對(duì)象,事實(shí)上是一個(gè)關(guān)于匹配子串的包裝類。 從前你看到我可以通過(guò)調(diào)用group(

7、)辦法得到匹配的子串,(我們將在下一個(gè)部分看到,實(shí)際上匹配對(duì)象在處理分組問(wèn)題時(shí)十分實(shí)用),但是匹配對(duì)象還包含了更多關(guān)于匹配子串的信息。 例如,match對(duì)象可以告知我們匹配的內(nèi)容在原始字符串中的開(kāi)頭和結(jié)束位置: 知道這些信息有時(shí)候十分實(shí)用。 6. 用法 mathch.group 通過(guò)數(shù)字分組 就像我之前提到的,匹配對(duì)象在處理分組時(shí)十分得心應(yīng)手。 分組是對(duì)囫圇正則表達(dá)式的特定子串舉行定位的能力。我們可以定義一個(gè)分組做為囫圇正則表達(dá)式的一部分,然后單獨(dú)的對(duì)這部分對(duì)應(yīng)匹配到的內(nèi)容定位。 讓我們來(lái)看一下它是怎么工作的: 我剛才創(chuàng)建的字符串類似一個(gè)從某人的地址本里取出來(lái)的一個(gè)片段。我們可以通過(guò)這樣一個(gè)正

8、則表達(dá)式來(lái)匹配這一行: 通過(guò)用圓括號(hào)來(lái)(字符‘(‘和‘)’)包圍正則表達(dá)式的特定部分,我們可以對(duì)內(nèi)容舉行分組然后對(duì)這些子組做單獨(dú)處理。 這些分組可以通過(guò)用分組對(duì)象的group()辦法得到。它們可以通過(guò)其在正則表達(dá)式中從左到右浮現(xiàn)的數(shù)字挨次來(lái)定位(從1開(kāi)頭): 組的序數(shù)從1開(kāi)頭的緣由是由于第0個(gè)組被預(yù)留來(lái)存放全部匹配對(duì)象(我們?cè)谥皩W(xué)習(xí)match()辦法和search()辦法到時(shí)候看到過(guò))。 7. 用法 match.group 通過(guò)別號(hào)來(lái)分組 有時(shí)候,特殊是當(dāng)一個(gè)正則表達(dá)式有無(wú)數(shù)分組的時(shí)候,通過(guò)組的浮現(xiàn)次序來(lái)定位就會(huì)變的不現(xiàn)實(shí)。python還允許你通過(guò)下面的語(yǔ)句來(lái)指定一個(gè)組名: 我們還是可以用group()辦法獵取分組的內(nèi)容,但這時(shí)候我們要用我們所指定的組名而不是之前所用法的組的所在位數(shù)。 但是,給分組命名并不適用于findall()辦法。 在本文中我們介紹了python中用法正則表達(dá)式的一些基礎(chǔ),學(xué)習(xí)了原始字符串類型(還有它能幫你解決的在用法正則表達(dá)式中一些頭痛的問(wèn)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論