* :匹配前一个字符出现0次或者无限次,即可有可无
+ :匹配前一个字符出现1次或者无线次,即至少有1次
?:匹配前一个字符出现1次或者0次,即要么有1次,要么没有
{m} :匹配前一个字符出现m次
{m,n}:匹配前一个字符出现从m到n次
示例1:*
需求:匹配出,一个字符串第一个字母为大小字符,后面都是小写字母并且这些小写字母可有可无
import re
#注意是前一个字符
ret = re.match("[A-Z][a-z]*","M")
up())
ret = re.match("[A-Z][a-z]*","AaBcDE")
up())
ret = re.match("[A-Z][a-z]*","Aabcdef")
up())
#运行结果
M
Aa
Aabcdef
示例2:+
需求:匹配出,变量名是否有效
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ:778463939
寻有志同道合的小伙伴,互帮互助,里还有不错的视频学习教程和PDF电子书!
'''
import re
names =["name1","_name","2_name","__name__"]
for i in names:
ret = re.match("[a-zA-Z_]+[\w]*",i)
if ret:
print("变量名 %s 符合要求"% up())python正则表达式不包含
else:
print("变量名 %s 非法"% i)
#运行结果
变量名 name1 符合要求
变量名 _name 符合要求
变量名 2_name 非法
变量名 __name__ 符合要求
示例3:?
需求:匹配出0到99之间的数字
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ:778463939
寻有志同道合的小伙伴,互帮互助,里还有不错的视频学习教程和PDF电子书!
'''
import re
ret = re.match("[1-9]?[0-9]","7")
up())
ret = re.match("[1-9]?\d","33")
up())
ret = re.match("[1-9]?\d","09")
up())
#运行结果
7
33
0# 这个结果并不是想要的,利用$才能解决
示例4:{m}
需求:匹配出,8到20位的密码,可以是大小写英文字母、数字、下划线
import re
ret = re.match("[a-zA-Z0-9_]{6}","123a3g45678")
up())
ret = re.match("[[a-zA-Z0-9_]{8,20}","1ad3123456addfcasdef")
up())
#运行结果
123a3g
1ad3123456addfcasdef
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论