问题描述
iso.3.6.1.4.1.2011.6.128.1.1.2.21.1.6.4194455040
例如,使用SNMP OID,我想捕获最后一个序列号, 4194455040 ,有时可能倒数第二个序列号, 6 ?>
还是我需要迭代查找字符串中的点(。)并捕获这些数字?
语言:Python
解决方法
我认为最好的方法是捕获所有由点分隔的数字。然后,您可以根据需要决定选择多少个这些数字。这样做的正则表达式为:/\.(\d+)/gm
。这是假设您确实想要/需要使用正则表达式。否则,您可以简单地split
字符串。
演示:https://regex101.com/r/OmzQcj/2/
正则表达式反向解释:
-
\d
:捕获任意数字(0到9) -
\d+
:至少一次 -
(\d+)
:将其保存到组中 -
\.(\d+)
:该组的开头有一个点
如果您只想捕获最后两批数字,则可以改用以下正则表达式:https://regex101.com/r/evaF3X/1。这个将这些数字存储在组1和组2中。
,需要最后一个数字时使用此正则表达式。
\d+$
工作demo。
此正则表达式将给您倒数第二个。
\d+(?=\.\d+$)
工作demo。
我在这里使用lookaround运算符。第一个很简单。它说从行尾开始获得一个或多个数字。
第二个使用超前运算符。它表示要获得一个或多个数字,然后是.\d+$
。