gpt4 book ai didi

python - 比较和组合字典

转载 作者:太空宇宙 更新时间:2023-11-03 14:08:46 25 4
gpt4 key购买 nike

我有一个列表,其中包含不同数量的词典。

我需要循环输入中的每个字典并比较键值“s_source_zone”、“s_destination_zone”和“Services”。如果这些键值匹配,我需要将它们(键源 IP 和目标 IP)组合到存储在结果 [] 中的一个字典中。如果不匹配,则需要将输入字典添加到结果中。

本质上将所有“匹配”词典合并为一个。请参阅下面的示例

    result = []
input_ = [{'s_logical_system': 'logical_1', 's_virtual_router': 'vr_1', 's_matched_route': '10.0.0.0/8', 's_source_zone': 'zone_cccc_1', 's_destination_zone': 'zone_bbbb_1', 'Services': 80, 'Source IP': '10.10.10.10', 'Destination IP': '10.20.20.20'}, {'s_logical_system': 'logical_1', 's_virtual_router': 'vr_1', 's_matched_route': '10.0.0.0/8', 's_source_zone': 'zone_cccc_1', 's_destination_zone': 'zone_bbbb_1', 'Services': 80, 'Source IP': '10.40.10.10', 'Destination IP': '10.10.50.20'}, {'s_logical_system': 'logical_3', 's_virtual_router': 'vr_2', 's_matched_route': '10.0.0.0/8', 's_source_zone': 'zone_zzzz_1', 's_destination_zone': 'zone_rrrr_1', 'Services': 443, 'Source IP': '10.10.10.10', 'Destination IP': '10.20.20.20'}]

if 's_source_zone', 's_destination_zone' and 'Services' all have the same values, combine the keys "Source IP" and "Destination IP" into one dictionary appended to result[]. See below;

result = [{'s_logical_system': 'logical_1', 's_virtual_router': 'vr_1', 's_matched_route': '10.0.0.0/8', 's_source_zone': 'zone_cccc_1', 's_destination_zone': 'zone_bbbb_1', 'Services': 80, 'Source IP': '10.10.10.10, 10.40.10.10', 'Destination IP': '10.20.20.20, 10.10.50.20'}, {'s_logical_system': 'logical_3', 's_virtual_router': 'vr_2', 's_matched_route': '10.0.0.0/8', 's_source_zone': 'zone_zzzz_1', 's_destination_zone': 'zone_rrrr_1', 'Services': 443, 'Source IP': '10.10.10.10', 'Destination IP': '10.20.20.20'}]

if match not found. Append the entire dictionary to result. result.append(input_[x])

最佳答案

您可以使用itertools.groupby来做到这一点:

from itertools import groupby

match_on = ['s_source_zone', 's_destination_zone', 'Services',
's_logical_system', 's_virtual_router']
groupfunc = lambda x: [x[match] for match in match_on]

result = []
for (source, dest, service, log, virt), group in groupby(input_, groupfunc):
group_ = tuple(group) # otherwise iterator goes bye-bye
res = {'Destination IP': ', '.join(d['Destination IP'] for d in group_),
'Services': service,
'Source IP': ', '.join(d['Source IP'] for d in group_),
's_destination_zone': dest,
's_logical_system': log,
's_matched_route': ', '.join(d['s_matched_route'] for d in group_),
's_source_zone': source,
's_virtual_router': virt}
result.append(res)

从您的示例中推断一下,看起来实际上有 5 个您想要匹配的键/值对。 (否则,您会以某种方式组合重复/相同的值,但您没有这样做。)

这里的 lambda 函数根据 match_on 中 5 个键的等效值的交集来匹配输入中的字典。所有匹配的字典都被放入一个 group 中,这里是一个 itertools._grouper 迭代器。

关于python - 比较和组合字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48675638/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com