Python-正則表達(dá)式

前言:

什么是正則表達(dá)式?

正則表達(dá)式(Regular expressions 也稱為 REs,或 regexes 或 regex patterns)本質(zhì)上是一個微小的且高度專業(yè)化的編程語言。

正則表達(dá)式并不是Python的一部分。它被嵌入到 Python 中,并通過 re 模塊提供給程序猿使用。使用正則表達(dá)式,你需要指定一些規(guī)則來描述那些你希望匹配的字符串集合。這些字符串集合可能包含英語句子、 e-mail 地址、TeX 命令,或任何你想要的字符串。

下圖展示了使用正則表達(dá)式進(jìn)行匹配的流程:


***********************可借助在線正則表達(dá)式測試來練習(xí)*************************


一、簡單介紹

1、普通字符

>>>通配符(.)

正則表達(dá)式可以匹配多于一個的字符串,通配符(.)可以匹配任何除換行符“\n”外的字符。

例:待匹配文本:“school

正則表達(dá)式:“s....l”

匹配結(jié)果:“school


>>>轉(zhuǎn)義符(\)

轉(zhuǎn)義字符,使用后使一個字符改變原來的意思,如果字符串中有字符需要匹配,可以使用(\字符)來表達(dá)。

例:待匹配文本:“W3.school”

正則表達(dá)式:“W3\.school”

匹配結(jié)果:“W3.school


>>>字符集([ ])

我們可以使用中括號([?])括住字符串來創(chuàng)建字符集。可以使用范圍,比如‘[a-z]’能夠匹配a到z的任意一個字符;還可以通過一個接一個的方式將范圍聯(lián)合起來使用,比如‘[a-zA-Z0-9]’能夠匹配任意大小寫字母和數(shù)字。

例:待匹配文本:“W3school”

正則表達(dá)式:“[a-z]”

匹配結(jié)果:“school

正則表達(dá)式:“[0-9]”

匹配結(jié)果:“3

正則表達(dá)式:“[A-Z]”

匹配結(jié)果:“W


>>>反轉(zhuǎn)字符集([^ ])

可以在開頭使用^字符,比如‘[^abc]’可以匹配任何除了a、b、c之外的字符。

例:待匹配文本:“W3school”

正則表達(dá)式:“[^a-z]”

匹配結(jié)果:“W3


2、預(yù)定義字符集

>>>數(shù)字(\d):匹配一個數(shù)字字符。等價于 [0-9]。

例:待匹配文本:“W3school”

正則表達(dá)式:“\d”

匹配結(jié)果:"3"


>>>非數(shù)字(\D): 匹配一個非數(shù)字字符。等價于 [^0-9]。

例:待匹配文本:“W3school”

正則表達(dá)式:“\D”

匹配結(jié)果:"Wschool"


>>>空白字符(\s): ?匹配任何空白字符,包括空格、制表符、換頁符等等。等價于 [ \f\n\r\t\v]。

例:待匹配文本:“W3 school”

正則表達(dá)式:“W3\sschool”

匹配結(jié)果:"W3 school"


>>>非空白字符(\S):? 匹配任何非空白字符。等價于 [^ \f\n\r\t\v]。

例:待匹配文本:“W3 school”

正則表達(dá)式:“\S”

匹配結(jié)果:"W3school"


>>>任何單詞字符(\w): ?匹配包括下劃線的任何單詞字符。等價于'[A-Za-z0-9_]'。

例:待匹配文本:“W3_school”

正則表達(dá)式:“\w”

匹配結(jié)果:"W3_school"


>>>>任何非單詞字符(\W):? 匹配任何非單詞字符。等價于 '[^A-Za-z0-9_]'。

例:待匹配文本:“!@#W3school”

正則表達(dá)式:“\W”

匹配結(jié)果:"!@#"


3、數(shù)量詞

>>>(pattern)* : ? 允許模式重復(fù)0次或多次

例:待匹配文本:“www.lxweimin.com”

正則表達(dá)式:“w*\.jianshu\.com”

匹配結(jié)果:"www.lxweimin.com"


>>>(pattern)+ : ? 允許模式重復(fù)1次或多次

例:待匹配文本:“www.lxweimin.com”

正則表達(dá)式:“w+\.jianshu\.com”

匹配結(jié)果:"www.lxweimin.com"


