首页 > 解决方案 > 根据字典中的两个值比较多个字典的条目

问题描述

我有两个 python 字典,我需要一种有效的方法来迭代一个字典,检查每个条目的多个值与另一个字典。如果该条目不存在,我需要将该条目从一个字典添加到源字典。

我尝试了不同的方法,例如 itter() 对两个字典值并使用“in”来查看值是否存在,但逻辑在某处被破坏。

for key, value in export_data.iteritems():
  if  value['computer_id'] and value['computer_name'] in import_data.iteritems():

如果computer_id并且computer_nameimport_data则继续,如果不是则将缺少的字典项从 import_data 添加到 export_data 字典。

在下面的示例数据中,“ import_data”有一个额外的项目“ host-c”,我希望将其添加到 export_data 字典中。

我遇到困难的部分是“host-g”还有一条记录,但computer_id与export_data中的host-a相同,所以我不想添加该条目。

只有 computer_name 和 computer_id 不同的唯一项目。

示例数据:

export_data = 
{u'host-a': {'computer_id': [u'6353a65387'], 'computer_name': ['host-a'], 'first_observed': ['Wed Jul 24 13:57:56  2019']}, {u'host-b': {'computer_id': [u'635365d387'], 'computer_name': ['host-b'], 'first_observed': ['Wed Jul 24 13:57:56  2019']}

import_data = 
{u'host-a': {'computer_id': [u'6353a65387'], 'computer_name': ['host-a'], 'first_observed': ['Wed Jul 24 13:57:56  2019']}, {u'host-b': {'computer_id': [u'635365d387'], 'computer_name': ['host-b'], 'first_observed': ['Wed Jul 24 13:57:56  2019']},{u'host-c': {'computer_id': [u'6353654d387'], 'computer_name': ['host-c'], 'first_observed': ['Wed Jul 24 13:57:56  2019']},{u'host-g': {'computer_id': [u'6353a65387'], 'computer_name': ['host-g'], 'first_observed': ['Wed Jul 24 13:57:56  2019']}

标签: pythondictionarycompare

解决方案


我认为没有办法遍历两个字典并手动比较值。试验你的代码我得到了这个:

export_data = {
    u'host-a': {
        'computer_id': [u'6353a65387'],
        'computer_name': ['host-a'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        },
    u'host-b': {
        'computer_id': [u'635365d387'],
        'computer_name': ['host-b'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        }
    }

import_data = {
    u'host-a': {
        'computer_id': [u'6353a65387'],
        'computer_name': ['host-a'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        },
    u'host-b': {
        'computer_id': [u'635365d387'],
        'computer_name': ['host-b'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        },
    u'host-c': {
        'computer_id': [u'6353654d387'],
        'computer_name': ['host-c'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        },
    u'host-g': {
        'computer_id': [u'6353a65387'],
        'computer_name': ['host-g'],
        'first_observed': ['Wed Jul 24 13:57:56  2019']
        }
    }

print(export_data)

additional_export_data = []

for im_key, im_value in import_data.items():
    found_in_export = False

    for ex_key, ex_value in export_data.items():
        if ex_value['computer_id'][0] == im_value['computer_id'][0] and ex_value['computer_name'][0] == im_value['computer_name'][0]:
            found_in_export = True

    if not found_in_export:
        additional_export_data.append((im_key, im_value))

        print(im_key, im_value['computer_id'][0])
        print("")

for key, value in additional_export_data:
    export_data[key] = value

print(export_data)

如果没有与相同的条目,这将添加键值对 fromimport_data到。export_dataexport_datacomputer_id computer_name


我也不知道为什么你的export_data结构import_data是这样的。字典的键与computer_name值相同。和都是一个列表computer_id,即使它对我computer_name来说first_observed没有意义。

也许您有理由以这种方式构建数据,但如果不是,我建议您执行以下操作:

  • 摆脱computer_name子词典
  • 将 和 的值存储为字符串,computer_idfirst_observed不是列表中的字符串

如果这样做,代码如下所示:

export_data = {
    u'host-a': {
        'computer_id': u'6353a65387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        },
    u'host-b': {
        'computer_id': u'635365d387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        }
    }

import_data = {
    u'host-a': {
        'computer_id': u'6353a65387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        },
    u'host-b': {
        'computer_id': u'635365d387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        },
    u'host-c': {
        'computer_id': u'6353654d387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        },
    u'host-g': {
        'computer_id': u'6353a65387',
        'first_observed': 'Wed Jul 24 13:57:56  2019'
        }
    }

print(export_data)

additional_export_data = []

for im_key, im_value in import_data.items():
    found_in_export = False

    for ex_key, ex_value in export_data.items():
        if ex_value['computer_id'] == im_value['computer_id'] and ex_key == im_key:
            found_in_export = True

    if not found_in_export:
        additional_export_data.append((im_key, im_value))

        print(im_key, im_value['computer_id'])
        print("")

for key, value in additional_export_data:
    export_data[key] = value

print(export_data)

推荐阅读