python项目实战11-正则表达式基础

1.正则表达式:是一种用特定语法规则组成的字符串模式,用来描述、匹配或替换文本中符合某种规则的字符序列,可以理解为是专门用于文本处理的"高级查找和匹配公式"。

(1) 字符串前的r标识什么意思?

r 表示当前这个字符串中的转义字符无效,作为普通字符串使用

(2) re模块提供的如下三个函数的作用与区别 ?

match("正则表达式", "文本字符串"):从字符串的开头开始匹配

search("正则表达式", "文本字符串"):从任意位置开始,搜索第一个匹配项

findall("正则表达式", "文本字符串"):从任意位置开始,搜索所有匹配项

s1 = "18809090000是我的手机号, 你记住了吗? 我的另一个手机号是18800008888,两个QQ号分别是155998992 和 18809091293821 你记住了吗?"

s2 = "我的手机号是18809090000, 你记住了吗? 我的另一个手机号是18800008888,两个QQ号分别是155998992 和 18809091293821 你记住了吗?"

(1) match:从字符串的开头开始匹配(匹配第一个匹配项)

python 复制代码
import re

s1 = "18809090000是我的手机号, 你记住了吗? 我的另一个手机号是18800008888,两个QQ号分别是155998992 和 18809091293821 你记住了吗?"
s2 = "我的手机号是18809090000, 你记住了吗? 我的另一个手机号是18800008888,两个QQ号分别是155998992 和 18809091293821 你记住了吗?"

# match - 从字符串的开头开始匹配(匹配第一个匹配项) ----> Match 对象
# r"1[3-9]\d{9}" 表示第1位是1(1),第2位在3-9之间([3-9]),第3-11位为数字(\d{9})
# r"1[3-9]\d{9}" ==>  "1[3-9]\\d{9}" 其中r表示字符串中的反斜杠为本身含义,而不是转义字符
result = re.match(r"1[3-9]\d{9}", s1)
print(result.group()) # 获取到匹配的结果
print(result.span()) # 获取匹配项的索引
print(result.start()) # 获取匹配项的开始索引
print(result.end()) # 获取匹配项的结束索引

18809090000

(0, 11)

0

11

(2) search:从任意位置开始, 搜索第一个匹配项

python 复制代码
# search - 从任意位置开始, 搜索第一个匹配项 ----> Match 对象
result = re.search(r"1[3-9]\d{9}", s2)
print(result.group()) # 获取到匹配的结果
print(result.span()) # 获取匹配项的索引
print(result.start()) # 获取匹配项的开始索引
print(result.end()) # 获取匹配项的结束索引

18809090000

(6, 17)

6

17

(3) findall:从任意位置开始, 搜索所有匹配项

python 复制代码
# findall - 从任意位置开始, 搜索所有匹配项 ---> list
result = re.findall(r"1[3-9]\d{9}", s2)
print(result)

'18809090000', '18800008888', '18809091293'

(4)

python 复制代码
import re

s1 = "18809090000是我的手机号,188开头的,以00结尾的;我的另一个手机号是15500008888,两个QQ号分别是1259989092和13809091293821,邮箱为python666@163.com,请给我发邮件。"

# 正则表达式
print(re.findall(r"188.*", s1)) # * 匹配任何个 字符
print(re.findall(r"188.?", s1)) # ? 匹配0个或者1个 (最多出现一次) 字符
print(re.findall(r"188.+", s1)) # + 匹配1个或者多个 (最少出现一次) 字符

(1) '18809090000是我的手机号,188开头的,以00结尾的;我的另一个手机号15500008888,两个QQ号分别是1259989092和13809091293821,邮箱为python666@163.com,请给我发邮件。'

(2) '1880', '188开'

(3) '18809090000是我的手机号,188开头的,以00结尾的;我的另一个手机号是15500008888,两个QQ号分别是1259989092和13809091293821,邮箱为python666@163.com,请给我发邮件。'

