python正则表达式

爬虫程序:能自动从相关网页中搜索与提取所需数据的程序。

爬虫工作程序:获取该网站的HTML代码,解析HTML代码,提取代码中的数据。

爬虫程序的关键就是解析与提取html中的数据,而正则表达式就是解析与提取HTMl代码中数据的一种较为简单的方法。

一、正则表达式

1、 \d :匹配0~9的一个数值

python 复制代码
import re
reg = r "\d"
m = re.search(reg,"abc12345cd")
print(m)

结果:

python 复制代码
<re.Match object; span=(3, 4), match='1'>

匹配结果是:1

2、+ :字符+可以重复前面的一个匹配字符一次或者多次

python 复制代码
import re
reg = r"b\d+"
m = re.search(reg,"a12b1234")
print(m)

结果:

python 复制代码
<re.Match object; span=(3, 8), match='b1234'>

匹配结果是:b1234
注意: r"b\d+"表示第一个字符要匹配 "b" ,后面是连续的过个数值,因此匹配的是b1234

3、* 表示重复前边的一个匹配字符0次或者多次。

注:加号和星号的匹配机制类似,但有区别在于 * 可以匹配到0次。

python 复制代码
import re
reg = r"ab+"
m = re.search(reg, "acabc")
print(m)
reg1 = r"ab*"
m1 = re.search(reg1, "acabc")
print(m1)

结果:

python 复制代码
<re.Match object; span=(2, 4), match='ab'>
<re.Match object; span=(0, 1), match='a'>

r "ab+ "的匹配机制是匹配到"ab":。

r "ab*"的匹配是"a",b可以是0或者多次。

4、? :表示重复前面的一个匹配字符0次或者1次

python 复制代码
import re
reg = r"ab?"
m = re.search(reg, "abbcabc")
print(m)

结果:

python 复制代码
<re.Match object; span=(0, 2), match='ab'>

匹配结果是ab,但是只匹配了1次

5、字符 . 代表任意字符,但是没有特别声明时,不代表任何字符

python 复制代码
import re
s = "xaxby"
m = re.search(r"a.b", s)
print(m)

结果:

python 复制代码
<re.Match object; span=(1, 4), match='axb'>

__.__代表了字符"x"

6、 " | "表示 | 符号左右两个部分任意匹配一个

python 复制代码
import re
s = "xaababy"
m = re.search(r"ab|ba", s)
print(m)

结果:

python 复制代码
<re.Match object; span=(2, 4), match='ab'>

匹配"ab"或者匹配"ba"都可以

7、特殊字符使用" \ "引导

例如

  • \r 表示回车符,
  • \n 表示换行符 ,
  • \t 表示制表符 ,
  • \ \ 表示反斜线本身。

8、字符 \b 表示单词结尾,各种空白字符或者字符串结尾都是单词结尾。

python 复制代码
import re

reg = r"car\b"
m = re.search(reg, "The car is black")
print(m)

结果:

python 复制代码
<re.Match object; span=(4, 7), match='car'>

匹配结果是 "car",因为car后边有一个空格

9、[ ]中的字符可以对任选一个

如果字符是ASCII中的连续的一组,那么可以使用"_"连接。

例如:[0-9]表示0-9中的一个数字。

[A- Z]表示A- Z中的一个大写字符。

[0- 9A~ Z]表示0- 9中的要给数字或者A~Z中的一个大写字母。

python 复制代码
import re
reg = r"x[0-9]y"
m = re.search(reg, "xyx2y")
print(m)

结果:

python 复制代码
<re.Match object; span=(2, 5), match='x2y'>

匹配结果是x2y

10、^出现在[ ]中第一个字符位置,表示取反

例如[^ab0-9]表示不是a,b,也不是0-9之间的数字。

python 复制代码
import re
reg = r"x[^ab0-9]y"
m = re.search(reg, "xayx2yxcy")
print(m)

结果:

python 复制代码
<re.Match object; span=(6, 9), match='xcy'>

匹配结果是"xcy"

11、\s匹配任何空白字符,

\s等价于[\r\b\x20\t\f\v]

12、\w匹配下划线、英文、数字等字符

\w等价于[a-zA-Z0-9]

python 复制代码
import re
reg = r"\w+"
m = re.search(reg, "python is easy")
print(m)

结果:

python 复制代码
<re.Match object; span=(0, 6), match='python'>

匹配结果是python,因为加号匹配1次或者多次,\w匹配下划线、英文、数字等字符

13、^匹配字符串的开头位置。

python 复制代码
import re
reg = r"^ab"
m = re.search(reg, "cabcab")
print(m)

结果:

python 复制代码
None

因为没有以ab开头的字母

14、$ 匹配字符的结尾位置

python 复制代码
import re
reg = r"ab$"
m = re.search(reg, "cabcab")
print(m)

结果:

python 复制代码
<re.Match object; span=(4, 6), match='ab'>

经常匹配字符串的结尾位置

15、() 经常与+,*, ? , 等一起使用,对()内的部分进行重复。

python 复制代码
import re
reg = r"(ab)+"
m = re.search(reg, "ababcab")
print(m)

结果:

python 复制代码
<re.Match object; span=(0, 4), match='abab'>

匹配结果是abab,因为+对ab进行了重复。

相关推荐
SONGW201812 分钟前
其他节点使用kubectl访问集群,kubeconfig配置文件 详解
java·开发语言
Source.Liu22 分钟前
【用Rust写CAD】第二章 第一节 Rust注释
开发语言·rust
python15635 分钟前
Python Pandas内存管理技巧助力高效处理大数据
大数据·python·pandas
Python大数据分析@38 分钟前
学习python中的pandas有没有好的教程推荐?
python·学习·pandas
哪 吒40 分钟前
华为OD机试 - 无重复字符的元素长度乘积的最大值(Python/JS/C/C++ 2024 C卷 100分)
javascript·python·华为od
世间万物皆对象1 小时前
Java 基础教学:高级特性与实战-集合框架
java·开发语言
不爱吃米饭_1 小时前
如何优雅处理异常?处理异常的原则
java·开发语言·spring boot
科研小达人1 小时前
Langchain调用模型使用FAISS
python·chatgpt·langchain·faiss
Biomamba生信基地1 小时前
jupyter如何切换内核
ide·python·jupyter
T0uken1 小时前
【ESP32+MicroPython】网络编程基础
网络·python·esp32