日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

python3-正则表达式基本使用方法(附案例)_python正则表达式

發(fā)布時(shí)間:2025/5/22 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python3-正则表达式基本使用方法(附案例)_python正则表达式 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

python正則表達(dá)式

一、re模塊

python中處理正則表達(dá)式的一個(gè)模塊,通過(guò)re模塊的方法,把正則表達(dá)式pattern編譯成正則

對(duì)象,以便使用正則對(duì)象的方法

1.compile加速

re.compile(pattern[, flags])

說(shuō)明:將正則規(guī)則編譯成一個(gè)Pattern對(duì)象,以供接下來(lái)使用;第一個(gè)參數(shù)是規(guī)則式,第二個(gè)參數(shù)是規(guī)則選項(xiàng);返回一個(gè)Pattern對(duì)象

1)參數(shù)flag是匹配模式,取值可以使用按位或運(yùn)算符“|”表示同時(shí)生效,比如:re.I | re.M

2)flag的可選值:

re.I(re.IGNORECASE): 忽略大小寫(xiě)(括號(hào)內(nèi)是完整寫(xiě)法,下同)

M(MULTILINE): ? ? ?多行模式,改變'^'和'$'的行為

S(DOTALL): ? ? ? ?點(diǎn)任意匹配模式,改變'.'的行為

L(LOCALE): ? ? ? ?使預(yù)定字符類(lèi) \w \W \b \B \s \S 取決于當(dāng)前區(qū)域設(shè)定

U(UNICODE): ? ? ? ?使預(yù)定字符類(lèi) \w \W \b \B \s \S \d \D 取決于unicode定義的字符屬性

X(VERBOSE): ? ? ? ?詳細(xì)模式,正則表達(dá)式可以多行,忽略空白字符,可以加入注釋

例子:

a和b等價(jià)

a = re.compile(r"""\d +? # the integral part

\.??? # the decimal point

\d *? # some fractional digits""", re.X)

b = re.compile(r"\d+\.\d*")

2.正則原生符r

表示這個(gè)字符串中間的特殊字符不用轉(zhuǎn)義,比如要表示‘\n’,可以這樣:r'\n',或者不用原生字符,而是用字符串:‘\\n

例子:

a =r"\n"

b ="\n"

c ="\\n"

printa

printb

printc

結(jié)果:

\n

\n

3.re模塊compile后,patten對(duì)象常用方法

3.1.match()方法----匹配開(kāi)始

格式:match(string[, pos[, endpos]])

參數(shù):

1)string: ? ?匹配使用的字符串

2)pos: ? ? ? 開(kāi)始搜索的索引(即開(kāi)始搜索string的下標(biāo))默認(rèn)從開(kāi)頭匹配,如沒(méi)有返回None

3)endpos: ? ?結(jié)束搜索的索引

例子

importre

pattern = re.compile(r"\w*(hello.*)(world.*)")

result = pattern.match("aahello world huang")

print(result.groups())

結(jié)果:

('hello ', 'world huang')

3.2.search()方法----匹配任意位置

從string的pos下標(biāo)處起嘗試匹配pattern,如果pattern結(jié)束時(shí)仍可匹配,則返回一個(gè)Match對(duì)象;若無(wú)法匹配,則將pos加1后重新嘗試匹配;直到pos=endpos時(shí)仍無(wú)法匹配則返回None

格式:search(string[, pos[, endpos]])

例子:

importre

pattern = re.compile(r"\w*(hello.*)(world.*)")

result = pattern.search("aahello world huang")

print(result.groups())

結(jié)果:

('hello ', 'world huang')

3.3.findall()方法----匹配所有對(duì)象

返回匹配到的全部子串,列表形式

格式:

findall(string[, pos[, endpos]])

例子:

importre

pattern = re.compile(r"\d+")

result = pattern.findall("one1two2three3four")

printresult

結(jié)果:

['1', '2', '3']

3.4.finditer()方法

按順序返回匹配結(jié)果(Match對(duì)象)的迭代器

格式:finditer(string[, pos[, endpos]])

例子:

importre

pattern = re.compile(r"\d+")

result = pattern.finditer("one1two2three3four")

printtype(result)

forminresult:

printtype(m)

print(m.group())

結(jié)果:

1

2

3

# 3.5.split()方法

以匹配到的子串作為分隔符,返回列表

格式:split(string[, maxsplit])

參數(shù):

maxsplit:用于指定最大分割次數(shù),不指定將全部分割

例子:

importre

pattern = re.compile(r"\d+")

result = pattern.split("one1two2three3four")

printresult

結(jié)果:

['one', 'two', 'three', 'four']

# 3.6.sub()方法

替換匹配結(jié)果的字符串

格式:sub(repl, string[, count])

參數(shù):

1)使用repl替換string中每一個(gè)匹配的子串后返回替換后的字符串:

