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