正则表达式三---匹配多个字符,开头和结尾

转自:https://www.jianshu.com/p/8d93be682620

匹配多个字符的相关格式

first(字符)desc(功能)
*匹配前一个字符出现0次或者无限次,即可有可无
+匹配前一个字符出现1次或者无限次,即至少有1次
?匹配前一个字符出现1次或者0次,即要么有1次,要么没有
{m}匹配前一个字符出现m次
{m,n}匹配前一个字符出现从m到n次
^匹配字符串开头
$匹配字符串结尾

* 的使用

  • 匹配出,一个字符串第一个字母为大小字符,后面都是小写字母并且这些小写字母可有可无
#coding=utf-8
import re

ret = re.match("[A-Z][a-z]*","M")
print(ret.group())#M

ret = re.match("[A-Z][a-z]*","MnnM")
print(ret.group())#Mnn

ret = re.match("[A-Z][a-z]*","Aabcdef")
print(ret.group())#Aabcdef

+ 的使用

  • 匹配前一个字符出现1次或者无限次,即至少有1次
#coding=utf-8
import re
names = ["name1", "_name", "2_name", "__name__"]
for name in names:
    ret = re.match("[a-zA-Z_]+[\w]*",name)
    if ret:
        print("变量名 %s 符合要求" % ret.group())
    else:
        print("变量名 %s 非法" % name)

? 的使用

  • 匹配前一个字符出现1次或者0
#coding=utf-8
import re

ret = re.match("[1-9]?[0-9]","7")
print(ret.group())

ret = re.match("[1-9]?\d","33")
print(ret.group())

ret = re.match("[1-9]?\d","09")
print(ret.group())

{} 的使用,里面可以跟一个数字,也可以跟一个两个数字,含义不同

#coding=utf-8
import re

ret = re.match("[a-zA-Z0-9_]{6}","12a3g45678")
print(ret.group())

ret = re.match("[a-zA-Z0-9_]{8,20}","1ad12f23s34455ff66")
print(ret.group())

^ 一般跟在表达式最前方,表示必须该符号后的的字符开头

import re
baseStr = 'hahahahahaha'
ret = re.match('^h.+',baseStr)
print(ret)

baseStr = 'hahahahahaha'
ret = re.match('^h.{2,4}',baseStr)
print(ret.group())

$ 一般跟在表达式末尾,表示必须以$前的字符结尾

email_list = ["xiaoWang@163.com", "xiaoWang@163.comheihei", ".com.xiaowang@qq.com"]

for email in email_list:
    ret = re.match("[\w]{4,20}@163\.com$", email)
    if ret:
        print("%s 是符合规定的邮件地址,匹配后的结果是:%s" % (email, ret.group()))
    else:
        print("%s 不符合要求" % email)

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值