當(dāng)repl是一個(gè)字符串時(shí),可以使用\id或\g、\g引用分組,但不能使用編號(hào)0;

當(dāng)repl是一個(gè)方法時(shí),這個(gè)方法應(yīng)當(dāng)只接受一個(gè)參數(shù)(Match對(duì)象),并返回一個(gè)字符串用于替換(返回的字符串中不能再引用分組)

2)count用于指定最多替換次數(shù),不指定時(shí)全部替換

例子:

importre

p = re.compile(r'(\w+) (\w+)')

s ='i say, hello world!'

print(p.sub(r'\2 \1', s))

結(jié)果:

say i, world hello!

4.re模塊方法

說(shuō)明:用法同compile后,patten常用方法一樣

4.1.match()和serch()函數(shù)

格式:

match( rule , targetString [,flag] )#?從開(kāi)始位置開(kāi)始匹配,如果開(kāi)頭沒(méi)有,則返回?zé)o

search( rule , targetString [,flag] )#?搜索整個(gè)字符串

參數(shù):

第一個(gè)是正則規(guī)則;第二個(gè)是目標(biāo)字符串;第三個(gè)是選項(xiàng)(同compile函數(shù)的選項(xiàng))

返回:

若成功,則返回一個(gè)Match對(duì)象;若失敗,則無(wú)返回

4.2.findall()和finditer()函數(shù)

格式:

findall( rule , targetString [,flag] )#?返回所有匹配的字符串,并存為一個(gè)列表

finditer( rule , target [,flag] )#?返回一個(gè)匹配的字符串迭代器

4.3.split()函數(shù)

切片,返回一個(gè)被切完的子字符串的列表

格式:

split( rule , target [,maxsplit] )

4.4.sub()函數(shù)

替換字符串

格式:

sub ( rule , replace , target [,count] )#?返回一個(gè)被替換的字符串

subn(rule , replace , target [,count] )#?返回一個(gè)元組,第一個(gè)元素是被替換的字符串,第二個(gè)次數(shù)

5.match對(duì)象和group

每個(gè)組都有一個(gè)序號(hào),按定義時(shí)從左到右的順序從1開(kāi)始編號(hào),0表示整個(gè)正則表達(dá)式本身

group([index|id])#?獲取匹配的組號(hào),缺省返回組0,表示全部值

groups()# 返回全部的組

groupdict()# 返回以組名為key,匹配的內(nèi)容為values的字典

1)通過(guò)數(shù)字分組

2)通過(guò)別名分組

例子:

importre

prog = re.compile(r'(?Pabc)(.*)(?P=tagname)')

result = prog.match('abc1234567890abc')

print"## groups() ############"

print(result.groups())

print""

print"## group('tagname') ############"

printresult.group('tagname')

print""

print"## group(1) ############"

print(result.group(1))

print""

print"## group(2) ############"

print(result.group(2))

print""

print"## groupdict() ############"

print(result.groupdict())

結(jié)果:

## groups() ############

('abc', '1234567890')

## group('tagname') ############

abc

## group(1) ############

abc

## group(2) ############

1234567890

## groupdict() ############

{'tagname': 'abc'}

二、正則表達(dá)式分組

分組就是用一對(duì)圓括號(hào)“()”括起來(lái)的正則表達(dá)式,匹配出的內(nèi)容就表示一個(gè)分組。從正則表達(dá)式的左邊開(kāi)始看,看到的第一個(gè)左括號(hào)“(”表示第一個(gè)分組,第二個(gè)表示第二個(gè)分組,依次類(lèi)推,需要注意的是,有一個(gè)隱含的全局分組(就是0),就是整個(gè)正則表達(dá)式。

分完組以后,要想獲得某個(gè)分組的內(nèi)容,直接使用group(num)和groups()函數(shù)去直接提取就行

1.命名分組

命名分組就是給具有默認(rèn)分組編號(hào)的組另外再給一個(gè)別名。命名分組的語(yǔ)法格式如下:

(?P正則表達(dá)式) ? #name是一個(gè)合法的標(biāo)識(shí)符

2.后向引用

當(dāng)用”()”定義了一個(gè)正則表達(dá)式組后,正則引擎則會(huì)把被匹配的組按照順序編號(hào),存入緩存。這樣我們想在后面對(duì)已經(jīng)匹配過(guò)的內(nèi)容進(jìn)行引用時(shí),就可以用”\數(shù)字”的方式或者是通過(guò)命名分組進(jìn)行”(?P=name)“進(jìn)行引用。\1表示引用第一個(gè)分組,\2引用第二個(gè)分組,以此類(lèi)推,\n引用第n個(gè)組。而\0則引用整個(gè)被匹配的正則表達(dá)式本身

總結(jié)

以上是生活随笔為你收集整理的python3-正则表达式基本使用方法(附案例)_python正则表达式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。