五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)
data:image/s3,"s3://crabby-images/90ec5/90ec5e9da3eab1696ff8fd40f6496775f7cc904e" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
Python中正则表达式 在 re 模块 — Regular expression operations
Python中的re模块提供与Perl类似的正则表达式匹配操作,但是要注意的是:正则匹配时 表达式和要查询的字符串可以是 unicode字符串,也可是8-bit 字符串,但是两种模式不可以混合使用,也就是说 表达式和要查询的字符串必须一致。
正则表达式特殊字符:
.(点): 默认模式下,.可以匹配除了换行外的所有字符,如果需要匹配换行,可以传参 re.DOTALL。
data:image/s3,"s3://crabby-images/09a41/09a4119478d9064beb4efc1384629d4075d57001" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
运行结果:
data:image/s3,"s3://crabby-images/a4e24/a4e2432fa4c7e88c0fd610bb4dce2d11d3cb2cd9" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
^:只匹配字符串的开始位置,可以使用re.MULTILINE(匹配多行),匹配每一行的开始位置。
data:image/s3,"s3://crabby-images/f1717/f171766f5c5a33f11f901685f5a7822647340a86" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
代码中每一行的开头都有ae字符串,所以开启多行模式后,会匹配两个结果。
运行结果:
data:image/s3,"s3://crabby-images/43ff4/43ff42e4b677940e89e1d36ed7f840a7dd1a6c74" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
$ : 与^相反,匹配字符串的结束位置,可以使用re.MULTILINE(匹配多行),匹配每一行的结尾位置。
data:image/s3,"s3://crabby-images/a995c/a995c7379ddfa30266927c1e62706fd06791bc37" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
运行结果:
data:image/s3,"s3://crabby-images/b49d4/b49d4d3de56def5ff2d1a7be5e4b5ced98cc021b" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
.: 匹配0个或多个的表达式
data:image/s3,"s3://crabby-images/b1c63/b1c63bce95a1abb3325a1fe1fa847d63ff035cd9" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
运行结果:
data:image/s3,"s3://crabby-images/1d178/1d178dce6d4955afc00b6cd0bfd5f62a0e9db780" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
分析:c*表示,匹配字符"c"0次或者多次,也就是说会匹配 a,ac。
+: 匹配1个或多个的表达式
data:image/s3,"s3://crabby-images/a776e/a776e4eee06eb243972d3211981df001b4023191" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
运行结果:
data:image/s3,"s3://crabby-images/9a29d/9a29db9be840abd6e7131f23a945048efcf1c9ab" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
分析:匹配字符a并且c一次或者多次,所以会匹配ac或者accccc
? : 匹配0次或1次,非贪婪方式
data:image/s3,"s3://crabby-images/5b4c6/5b4c67c55dbee0814f7cfa1669d03b24444abb76" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
运行结果:
分析:表达式“ac?” 匹配字符a或者ac(?只匹配0次或者1次,比较懒惰,不像上面的+或者*会匹配多次)
.? : 这三个特殊符号上面都讲过了,.是匹配任意字符匹配0次或者多次,连在一起使用也就是匹配全文了,加上?号,非贪婪模式匹配,将尽可能少的匹配结果。
data:image/s3,"s3://crabby-images/bb23a/bb23af70b35daa706564307e48561f0f497de428" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
匹配结果:
data:image/s3,"s3://crabby-images/c5282/c528241e2cb98331772cee7bb4478a9e3b1ea7b0" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
image
4小结正则匹配的语法是通用的,大家学会这些特殊字符,无论什么语言都能迅速入门。所以有必要好好学习一下。
柠檬为大家准备了一些python的学习教程分享,希望可以帮助到大家。
data:image/s3,"s3://crabby-images/306ea/306ea1b9b805e4382c229e30a4e53c69d17cc573" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"
data:image/s3,"s3://crabby-images/07c1b/07c1baa74b9cecb8e8471a99ef433b3b02e17008" alt="五分钟学会使用Python爬虫正则表达式(附全套学习资料教程) 五分钟学会使用Python爬虫正则表达式(附全套学习资料教程)"