首页 > 如何判断自己编写的正则表达式足够精确或最优?

如何判断自己编写的正则表达式足够精确或最优?

在使用python的正则表达式时,对一些配置文件进行查找匹配。总觉得自己写的不是最优,但又可用。

比如如下

 interface Vlan100
 ip address 10.212.44.129 255.255.255.128 secondary

目的是匹配出IP地址和掩码来,其中IP地址和掩码均不固定。

^sipsaddresss(?:d+.){3}d+s(?:d+.){3}d+ssecondary

我使用上面的表达式可以得到结果,然后做一些split之类的得到IP地址和掩码。
但作为一个强迫症来说,总觉得不够完美。请教下如何判断自己的表达式是最优的(不限于上面这个,上面的只是举例)


目测你这个数据是非常规范规整的,所以不会出现异常数据,那么正则简单匹配即可

address\s([\d.]+)\s([\d.]+)\ssecondary

第一个子表达式是ip,第二个子表达式是掩码。

python不会,所以没办法写py例子给你,不过这个正则通用。


一句到底,就是产生足够多的随机测试集合,过了就好。。。

【热门文章】
【热门文章】