国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

python的正則表達(dá)式re模塊的常用方法

2019-11-25 18:39:59
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
1.re的簡(jiǎn)介
使用python的re模塊,盡管不能滿足所有復(fù)雜的匹配情況,但足夠在絕大多數(shù)情況下能夠有效地實(shí)現(xiàn)對(duì)復(fù)雜字符串的分析并提取出相關(guān)信息。python 會(huì)將正則表達(dá)式轉(zhuǎn)化為字節(jié)碼,利用 C 語(yǔ)言的匹配引擎進(jìn)行深度優(yōu)先的匹配。

復(fù)制代碼 代碼如下:

import re
print re.__doc__


可以查詢r(jià)e模塊的功能信息,下面會(huì)結(jié)合幾個(gè)例子說(shuō)明。

2.re的正則表達(dá)式語(yǔ)法

正則表達(dá)式語(yǔ)法表如下:

語(yǔ)法 意義 說(shuō)明
"." 任意字符
"^" 字符串開(kāi)始 '^hello'匹配'helloworld'而不匹配'aaaahellobbb'
"$" 字符串結(jié)尾 與上同理
"*" 
0 個(gè)或多個(gè)字符(貪婪匹配)
<*>匹配<title>chinaunix</title>
"+"
1 個(gè)或多個(gè)字符(貪婪匹配
與上同理
"?"
0 個(gè)或多個(gè)字符(貪婪匹配
與上同理
*?,+?,??
以上三個(gè)取第一個(gè)匹配結(jié)果(非貪婪匹配 <*>匹配<title>
{m,n}
對(duì)于前一個(gè)字符重復(fù)m到n次,{m}亦可
a{6}匹配6個(gè)a、a{2,4}匹配2到4個(gè)a
{m,n}?
對(duì)于前一個(gè)字符重復(fù)m到n次,并取盡可能少
‘a(chǎn)aaaaa'中a{2,4}只會(huì)匹配2個(gè)
"http://"
特殊字符轉(zhuǎn)義或者特殊序列
[]
表示一個(gè)字符集 [0-9]、[a-z]、[A-Z]、[^0]
"|"
A|B,或運(yùn)算
(...)
匹配括號(hào)中任意表達(dá)式
(?#...)
注釋,可忽略
(?=...)
Matches if ... matches next, but doesn't consume the string.
'(?=test)'  在hellotest中匹配hello
(?!...)
Matches if ... doesn't match next.
'(?!=test)'  若hello后面不為test,匹配hello
(?<=...) 
Matches if preceded by ... (must be fixed length).
'(?<=hello)test'  在hellotest中匹配test
(?<!...)
Matches if not preceded by ... (must be fixed length).
'(?<!hello)test'  在hellotest中不匹配test

正則表達(dá)式特殊序列表如下:

特殊序列符號(hào)
意義
/A
只在字符串開(kāi)始進(jìn)行匹配
/Z
只在字符串結(jié)尾進(jìn)行匹配
/b
匹配位于開(kāi)始或結(jié)尾的空字符串
/B
匹配不位于開(kāi)始或結(jié)尾的空字符串
/d
相當(dāng)于[0-9]
/D
相當(dāng)于[^0-9]
/s
匹配任意空白字符:[/t/n/r/r/v]
/S
匹配任意非空白字符:[^/t/n/r/r/v]
/w
匹配任意數(shù)字和字母:[a-zA-Z0-9]
/W
匹配任意非數(shù)字和字母:[^a-zA-Z0-9]

3.re的主要功能函數(shù)

    常用的功能函數(shù)包括:compile、search、match、split、findall(finditer)、sub(subn)
compile
re.compile(pattern[, flags])
作用:把正則表達(dá)式語(yǔ)法轉(zhuǎn)化成正則表達(dá)式對(duì)象
flags定義包括:
re.I:忽略大小寫(xiě)
re.L:表示特殊字符集 /w, /W, /b, /B, /s, /S 依賴于當(dāng)前環(huán)境
re.M:多行模式
re.S:' . '并且包括換行符在內(nèi)的任意字符(注意:' . '不包括換行符)
re.U: 表示特殊字符集 /w, /W, /b, /B, /d, /D, /s, /S 依賴于 Unicode 字符屬性數(shù)據(jù)庫(kù)

search
re.search(pattern, string[, flags])
search (string[, pos[, endpos]])
作用:在字符串中查找匹配正則表達(dá)式模式的位置,返回 MatchObject 的實(shí)例,如果沒(méi)有找到匹配的位置,則返回 None。

match
re.match(pattern, string[, flags])
match(string[, pos[, endpos]])
作用:match() 函數(shù)只在字符串的開(kāi)始位置嘗試匹配正則表達(dá)式,也就是只報(bào)告從位置 0 開(kāi)始的匹配情況,而 search() 函數(shù)是掃描整個(gè)字符串來(lái)查找匹配。如果想要搜索整個(gè)字符串來(lái)尋找匹配,應(yīng)當(dāng)用 search()。

下面是幾個(gè)例子:
例:最基本的用法,通過(guò)re.RegexObject對(duì)象調(diào)用

復(fù)制代碼 代碼如下:

#!/usr/bin/env python
import re
r1 = re.compile(r'world')
if r1.match('helloworld'):
    print 'match succeeds'
else:
    print 'match fails'
if r1.search('helloworld'):
    print 'search succeeds'
else:
    print 'search fails'

說(shuō)明一下:r是raw(原始)的意思。因?yàn)樵诒硎咀址杏幸恍┺D(zhuǎn)義符,如表示回車(chē)'/n'。如果要表示/表需要寫(xiě)為'//'。但如果我就是需要表示一個(gè)'/'+'n',不用r方式要寫(xiě)為:'//n'。但使用r方式則為r'/n'這樣清晰多了。

例:設(shè)置flag

復(fù)制代碼 代碼如下:

#r2 = re.compile(r'n$', re.S)
#r2 = re.compile('/n$', re.S)
r2 = re.compile('World$', re.I)
if r2.search('helloworld/n'):
    print 'search succeeds'
else:
    print 'search fails'

例:直接調(diào)用
復(fù)制代碼 代碼如下:

if re.search(r'abc','helloaaabcdworldn'):
    print 'search succeeds'
else:
    print 'search fails'

split
re.split(pattern, string[, maxsplit=0, flags=0])
split(string[, maxsplit=0])
作用:可以將字符串匹配正則表達(dá)式的部分割開(kāi)并返回一個(gè)列表
例:簡(jiǎn)單分析ip

復(fù)制代碼 代碼如下:

#!/usr/bin/env python
import re
r1 = re.compile('W+')
print r1.split('192.168.1.1')
print re.split('(W+)', '192.168.1.1')
print re.split('(W+)', '192.168.1.1', 1)

結(jié)果如下:
['192', '168', '1', '1']
['192', '.', '168', '.', '1', '.', '1']
['192', '.', '168.1.1']

findall
re.findall(pattern, string[, flags])
findall(string[, pos[, endpos]])
作用:在字符串中找到正則表達(dá)式所匹配的所有子串,并組成一個(gè)列表返回
例:查找[]包括的內(nèi)容(貪婪和非貪婪查找)

復(fù)制代碼 代碼如下:

#!/usr/bin/env python
import re
r1 = re.compile('([.*])')
print re.findall(r1, "hello[hi]heldfsdsf[iwonder]lo")
r1 = re.compile('([.*?])')
print re.findall(r1, "hello[hi]heldfsdsf[iwonder]lo")
print re.findall('[0-9]{2}',"fdskfj1323jfkdj")
print re.findall('([0-9][a-z])',"fdskfj1323jfkdj")
print re.findall('(?=www)',"afdsfwwwfkdjfsdfsdwww")
print re.findall('(?<=www)',"afdsfwwwfkdjfsdfsdwww")

finditer
re.finditer(pattern, string[, flags])
finditer(string[, pos[, endpos]])
說(shuō)明:和 findall 類似,在字符串中找到正則表達(dá)式所匹配的所有子串,并組成一個(gè)迭代器返回。同樣 RegexObject 有:

sub
re.sub(pattern, repl, string[, count, flags])
sub(repl, string[, count=0])
說(shuō)明:在字符串 string 中找到匹配正則表達(dá)式 pattern 的所有子串,用另一個(gè)字符串 repl 進(jìn)行替換。如果沒(méi)有找到匹配 pattern 的串,則返回未被修改的 string。Repl 既可以是字符串也可以是一個(gè)函數(shù)。
例:

復(fù)制代碼 代碼如下:

#!/usr/bin/env python
import re
p = re.compile('(one|two|three)')
print p.sub('num', 'one word two words three words apple', 2)

subn
re.subn(pattern, repl, string[, count, flags])
subn(repl, string[, count=0])

說(shuō)明:該函數(shù)的功能和 sub() 相同,但它還返回新的字符串以及替換的次數(shù)。同樣 RegexObject 有:

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 城口县| 卢龙县| 镇雄县| 利辛县| 枞阳县| 乌鲁木齐市| 宜兴市| 株洲县| 南溪县| 噶尔县| 阳新县| 集安市| 苗栗市| 共和县| 岑巩县| 白沙| 德安县| 黑山县| 五指山市| 祁门县| 通江县| 无为县| 六盘水市| 临沭县| 巍山| 临海市| 民和| 竹北市| 富川| 营山县| 梅河口市| 玉屏| 江北区| 大邑县| 嘉荫县| 县级市| 萨嘎县| 禹州市| 泉州市| 大名县| 远安县|