Python 正則表達(dá)式
正則表達(dá)式是一個(gè)特殊的字符序列,它能幫助你方便的檢查一個(gè)字符串是否與某種模式匹配。
Python 自1.5版本起增加了re 模塊,它提供 Perl 風(fēng)格的正則表達(dá)式模式。
re 模塊使 Python 語(yǔ)言擁有全部的正則表達(dá)式功能。
compile 函數(shù)根據(jù)一個(gè)模式字符串和可選的標(biāo)志參數(shù)生成一個(gè)正則表達(dá)式對(duì)象。該對(duì)象擁有一系列方法用于正則表達(dá)式匹配和替換。
re 模塊也提供了與這些方法功能完全一致的函數(shù),這些函數(shù)使用一個(gè)模式字符串做為它們的第一個(gè)參數(shù)。
本章節(jié)給大家介紹Python正則表達(dá)式中的re.S的作用,具體內(nèi)容如下所示:
在Python的正則表達(dá)式中,有一個(gè)參數(shù)為re.S。它表示“.”(不包含外側(cè)雙引號(hào),下同)的作用擴(kuò)展到整個(gè)字符串,包括“\n”。看如下代碼:
import re
a = '''asdfsafhellopass:
234455
worldafdsf
'''
b = re.findall('hello(.*?)world',a)
c = re.findall('hello(.*?)world',a,re.S)
print 'b is ' , b
print 'c is ' , c
運(yùn)行結(jié)果如下:
b is []
c is ['pass:\n\t234455\n\t']
正則表達(dá)式中,“.”的作用是匹配除“\n”以外的任何字符,也就是說,它是在一行中進(jìn)行匹配。這里的“行”是以“\n”進(jìn)行區(qū)分的。a字符串有每行的末尾有一個(gè)“\n”,不過它不可見。
如果不使用re.S參數(shù),則只在每一行內(nèi)進(jìn)行匹配,如果一行沒有,就換下一行重新開始,不會(huì)跨行。而使用re.S參數(shù)以后,正則表達(dá)式會(huì)將這個(gè)字符串作為一個(gè)整體,將“\n”當(dāng)做一個(gè)普通的字符加入到這個(gè)字符串中,在整體中進(jìn)行匹配。
在re.py庫(kù)的介紹中有以下語(yǔ)句:
“.” Matches any character except a newline.
S DOTALL “.” matches any character at all, including the newline.
您可能感興趣的文章:- python re正則匹配網(wǎng)頁(yè)中圖片url地址的方法
- python中正則表達(dá)式 re.findall 用法
- python中redis查看剩余過期時(shí)間及用正則通配符批量刪除key的方法
- Python3正則匹配re.split,re.finditer及re.findall函數(shù)用法詳解
- Python3中正則模塊re.compile、re.match及re.search函數(shù)用法詳解
- Python正則表達(dá)式和re庫(kù)知識(shí)點(diǎn)總結(jié)