正規表示式

2022-09-02 11:09:10 字數 3080 閱讀 7954

正規表示式使用單個字串來描述、匹配一系列符合某個句法規則。正規表示式通常被用來檢索、替換那些符合某個模式的文字。

語法:

import re  #

匯入re模組

m = re.match("

abc","

abcdef")

ifm:

print(m.group()) #

輸出abc,表示匹配到abc

p = re.compile("

^[0-9]

") #

生成的正則物件

m = p.match('

12354abc

') #

需要匹配的字串

print(m.group()) #

輸出1

常用操作:

1.re.match(pattern, string)     #

從頭匹配

2.re.search(pattern, string)    #

匹配整個字串,直到找到乙個匹配

3.re.split()             #

將匹配到的格式當做分割點對字串分割成列表

m = re.split("

[0-9]

","tudou1fanqie2qiezi3doujiao4")

print(m) #

輸出 ['tudou', 'fanqie', 'qiezi', 'doujiao', '']

4.re.findall()          #

找到所有要匹配的字元並返回列**式

m = re.findall("

[0-9]

","tudou1fanqie2qiezi3doujiao4")

print(m) #

輸出 ['1', '2', '3', '4']

5.re.sub(pattern, repl, string, count,flag)    #

替換匹配到的字元

m = re.sub("

[0-9]

","|

","tudou1fanqie2qiezi3doujiao4

",count=3)

print(m) #

輸出 tudou|fanqie|qiezi|doujiao4

匹配格式

模式描述

^匹配字串的開頭

$匹配字串的末尾。

.匹配任意字元,除了換行符,當re.dotall標記被指定時,則可以匹配包括換行符的任意字元。

[...]

用來表示一組字元,單獨列出:[amk] 匹配 'a','m'或'k'

[^...]

不在中的字元:[^abc] 匹配除了a,b,c之外的字元。

re*匹配0個或多個的表示式。

re+匹配1個或多個的表示式。

re?匹配0個或1個由前面的正規表示式定義的片段,非貪婪方式

rere

精確匹配n個前面表示式。

re匹配 n 到 m 次由前面的正規表示式定義的片段,貪婪方式

a| b

匹配a或b

(re)

g匹配括號內的表示式,也表示乙個組

(?imx)

正規表示式包含三種可選標誌:i, m, 或 x 。只影響括號中的區域。

(?-imx)

正規表示式關閉 i, m, 或 x 可選標誌。只影響括號中的區域。

(?: re)

類似 (...), 但是不表示乙個組

(?imx: re)

在括號中使用i, m, 或 x 可選標誌

(?-imx: re)

在括號中不使用i, m, 或 x 可選標誌

(?#...)

注釋.(?= re)

前向肯定界定符。如果所含正規表示式,以 ... 表示,在當前位置成功匹配時成功,否則失敗。但一旦所含表示式已經嘗試,匹配引擎根本沒有提高;模式的剩餘部分還要嘗試界定符的右邊。

(?! re)

前向否定界定符。與肯定界定符相反;當所含表示式不能在字串當前位置匹配時成功

(?> re)

匹配的獨立模式,省去回溯。

\w匹配字母數字

\w匹配非字母數字

\s匹配任意空白字元,等價於 [\t\n\r\f].

\s匹配任意非空字元

\d匹配任意數字,等價於 [0-9].

\d匹配任意非數字

\a匹配字串開始

\z匹配字串結束,如果是存在換行,只匹配到換行前的結束字串。c

\z匹配字串結束

\g匹配最後匹配完成的位置。

\b匹配乙個單詞邊界,也就是指單詞和空格間的位置。例如, 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。

\b匹配非單詞邊界。'er\b' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。

\n, \t, 等.

匹配乙個換行符。匹配乙個製表符。等

\1...\9

匹配第n個分組的子表示式。

\10匹配第n個分組的子表示式,如果它經匹配。否則指的是八進位制字元碼的表示式。

re.match與re.search的區別

re.match從字串的開始匹配,如果字串開始不符合正規表示式,則匹配失敗,函式返回none;而re.search匹配整個字串,直到找到乙個匹配。

舉例:匹配郵件位址

email = "

[email protected]

"m = re.search("

[0-9a-z]@[0-9a-z].[0-9a-z]

", email)

print(m.group())

匹配ip位址

ip = "

inet addr:172.16.0.109 bcast:172.16.255.255 mask:255.255.0.0

"m = re.search("

\d\.\d\.\d\.\d

",ip)

print(m.group())

正規表示式 正規表示式 總結

非負整數 d 正整數 0 9 1 9 0 9 非正整數 d 0 負整數 0 9 1 9 0 9 整數 d 非負浮點數 d d 正浮點數 0 9 0 9 1 9 0 9 0 9 1 9 0 9 0 9 0 9 1 9 0 9 非正浮點數 d d 0 0 負浮點數 正浮點數正則式 英文本串 a za z...

正規表示式 表示式

網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 13 0 9 14 5 7 15 0 1 2 3 5 6 7 8 9 18 0 1 2 3 5 6 7 8 9 d 號碼 x x x...

Linux正規表示式 編寫正規表示式

為了所有實用化的用途,你可以通過使用程式產生正確的結果。然而,並不意味著程式總是如你所願的那樣正確地工作。多數情況下,如果程式不能產生想要的輸出,可以斷定真正的問題 排除輸入或語法錯誤 在於如何描述想要的東西。換句話說,應該考慮糾正問題的地方是描述想要的結果的表示式。表示式不完整或者公式表示得不正確...