學會簡單的使用Python爬蟲正則表示式!
學完此次課程,我能做什麼?此次課程我們會系統的學習一下python的正則表示式,以及可以根據自己的需求寫出正確的正則表示式。2學習此次課程,需要多久?15-20分鐘,建議每個表示式跟著實踐一下,加深印象3課程內容
學習Python中有不明白推薦加入交流群
號:864573496 群裡有志同道合的小夥伴,互幫互助, 群裡有不錯的視訊學習教程和PDF!
Python中正則表示式 在 re 模組 — Regular expression operations
Python中的re模組提供與Perl類似的正則表示式匹配操作,但是要注意的是:正則匹配時 表示式和要查詢的字串可以是 unicode字串,也可是8-bit 字串,但是兩種模式不可以混合使用,也就是說 表示式和要查詢的字串必須一致。
正則表示式特殊字元:
.(點): 預設模式下,.可以匹配除了換行外的所有字元,如果需要匹配換行,可以傳參 re.DOTALL。

image
執行結果:

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

image
程式碼中每一行的開頭都有ae字串,所以開啟多行模式後,會匹配兩個結果。
執行結果:

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

image
執行結果:

image
.: 匹配0個或多個的表示式

image
執行結果:

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

image
執行結果:

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

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

image
匹配結果:

image
4小結正則匹配的語法是通用的,大家學會這些特殊字元,無論什麼語言都能迅速入門。所以有必要好好學習一下。