我有一个由接口名称和访问列表名称组成的元组列表。像这样:exempt_int_acl_tuple=[('(app)', 'access-list nonat'), ('(app2)', 'access-list nonat')]
样本配置进行搜索是这样的:
config=['access-list nonat extended permit ip 10.0.0.0 255.0.0.0 10.0.0.0 255.0.0.0','access-list nonat extended permit ip 10.0.0.0 255.0.0.0 192.168.15.0 255.255.255.0','access-list nonat extended permit ip 10.0.0.0 255.0.0.0 1.1.1.1 255.255.255.240','blah','blah blah','some more blah']
我有一个列表字符串,在其中寻找特定的模式。如果列表与模式匹配,则将其添加到名为的新列表中exempt_acl。
所以我的代码看起来像这样:
exempt_acl=[]
for interface,acl_name in exempt_int_acl_tuple:
for someline in config:
acl_statement=acl_name+' extended permit ip '
if (acl_statement in someline) and (someline not in exempt_acl):
exempt_acl.append(someline)
在这种情况下,将重复元组中的访问列表名称,以便在配置文件中搜索两次。所以exempt_acl看起来像这样:
['access-list nonat extended permit ip 10.0.0.0 255.0.0.0 10.0.0.0 255.0.0.0 ', 'access-list nonat extended permit ip 10.0.0.0 255.0.0.0 192.168.15.0 255.255.255.0 ', 'access-list nonat extended permit ip 10.0.0.0 255.0.0.0 1.1.1.1 255.255.255.240 ']
['access-list nonat extended permit ip 10.0.0.0 255.0.0.0 10.0.0.0 255.0.0.0 ', 'access-list nonat extended permit ip 10.0.0.0 255.0.0.0 192.168.15.0 255.255.255.0 ', 'access-list nonat extended permit ip 10.0.0.0 255.0.0.0 1.1.1.1 255.255.255.240 ']
但是,相同的行被添加了两次,并且它创建的是列表列表,而不是字符串列表。我认为的布尔值评估(someline not in exempt_acl)会阻止第二次添加该行,但是确实如此。我究竟做错了什么?我正在file.read().splitlines()阅读配置文件,以防万一。
解决方案
首先,通过说来list神化。somelinesomeline = someline[0]
如果仍然出现两次附加行,则可能是由于条件不明确if (acl_statement in someline)。如果两行稍有不同(例如,空白量不同),但包含相同的行acl_statement,则将两行都追加。