【Python-正则表达式】

Python-正则表达式

  • [■ 基础匹配](#■ 基础匹配)
    • [■ match 从头匹配](#■ match 从头匹配)
    • [■ search 搜索匹配](#■ search 搜索匹配)
    • [■ findall 搜索全部匹配](#■ findall 搜索全部匹配)
    • [■ 综合](#■ 综合)
  • [■ 元字符匹配](#■ 元字符匹配)
    • [■ r'[b-eF-Z3-9]' r表示意思](#■ r'[b-eF-Z3-9]' r表示意思)
    • [■ 正则表达式使用元字符进行匹配](#■ 正则表达式使用元字符进行匹配)
    • [■ 匹配账号,只能由字母和数字组成,长度限制6到10位](#■ 匹配账号,只能由字母和数字组成,长度限制6到10位)
    • [■ 匹配QQ号,要求纯数字,长度5-11,第一位不为0](#■ 匹配QQ号,要求纯数字,长度5-11,第一位不为0)
    • [■ 匹配邮箱地址,只允许qq、163、gmail这三种邮箱地址](#■ 匹配邮箱地址,只允许qq、163、gmail这三种邮箱地址)
    • [■ 综合](#■ 综合)

■ 基础匹配

■ match 从头匹配

python 复制代码
import re
s = "1python itheima python python"
# match 从头匹配
result = re.match("python", s)
print(result)
python 复制代码
import re
s = "1python itheima python python"
# search 搜索匹配
result = re.search("python2", s)
print(result)

■ findall 搜索全部匹配

python 复制代码
import re
s = "1python itheima python python"
# findall 搜索全部匹配
result = re.findall("python", s)
print(result)

■ 综合

python 复制代码
"""
演示Python正则表达式re模块的3个基础匹配方法
"""
import re

s = "1python itheima python python"
# match 从头匹配
result = re.match("python", s)
print(result)
# print(result.span())
# print(result.group())
# search 搜索匹配

result = re.search("python2", s)
print(result)
# findall 搜索全部匹配
result = re.findall("python", s)
print(result)

■ 元字符匹配

■ r'[b-eF-Z3-9]' r表示意思

字符串前面带上r的标记,表示字符串中转义字符无效,就是普通字符的意思

■ 正则表达式使用元字符进行匹配

python 复制代码
"""
演示Python正则表达式使用元字符进行匹配
"""
import re
# s = "itheima1 @@python2 !!666 ##itccast3"
#
# result = re.findall(r'[b-eF-Z3-9]', s)   # 字符串前面带上r的标记,表示字符串中转义字符无效,就是普通字符的意思
# print(result)

■ 匹配账号,只能由字母和数字组成,长度限制6到10位

python 复制代码
# r = '^[0-9a-zA-Z]{6,10}$'
# s = '123456_'
# print(re.findall(r, s))

■ 匹配QQ号,要求纯数字,长度5-11,第一位不为0

python 复制代码
r = '^[1-9][0-9]{4,10}$'
s = '123453678'
print(re.findall(r, s))

■ 匹配邮箱地址,只允许qq、163、gmail这三种邮箱地址

python 复制代码
# abc.efg.daw@qq.com.cn.eu.qq.aa.cc
# abc@qq.com
# {内容}.{内容}.{内容}.{内容}.{内容}.{内容}.{内容}.{内容}@{内容}.{内容}.{内容}
r = r'(^[\w-]+(\.[\w-]+)*@(qq|163|gmail)(\.[\w-]+)+$)'
# s = 'a.b.c.d.e.f.g@qq.com.a.z.c.d.e'
s = 'a.b.c.d.e.f.g@126.com.a.z.c.d.e'
print(re.match(r, s))

■ 综合

python 复制代码
"""
演示Python正则表达式使用元字符进行匹配
"""
import re

# s = "itheima1 @@python2 !!666 ##itccast3"
#
# result = re.findall(r'[b-eF-Z3-9]', s)   # 字符串前面带上r的标记,表示字符串中转义字符无效,就是普通字符的意思
# print(result)

# 匹配账号,只能由字母和数字组成,长度限制6到10位
# r = '^[0-9a-zA-Z]{6,10}$'
# s = '123456_'
# print(re.findall(r, s))

# 匹配QQ号,要求纯数字,长度5-11,第一位不为0
# r = '^[1-9][0-9]{4,10}$'
# s = '123453678'
# print(re.findall(r, s))

# 匹配邮箱地址,只允许qq、163、gmail这三种邮箱地址
# abc.efg.daw@qq.com.cn.eu.qq.aa.cc
# abc@qq.com
# {内容}.{内容}.{内容}.{内容}.{内容}.{内容}.{内容}.{内容}@{内容}.{内容}.{内容}
r = r'(^[\w-]+(\.[\w-]+)*@(qq|163|gmail)(\.[\w-]+)+$)'
# s = 'a.b.c.d.e.f.g@qq.com.a.z.c.d.e'
s = 'a.b.c.d.e.f.g@126.com.a.z.c.d.e'
print(re.match(r, s))
相关推荐
xiao智2 分钟前
Ansible 数百台批量操作前期准备工作
linux·python·ansible
浪子西科34 分钟前
【数据结构】(Python)第六章:图
开发语言·数据结构·python
起个破名想半天了41 分钟前
Web自动化之Selenium添加网站Cookies实现免登录
python·selenium·cookie
程序趣谈43 分钟前
算法随笔_57 : 游戏中弱角色的数量
数据结构·python·算法
数学人学c语言2 小时前
记录torch运行的bug
python·深度学习·bug
小爬虫程序猿2 小时前
使用Python爬虫获取淘宝商品详情:API返回值说明与案例指南
开发语言·爬虫·python
ONE_PUNCH_Ge2 小时前
Python selenium 库
python
m0_748240023 小时前
Python大数据可视化:基于大数据技术的共享单车数据分析与辅助管理系统_flask+hadoop+spider
大数据·python·信息可视化
放氮气的蜗牛3 小时前
Python爬虫系列教程之第十五篇:爬取电商网站商品信息与数据分析
爬虫·python·数据分析
阿正的梦工坊3 小时前
PyTorch torch.logsumexp 详解:数学原理、应用场景与性能优化(中英双语)
人工智能·pytorch·python