(5)

python 复制代码
print(re.findall(r"188\d{8}", s1)) # {8} 匹配8个 数字
print(re.findall(r"155\d{6,10}", s1)) # {6,10} 匹配6到10个 数字
print(re.findall(r"155\d{6,}", s1)) # {6,} 匹配6个或者更多 数字

'18809090000'

'15500008888'

'15500008888'

(6)

python 复制代码
print(re.findall(r"1[38]\d{8}", s1)) # [38] 匹配3或者8
print(re.findall(r"1[^38]\d{8}", s1)) # [^38] 匹配非 3或者8
print(re.findall(r"1[3-9]\d{8}", s1)) # [3-9] 匹配3到9 (范围)
print(re.findall(r"^1[3-9]\d{9}", s1)) # ^ 匹配开头
print(re.findall(r"^1[3-9]\d{9}$", s1)) # $ 匹配结尾

'18809090000'

'15500008888'

'15500008888'

(7)

python 复制代码
print(re.findall(r"1[38]\d{8}", s1)) # [38] 匹配3或者8
print(re.findall(r"1[^38]\d{8}", s1)) # [^38] 匹配非 3或者8 (既不是3也不是8)
print(re.findall(r"1[3-9]\d{8}", s1)) # [3-9] 匹配3到9 (范围)
print(re.findall(r"^1[3-9]\d{9}", s1)) # ^ 匹配开头 (以1开头)
print(re.findall(r"^1[3-9]\d{9}$", s1)) # $ 匹配结尾 (以1为字符串开头,任意数字结尾)

'1880909000', '1380909129'

'1550000888', '1259989092'

'1880909000', '1550000888', '1380909129'

'18809090000'

(8)

python 复制代码
# \w 匹配任何单词字符(a-z、A-Z、0-9、_、其它语言字符) -- 默认行为
# r"\w+@\w+\.\w+" 表示 以任意个字符开头(\w+),中间必须有一个@(@),后面再有任意个字符(\w+),再有一个. (\.),最后有任意个字符(\w+)
print(re.findall(r"\w+@\w+\.\w+", s1))

# \w 匹配任何单词字符(a-z、A-Z、0-9、_)
# re.ASCII 表示只会匹配ASCII(不会匹配到中文,韩文等字符)
print(re.findall(r"\w+@\w+\.\w+", s1, re.ASCII))

'邮箱为python666@163.com'

'python666@163.com'

(9)

python 复制代码
s2 = "现在的时间是2026-02-06 10:05:25, 今天的天气还可以, 气温是28度 "
print(re.findall(r"\d{4}-\d{2}-\d{2}", s2))
print(re.findall(r"(\d{4})-(\d{2})-(\d{2})", s2))

'2026-02-06'

('2026', '02', '06')

相关推荐
linksinke9 小时前
在 CentOS 7.x 外网环境离线构建便携式 Python 3.11.4 的方案参考
linux·python·centos
wapicn999 小时前
API接口调试笔记:从注册到第一个数据返回,全流程详解
java·开发语言·python·lua
logo_289 小时前
python指定目录进行虚拟环境配置
python·虚拟环境
大数据魔法师9 小时前
Streamlit(十七)- API 参考文档(十)- 身份认证与用户信息组件
python·web
geovindu9 小时前
python: Bounded Parallelism Pattern
开发语言·python·设计模式·有界并行模式
大明者省9 小时前
Ubuntu Python 部署终极版教程
开发语言·python·ubuntu
KANGBboy9 小时前
java知识二(数组)
java·开发语言·python
Cloud_Shy6189 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第一章 Item 4 - 6)
android·数据库·论文阅读·python
llilay9 小时前
企业级FastAPI后端模板搭建(二)整合路由Router
开发语言·python·fastapi
土狗TuGou9 小时前
SQL内功笔记 · 第7篇:CTE&临时表&递归
数据库·笔记·后端·sql·mysql