正则表达式字符匹配格式

本文详细介绍了正则表达式的各种匹配方式,包括单字符、多字符匹配,以及开头结尾的匹配。还探讨了贪婪和非贪婪模式,并解释了如何使用转义字符和原生字符串。此外,还列举了Python `re` 模块中的关键函数,如 `match`、`search`、`findall`、`sub`、`split` 和 `compile`,并提供了示例代码,帮助读者更好地理解和应用正则表达式。
摘要由CSDN通过智能技术生成

单字符匹配

字符 功能
. 匹配任意1个字符(除了\n(换行符))
[ ] 匹配[ ]中列举的字符
\d 匹配数字,即0-9
\D 匹配非数字,即不是数字
\s 匹配空白,即 空格,tab键
\S 匹配非空白
\w 匹配单词字符,即a-z、A-Z、0-9、_
\W 匹配非单词字符

多字符匹配

字符 功能
* 匹配前一个字符出现0次或者无限次,即可有可无
+ 匹配前一个字符出现1次或者无限次,即至少有1次
? 匹配前一个字符出现1次或者0次,即要么有1次,要么没有
{m} 匹配前一个字符出现m次
{m,n} 匹配前一个字符出现从m到n次

匹配开头结尾

字符 功能
^ 匹配字符串开头
$ 匹配字符串结尾
text = "hello"
ret = re.match("^h",text)
print(ret.group())

# 若text中的字符串不是以“h”开头则会报错。
text = "xxx@163.comsfsds"
ret = re.match(\w+@163.com$,text)
print(ret.group())

# 匹配以@163.com结尾的字符,若不是以@163.com结尾,则会报错。

匹配分组

字符 功能
I 匹配左右任意一个表达式
(ab) 将括号中字符作为一个分组
\num 引用分组num匹配到的字符串
(?P) 分组起别名
(?P=name) 引用别名为name分组匹配到的字符串
  • 在正则表达式中.具有特殊含义,若要对 . 使用正则,用\进行转义

贪婪模式和非贪婪模式

贪婪模式:正则表达式会匹配尽量多的字符。默认是贪婪模式。

text = "0123456"
ret = re.match('\d+',text)
print(ret
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值