www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 電源 > 功率器件
[導讀]作為一個概念而言,正則表達式對于Python來說并不是獨有的。但是,Python中的正則表達式在實際使用過程中還是有一些細小的差別。本文是一系列關于Python正則表達式文章的其

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

本文是一系列關于Python正則表達式文章的其中一部分。在這個系列的第一篇文章中,我們將重點討論如何使用Python中的正則表達式并突出Python中一些獨有的特性。

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

我們有興趣使用的Python中正則表達式的模塊通常叫做‘re’。

>>> import

re

1. Python中的原始類型字符串

Python編譯器用‘’(反斜杠)來表示字符串常量中的轉(zhuǎn)義字符。

如果反斜杠后面跟著一串編譯器能夠識別的特殊字符,那么整個轉(zhuǎn)義序列將被替換成對應的特殊字符(例如,‘n’將被編譯器替換成換行符)。

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

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

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

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

>>> string = 'This is annormal string'

>>> rawString = r'and this is anraw string'

>>> print string

這是一個普通字符串

>>> print rawString

and this

is anraw string

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

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

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

re.match()

re.search()

re.findall()

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

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

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

舉個例子,對字符串‘dog cat dog’調(diào)用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()方法?,F(xiàn)在,我們只需要知道我們用0作為它的參數(shù)調(diào)用了它,group()方法返回查找到的匹配的模式。

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

但是,如果我們對同一個字符串調(diào)用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()方法會在它查找到一個匹配項之后停止繼續(xù)查找,因此在我們的示例字符串中用searc()方法查找‘dog’只找到其首次出現(xiàn)的位置。

>>> match =

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

>>> match.group(0)

'dog'

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

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

['dog', 'dog']

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

['cat']

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

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

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

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

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

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

>>> match.start()

0

>>> match.end()

3

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

6. 使用 mathch.group 通過數(shù)字分組

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

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

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

>>> contactInfo =

'Doe, John: 555-1212'

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

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

<_sre.SRE_Match object

at 0xb74e1ad8<

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

>>> match =

re.search(r'(w+), (w+): (S+)', contactInfo)

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

>>> match.group(1)

'Doe'

>>> match.group(2)

'John'

>>> match.group(3)

'555-1212'

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

>>> match.group(0)

'Doe, John: 555-1212'

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

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

>>> match =

re.search(r'(?Pw+), (?Pw+): (?P

S+)', contactInfo)

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

>>> match.group('last')

'Doe'

>>> match.group('first')

'John'

>>> match.group('phone')

'555-1212'

這大大加強了代碼的明確性和可讀性。你可以想像當正則表達式變得越來越復雜,去弄懂一個分組到捕獲了什么內(nèi)容將會變得越來越困難。給你的分組命名將明確的告訴了你和你的讀者你的意圖。

盡管findall()方法不返回分組對象,它也可以使用分組。類似的,findall()方法將返回一個元組的集合,其中每個元組中的第N個元素對應了正則表達式中的第N個分組。

>>> re.findall(r'(w+), (w+): (S+)', contactInfo)

[('Doe', 'John', '555-1212')]

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

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

和往常一樣,如果想查看更多關于這個主題的內(nèi)容,re模塊的Python官方文檔是一個非常好的資源。

在以后的文章中,我們將更深入的討論Python中正則表達式的應用。我們將更加全面的學習匹配對象,學習如何使用它們在字符串中做替換,甚至使用它們從文本文件中去解析Python數(shù)據(jù)結(jié)構(gòu)。

本站聲明: 本文章由作者或相關機構(gòu)授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