Python中re模块:匹配开头/结尾(^/$)
匹配开头结尾
字符 | 功能 |
^ | 匹配字符串开头 |
$ | 匹配字符串结尾 |
示例1:$
需求:匹配163.com的邮箱地址
email_list = [ " xiaoWang@163.com " , " xiaoWang@163.comh eihei" , ". com.xiaowang@qq.com " ]
for email in email_list: ret = re.match("[\w]{4,20}@163\.com$", email) \.代表只是一个点 $代表以xxx结尾的字符串 if ret: print("%s ---是符合规定的邮件地址” % email) else: print("%s ---不符合要求" % email)
运行结果:
xiaoWang@163.com # ---是符合规定的邮件地址
xiaoWang@163.comheihei # ---不符合要求 # 如果没有$,这个字符串会匹配出来
.com.xiaowang@qq.com # ---不符合要求
匹配分组
字符 | 功能 |
| | 匹配左右任意一个表达式 |
(ab) | 将括号中字符作为一个分组 |
\num | 引用分组num匹配到的字符串 |
(?P<name>) | 分组起别名 |
(?P=name) | 引用别名为name分组匹配到的字符串 |
示例1:|
需求:匹配出0-100之间的数字
#coding=utf-8 import re ret = re.match("[1-9]?\d","8”) # ?匹配前面的字符出现1次或者0次 类似78也可以匹配 print(ret.group()) # 结果:8
# 可能匹配不成功时? import re ret = re.match("[1-9]?\d$","08") if ret: print(ret.group()) else: print("不在0-100之间”) # 结果:不在0-100之间
# 添加|
import re ret = re.match("[1-9]?\d$|100","78") print(ret.group()) # 结果: 78 ret = re.match("[1-9]?\d$|100","100") print(ret.group()) # 结果: 100
示例2:( )
需求:匹配出163、126、qq邮箱
#coding=utf-8 import re ret = re.match("\w{4,20}@163\.com", "test@163.com”) print(ret.group()) # 结果: test@163.com ret = re.match("\w{4,20}@(163|126|qq)\.com", "test@gmail.com") if ret: print(ret.group()) else: print("不是163、126、qq邮箱") # 结果: 不是163、126、qq邮箱
需求:不是以4、7结尾的手机号码(11位)
import re tels = ["13100001234", "18912344321", "10086", "18800007777"] for tel in tels: ret = re.match("1\d{9}[0-3,5-6,8-9]", tel) if ret: print(ret.group()) else: print("%s 不是想要的手机号" % tel)
结果如下:
13100001234 不是想要的手机号
18912344321
10086 不是想要的手机号
18800007777 不是想要的手机号
示例三:分组匹配
需求:提取区号和电话号码
import re ret = re.match("([^-]*)-(\d+)", "010-12345678") print(ret.group()) print(ret.group(1)) print(ret.group(2))
结果如下:
010-12345678
010
12345678
^在[ ]里面代表非的含义:
例如:
- [^-]* *代表前所有字符0个或者多个,非-的字符串
- [^abc] 代表非a、且非b 、且非c的字符
到此这篇关于Python中re模块:匹配开头/结尾(^/$)的文章就介绍到这了,更多相关Python 匹配开头/结尾 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
python中DataFrame常用的描述性统计分析方法详解
这篇文章主要介绍了python中DataFrame常用的描述性统计分析方法详解,描述性统计分析是通过图表或数学方法,对数据资料进行整理、分析,并对数据的分布状态、数字特征和随机变量之间的关系进行估计和描述的方法,需要的朋友可以参考下2023-07-07python读取查看npz/npy文件数据以及数据完全显示方法实例
前两天从在GitHub下载了一个代码,其中的数据集是.npz结尾的文件,之前没有见过不知道如何处理,下面这篇文章主要给大家介绍了关于python读取查看npz/npy文件数据以及数据完全显示方法的相关资料,需要的朋友可以参考下2022-04-04
最新评论