按照之前的課程安排,此次課程應(yīng)該講python基礎(chǔ)第十六講爬蟲,但是如果正則一筆帶過大家可能還是沒辦法寫出自己想要實現(xiàn)的結(jié)果,所以把正則匹配詳解提前學習一下,此次課程的學習路線會翻譯官方的re模塊文檔,并且篩選出重點知識,完善文章中沒有的DEMO。
學完此次課程,我能做什么?
此次課程我們會系統(tǒng)的學習一下python的正則表達式,以及可以根據(jù)自己的需求寫出正確的正則表達式。
學習此次課程,需要多久?
15-20分鐘,建議每個表達式跟著實踐一下,加深印象
課程內(nèi)容
Python中正則表達式 在 re 模塊 — Regular expression operations
Python中的re模塊提供與Perl類似的正則表達式匹配操作,但是要注意的是
需要注意的是:正則匹配時 表達式和要查詢的字符串可以是 unicode字符串,也可是8-bit 字符串,但是兩種模式不可以混合使用,也就是說 表達式和要查詢的字符串必須一致。
正則表達式特殊字符:
.(點): 默認模式下,.可以匹配除了換行外的所有字符,如果需要匹配換行,可以傳參 re.DOTALL。

運行結(jié)果:

^:只匹配字符串的開始位置,可以使用re.MULTILINE(匹配多行),匹配每一行的開始位置。

代碼中每一行的開頭都有ae字符串,所以開啟多行模式后,會匹配兩個結(jié)果。
運行結(jié)果:

$ : 與^相反,匹配字符串的結(jié)束位置,可以使用re.MULTILINE(匹配多行),匹配每一行的結(jié)尾位置。

運行結(jié)果:

- : 匹配0個或多個的表達式

運行結(jié)果:

分析:c*表示,匹配字符"c"0次或者多次,也就是說會匹配 a,ac。
- : 匹配1個或多個的表達式

運行結(jié)果:

分析:匹配字符a并且c一次或者多次,所以會匹配ac或者accccc
? : 匹配0次或1次,非貪婪方式

運行結(jié)果:

分析:表達式“ac?” 匹配字符a或者ac(?只匹配0次或者1次,比較懶惰,不像上面的+或者*會匹配多次)
.? : 這三個特殊符號上面都講過了,.是匹配任意字符匹配0次或者多次,連在一起使用也就是匹配全文了,加上?號,非貪婪模式匹配,將盡可能少的匹配結(jié)果。

匹配結(jié)果:

小結(jié)
正則匹配的語法是通用的,大家學會這些特殊字符,無論什么語言都能迅速入門。所以有必要好好學習一下。
接下來學習什么?
Python的基礎(chǔ)教程暫時告一段落。
關(guān)注公眾號,回復 Python基礎(chǔ) 下載全部代碼+PDF版電子書