>>>(pattern){m,n} : ?允許模式重復(fù)m~ n次

例:待匹配文本:“wwwww.lxweimin.com”

正則表達(dá)式:“w{1,3}\.jianshu\.com”

匹配結(jié)果:"www.lxweimin.com"


4、邊界匹配

>>>匹配字符串開頭(^): 在多行模式中匹配每一行的開頭

例:待匹配文本:“W3school”

正則表達(dá)式:“^W3”

匹配結(jié)果:"W3"


>>>匹配字符串末尾($): 在多行模式中匹配每一行的末尾

例:待匹配文本:“W3school”

正則表達(dá)式:“ool$”

匹配結(jié)果:"ool"


>>>僅匹配字符串開頭(\A)

例:待匹配文本:“W3school”

正則表達(dá)式:“\AW3”

匹配結(jié)果:"W3"


>>>僅匹配字符串末尾(\Z)

例:待匹配文本:“W3school”

正則表達(dá)式:“ool\Z”

匹配結(jié)果:"ool"


5、邏輯、分組

>>>管道符號(|): 左右表達(dá)式任意匹配一個。如果|沒有被包括在()中,則它的范圍是整個正則表達(dá)式。

例:待匹配文本:“W3school”

正則表達(dá)式:“W3|ol”

匹配結(jié)果:"W3 ol"


>>>分組():被括起來的表達(dá)式將作為分組,從表達(dá)式左邊開始每遇到一個分組的左括號'(',編號+1 。另外,分組表達(dá)式作為一個整體,可以后接數(shù)量詞。表達(dá)式中的|僅在該組中有效。

例:待匹配文本:“W3schoolW3school”

正則表達(dá)式:“(W3school){2}”

匹配結(jié)果:"W3schoolW3school"

正則表達(dá)式:“W3(sch|ol)”

匹配結(jié)果:"W3sch"


>>>(?P<name>...) : 分組,除了原有的編號外在指定一個額外的別名。

>>>(?P=<name>): 引用別名為<name>的分組匹配到的字符串。


二、re模塊

Python 自1.5版本起增加了re 模塊,它提供 Perl 風(fēng)格的正則表達(dá)式模式。re 模塊使 Python 語言擁有全部的正則表達(dá)式功能。re模塊中一些重要的函數(shù),如下:

1、re.compile(strPattern[, flag])

這個方法是Pattern類的工廠方法,用于將字符串形式的正則表達(dá)式編譯為Pattern對象。 第二個參數(shù)flag是匹配模式,取值可以使用按位或運算符'|'表示同時生效,比如re.I | re.M。

正則表達(dá)式修飾符 - 可選標(biāo)志

舉例:

b=re.compile(r"\d+\.\d*", re.I | re.M)

2、re.search(pattern, string[, flags]

這個方法用于查找字符串中可以匹配成功的子串。從string的pos下標(biāo)處起嘗試匹配pattern,如果pattern結(jié)束時仍可匹配,則返回一個Match對象;若無法匹配,則將pos加1后重新嘗試匹配;直到pos=endpos時仍無法匹配則返回None。pos和endpos的默認(rèn)值分別為0和len(string));re.search()無法指定這兩個參數(shù),參數(shù)flags用于編譯pattern時指定匹配模式。

re.search

3、re.split(pattern, string[, maxsplit])

按照能夠匹配的子串將string分割后返回列表。maxsplit用于指定最大分割次數(shù),不指定將全部分割。

re.split

4、re. findall(pattern, string[, flags])

搜索string,以列表形式返回全部能匹配的子串。

re. findall


5、re.sub(pattern, repl, string[, count])

使用給定的替換內(nèi)容將匹配模式的子符串(最左端并且重疊子字符串)替換掉。

re.sub

6、re.escape(string)

可以對字符串中所有可能被解釋為正則運算符的字符進(jìn)行轉(zhuǎn)義的應(yīng)用函數(shù)。如果字符串很長且包含很多特殊字符,而你又不想輸入一大堆反斜線,可以使用這個函數(shù)。

re.escape



以上

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,345評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,494評論 3 416
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,283評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,953評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,714評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,410評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,940評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,776評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,210評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,642評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,878評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,654評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,958評論 2 373

推薦閱讀更多精彩內(nèi)容