【问题标题】:Python find obj value based on condition within dictionaryPython根据字典中的条件查找obj值
【发布时间】:2018-03-09 12:39:17
【问题描述】:

我从 python 请求中得到以下 json 数据:

{
    "results": [
        {
            "name": "virtual-machine-1",
            "guest": "Microsoft Windows Server 2016 (64-bit)",
            "status": "green",
            "id": "567890-004",
        },
        {
            "name": "virtual-machine-2",
            "guest": "CoreOS Linux (64-bit)",
            "status": "green",
            "id": "567890-005",
        }
    ]
}

如何根据“名称”值获取所有字典的“id”值。

我已经看到了基于键而不是基于条件在同一个字典中查找值并为多个字典迭代它的解决方案。感谢您的帮助。

【问题讨论】:

  • 什么意思?您是否尝试从结果字典中获取“id”的所有值,其中 name == 一些字符串?

标签: python dictionary conditional


【解决方案1】:

这是重新键入 id:

>>> {result['id']: result['name'] for result in data['results']}
{'567890-004': 'virtual-machine-1', '567890-005': 'virtual-machine-2'}

这种技术称为字典理解

【讨论】:

  • 感谢您的帮助。得到我需要的东西并了解字典理解。
【解决方案2】:
d = {result['name']: result['id'] for result in request.dict['results'] if 'name' in result}
# request.dict is the name of the object that contains the list "results"

【讨论】:

  • 只有在结果也有 name 键时才会返回 id
【解决方案3】:

将您的 json 转换为字典列表。然后只使用简写的语句。

results = [
{ "name": "virtual-machine-1",
            "guest": "Microsoft Windows Server 2016 (64-bit)",
            "status": "green",
            "id": "567890-004"},
{"name": "virtual-machine-2",
            "guest": "CoreOS Linux (64-bit)",
            "status": "green",
            "id": "567890-005"}
]

id = [x['id'] for x in results if x['name'] == "virtual-machine-1"]
print id    # prints 567890-004

id = [x['id'] for x in results if x['name'] == "virtual-machine-2"]
print id    # prints 567890-005

【讨论】:

  • 我很难编写格式化的评论,因此需要进行大量编辑。抱歉,在查看您的解决方案时,id 返回 '[]' 没有找到匹配项。
    例如,上面没有 'virtual-machine-3' 如果我尝试
    id = [ x['id'] for x in results if x['name'] == "virtual-machine-3"] print id # prints []
    我预计会出现错误,因为如果我使用 'assert 验证结果id is not None' 在某处使用它之前,它为空值返回'True'。
猜你喜欢
  • 1970-01-01
  • 2023-02-06
  • 2021-11-17
  • 2022-11-16
  • 2013-02-12
  • 1970-01-01
  • 2022-10-14
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多