正则表达式听着高大上?详解Python正则表达式(附速查字典)_python字典正则

本文介绍了Python正则表达式的各种模式匹配规则,如行首/行尾匹配、特殊字符转义、重复次数定义,以及如何在字符串替换和分组提取中使用。还涵盖了数字和字符校验正则表达式示例。
摘要由CSDN通过智能技术生成

匹配a、^或d: “[a^d]”
除了a以外的都匹配: “[^a]”



2.2 ^

从行首开始往后匹配第一个符合模式的字符串

示例

"^abc"

2.3 $

从行末开始往前匹配第一个符合模式的字符串

示例

"abc$"

2.4 \

将下一个字符标记为特殊或原义字符

示例

匹配\n: "\\n"
匹配换行符: "\n"

2.5 {m,n}

定义匹配次数 。省略m表示0下限,省略n表示无穷上限。注意该元字符属于贪婪匹配,即在所有符合匹配规则的字符串中选择匹配次数大的字符串

示例

匹配两个字母: "[a-zA-Z]{2}"

2.6 *

匹配零次或多次,等价于(,)

2.7 +

匹配一次或多次,等价于(1,)

2.8 ?

匹配零次或一次,等价于(0,1),{m,n}?声明非贪婪匹配,即在所有符合匹配规则的字符串中选择匹配次数小的字符串

示例

string = "{ymd:'2018-01-01',tianqi:'晴',aqiInfo:'轻度污染'},\
 {ymd:'2018-01-02',tianqi:'阴~小雨',aqiInfo:'优'},\
 {ymd:'2018-01-03',tianqi:'小雨~中雨',aqiInfo:'优'},\
 {ymd:'2018-01-04',tianqi:'中雨~小雨',aqiInfo:'优'}"
print(re.findall(r"tianqi:'(.\*?)'", string))

*?先进行贪婪匹配,再进行非贪婪匹配。

首先进行贪婪匹配,从第一个tianqi:'开始到最后一个’为止,其间的字符串均为匹配字符串,即

tianqi:'晴',aqiInfo:'轻度污染'},\
{ymd:'2018-01-02',tianqi:'阴~小雨',aqiInfo:'优'},\
{ymd:'2018-01-03',tianqi:'小雨~中雨',aqiInfo:'优'},\
{ymd:'2018-01-04',tianqi:'中雨~小雨',aqiInfo:'优'

接下来在贪婪匹配的结果中进行非贪婪匹配,即从第一个tianqi:'开始到最近一个’为止均为匹配字符串,即

[tianqi:'晴', tianqi:'阴~小雨', tianqi:'小雨~中雨', tianqi:'中雨~小雨']

最后用()进行匹配提取:

['晴', '阴~小雨', '小雨~中雨', '中雨~小雨']

2.9 .

匹配除换行符以外的任意字符

2.10 ()

匹配结果分组提取

3 Python正则库re的使用

3.1 字符串替换

re库提供的方法sub(reg, strReplace, str)subn(reg, strReplace, str)可将符合正则reg的字符串替换成strReplace,区别在于前者仅返回替换后的字符串而后者多返回一个替换次数。

3.2 字符串分割

re库提供的方法split(div, str)可将字符串以分隔符div为界进行分割,返回分割后的数组。

4 常用正则转义字符表

特殊字符说明
\b匹配单词边界。例如’er\b’可匹配"never"中的’er’但不能匹配"verb"中的’er’
\B匹配非单词边界。例如’er\B’可匹配"verb"中的’er’,但不能匹配"never"中的’er’
\d匹配数字字符,等价于[0-9]
\D匹配非数字字符,等价于[^0-9]
\f匹配换页符,等价于\x0c和\cL
\n匹配换行符,等价于\x0a和\cJ
\r匹配回车符,等价于\x0d和\cM
\s匹配空白字符,包括空格、制表符、换页符等。等价于[ \f\n\r\t\v]
\S匹配非空白字符,等价于[^ \f\n\r\t\v]
\t匹配制表符,等价于\x09和\cI
\v匹配一个垂直制表符,等价于\x0b和\cK
\w匹配字母、数字、下划线,等价于[A-Za-z0-9_]
\W匹配非字母、数字、下划线,等价于[^A-Za-z0-9_]

5 常用正则表达式

5.1 数字校验正则

  • 数字:1*$
  • m-n位的数字:^\d{m,n}$
  • 正数、负数和小数:^(-|+)?\d+(.\d+)?$
  • 非负整数:^\d+$
  • 非正整数:^-[1-9]\d*|0$
  • 非负浮点数:^\d+(.\d+)?$
  • 非正浮点数:^((-\d+(.\d+)?)|(0+(.0+)?))$
  • 正浮点数:2\d*.\d*|0.\d*[1-9]\d*$
  • 负浮点数:^-([1-9]\d*.\d*|0.\d*[1-9]\d*)$
  • 浮点数:^(-?\d+)(.\d+)?$

5.2 字符校验正则

  • 汉字:3{0,}$

最后

Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

👉Python所有方向的学习路线👈

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

👉Python必备开发工具👈

工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。

👉Python全套学习视频👈

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。

👉实战案例👈

学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。

因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。

👉大厂面试真题👈

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

需要这份系统化学习资料的朋友,可以戳这里无偿获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!


  1. 0-9 ↩︎

  2. 1-9 ↩︎

  3. \u4e00-\u9fa5 ↩︎

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值