Python 正则表达式查找器到字典中



编程新手,所以提前为我缺乏知识道歉。

在尝试推断电话的目录号码及其MAC地址的过程中,我在下面提供了一些示例数据,并将其放入LLDPLarge的变量中:

LLDPLarge = '''* Slot-1 Far-B65-2ND.1 # show lldp neighbours detailed | include (System Name: "regDN |: 08:00:0F)
Port ID     : 08:00:0F:36:46:62
- System Name: "regDN 7335,MITEL 5340 IP"
Port ID     : 08:00:0F:3E:56:1C
- System Name: "regDN 7383,MITEL 5340 IP"
Port ID     : 08:00:0F:3C:12:B2
- System Name: "regDN 7270,MITEL 5340 IP"
Port ID     : 08:00:0F:28:9C:22
- System Name: "regDN 7320,MITEL 5340 IP"'''

我想出的代码如下:

vartest1 = "(?<=System Name: "regDN )(.*)(?=,)"
vartest2 = "([0-9A-F]{2}[:-]){5}([0-9A-F]{2})"
vartest3 = vartest1 + "|" + vartest2
for match in re.finditer(vartest3, LLDPLarge):
sGroup = match.group()
print('{}'.format(sGroup))

这是它创建的输出示例,非常接近我想要的:

08:00:0F:36:46:62
7335
08:00:0F:3E:56:1C
7383
08:00:0F:3C:12:B2
7270
08:00:0F:28:9C:22
7320

我想做的是将其输出到字典中,如下所示:

'08:00:0F:36:46:62' : '7335'
'08:00:0F:3E:56:1C' : '7383'
'08:00:0F:3C:12:B2' : '7270'
'08:00:0F:28:9C:22' : '7320'

目前我不确定该怎么做,或者我的代码是否最优雅?

任何帮助,非常感谢。

提前非常感谢。

检查是否填写了group(1)group(2)。如果group(1)有一个值,则正则表达式与电话号码匹配,否则与 MAC 地址匹配。然后,您可以将其用作字典的键或值。

d = {}
for match in re.finditer(vartest3, LLDPLarge):
if match.group(2):
key = match.group()
else:
val = match.group()
d[key] = val
print(d)
from re import finditer
from itertools import islice
# LLDPLarge = ...
pattern_system = "(?<=System Name: "regDN )(.*)(?=,)"
pattern_port = "([0-9A-F]{2}[:-]){5}([0-9A-F]{2})"
pattern = f"{pattern_system}|{pattern_port}"
d = {key.group(): value.group() for key, value in zip(*[finditer(pattern, LLDPLarge)] * 2)}

这里有一个简单的方法:

# Make a list with all the strings
everything = [match.group() for match in re.finditer(vartest3, LLDPLarge)]
# Pick every other one to get a list of just the MAC addresses
macs = everything[0::2]
# Same thing for the names
names = everything[1::2]
# Make a blank dictionary
dict = {}
# Fill the dictionary from our lists
for i in range(0, len(macs)):
dict[macs[i]] = names[i]
print(repr(dict))

itertools解决方案比这更优雅,但这需要较少的python专业知识来理解。

如果LLDPLarge是问题中的字符串,那么这个例子:

import re
d = dict(re.findall(r'([dA-F:]{17}).*?regDN (d+)', LLDPLarge, flags=re.S))
print(d)

指纹:

{'08:00:0F:36:46:62': '7335', '08:00:0F:3E:56:1C': '7383', '08:00:0F:3C:12:B2': '7270', '08:00:0F:28:9C:22': '7320'}

最新更新