python正则记录

目录

搜索字符串中的小数

实验

规则 解释

参考资料


一些正则使用时总是搜索多次,特此记录

搜索字符串中的小数

实验

例如下面两个

1)期望能分别找出44和44.8数据

扫描二维码关注公众号,回复: 14720850 查看本文章
100 packets transmitted, 56 received, 44% packet loss, time 1001ms
100 packets transmitted, 56 received, 44.8% packet loss, time 1001ms

2)采用的正则:

re.findall(r"(\d+\.*\d*)(?=% packet loss)", ping_result)

规则 解释

a.   为了找出 pack loss前面的特定字符串,需要采用前向肯定搜索关键字,即:

正则表达式B(?=正则表达式A)	

构成要素:括号 ,问号,等于号 及匹配的字符串。本例中匹配的字符串为 % packet loss

也就是 在 搜索到这个 匹配的字符串% packet loss后,再将正则表达式的其余部分,本例中为(\d+\.*\d*) 匹配 字符串 % packet loss 之前的字符。

简而言之:即 用正则表达式B去匹配正则表达式A前面的字符串。

b. 为了只返回44 或者44.8,需要采用() 关键字,即:

(正则表单时)	      对正则表达式分组并记住匹配的文本

c.  小数

\d+\.*\d*

 这里我们看到网上有些资料是 \d+\.\d+ 实际上只能匹配小数,满足不了本需求

参考资料

(6条消息) Python正则表达式前向/后向搜索的肯定/否定模式的区别和示例_小龙在山东的博客-CSDN博客

Python 正则表达式 | 菜鸟教程 (runoob.com) 

猜你喜欢

转载自blog.csdn.net/proware/article/details/126188915