訂閱
糾錯(cuò)
加入自媒體

python的正則(一):簡單夠用的basic版

2020-07-14 17:05
ExASIC
關(guān)注

字符集合

[...] 字符集合,[]中的特殊字符表示字符本身

[^...] 字符集合以外的字符

分組匹配

| 或,比如A|B,如果A沒匹配到,就匹配B

匹配次數(shù)(重復(fù)次數(shù))

* 重復(fù)大于等于0次

+ 重復(fù)大于等于1次

? 重復(fù)0次或1次

非貪婪模式

*? 

+? 

??

默認(rèn)是貪婪模式,盡可能多的匹配。比如verilog里有很多個(gè)begin end塊。'begin.*end'是從第一個(gè)begin匹配到最后一個(gè)end,這往往不是我們想要的。如果我只需要匹配到第一個(gè)end,用非貪婪模式'begin.*?end'即可。

1begin

2...

3end

4begin

5...

6end

7begin

8...

9end

引用

(...) 括號(hào)中內(nèi)容可以再后續(xù)引用

基本規(guī)則介紹完畢。下面介紹幾個(gè)re模塊的函數(shù)。

re模塊的函數(shù)

在Perl中,匹配和替換用下面的語法:

1$str =~ m/.../;

2$str =~ s/.../.../;

re.search

而Python中,由于一切都是對(duì)象,我們需要使用re模塊中的方法(函數(shù))來實(shí)現(xiàn)。在re中有一個(gè)search函數(shù),第一個(gè)參數(shù)是pattern,就是正則,第二個(gè)參數(shù)是被匹配的字符串。需要注意的是:正則本身也是一個(gè)字符串,常使用raw字符串,即r'...',可以避免一些不必要的轉(zhuǎn)義。

1import re

2result = re.search(r'pattern', 'string', option)

如果匹配到了,result.group(0)則是匹配到的字符串;如果沒有匹配到,result則為None。所以,可以根據(jù)result是不是None來判斷是否查找到指定的字符串。例如:

1import re

2s = 'input wire a;input wire b;'

3result = re.search(r'wires+w+;', s)

4print(result.group(0))  # wire a

5if result: # if not result:

6    ...

在正則中加括號(hào)()來引用匹配的子字符串,例如下面的一段代碼,對(duì)verilog信號(hào)名a和b加括號(hào),則result.group(1)表示第一個(gè)括號(hào)匹配的子字符串a(chǎn),result.group(2)表示第二個(gè)括號(hào)匹配的子字符串b。而result.group(0)表示匹配的全部字符串。

1import re

2s = 'input wire a;input wire b;'

3result = re.search(r'wires+(w+).*wires(w+)', s, re.S)

4print(result.group(0))  # wire a;input wire b

5print(result.group(1))  # a

6print(result.group(2))  # b

由于原字符串帶有換行符,默認(rèn).*不能跨越換行符匹配,需要加上re.S的選項(xiàng)才可以。除了re.S還有其它一些常見選項(xiàng):

re.S    當(dāng)作單行(Singal line)來匹配

re.M   當(dāng)作多行(Multi line)來匹配

re.I     忽略(Ignore)大小寫

re.sub

正則的主要作用,是進(jìn)行高級(jí)查找和替換,查找是search(),替換就是sub(),如下所示:

1import re

2result = re.sub(r'pattern', r'replace', 'string', count=0, option)

在'string'中查找'pattern',并替換成'replace';

replace為空字符串''時(shí),等同于刪除;

count指定替換的次數(shù),默認(rèn)0是全部替換;

option與search中的相同,可以指定單行、多行、大小寫等;

返回值是替換后的新字符串,如果沒有匹配到,返回老字符串。

<上一頁  1  2  3  下一頁>  
聲明: 本文由入駐維科號(hào)的作者撰寫,觀點(diǎn)僅代表作者本人,不代表OFweek立場(chǎng)。如有侵權(quán)或其他問題,請(qǐng)聯(lián)系舉報(bào)。

發(fā)表評(píng)論

0條評(píng)論,0人參與

請(qǐng)輸入評(píng)論內(nèi)容...

請(qǐng)輸入評(píng)論/評(píng)論長度6~500個(gè)字

您提交的評(píng)論過于頻繁,請(qǐng)輸入驗(yàn)證碼繼續(xù)

  • 看不清,點(diǎn)擊換一張  刷新

暫無評(píng)論

暫無評(píng)論

人工智能 獵頭職位 更多
掃碼關(guān)注公眾號(hào)
OFweek人工智能網(wǎng)
獲取更多精彩內(nèi)容
文章糾錯(cuò)
x
*文字標(biāo)題:
*糾錯(cuò)內(nèi)容:
聯(lián)系郵箱:
*驗(yàn) 證 碼:

粵公網(wǎng)安備 44030502002758號(hào)