首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >python在json中查找与value相关的值

python在json中查找与value相关的值
EN

Stack Overflow用户
提问于 2019-10-03 21:26:08
回答 2查看 36关注 0票数 0

您好,我有一个python脚本,它可以打开一个json文件,搜索值并返回其他相关参数。目前我不能搜索它里面的值。

在我的json结构下面:

代码语言:javascript
运行
复制
{
    "MALE": [{
        "name": "John",
        "age": "70",
        "country": "Germany"
    },
    {
        "name": "Luke",
        "age": "35",
        "country": "France"
    }],
    "FEMALE": [{
        "name": "Sarah",
        "age": "29",
        "country": "Spain"
    }]
}

我在python方面的功能是:

代码语言:javascript
运行
复制
import json

with open('/path/to/json/file') as f_json:
     data = json.load(f_json)

我想做的是:获取解析"John“名字的"age”和"country“值

我怎么能做到呢?

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-10-03 21:31:45

您可以尝试以下代码,可能需要进行一些迭代以适合您的实际用例

代码语言:javascript
运行
复制
import json

with open('/path/to/json/file') as f_json:
    data = json.load(f_json)
    male, female = data.get("MALE"), data.get("FEMALE")
    for person in male:
        if person.get("name") == "John":
            print(person.get("age"), person.get("country")
票数 1
EN

Stack Overflow用户

发布于 2019-10-03 21:41:34

如果您更频繁地使用此逻辑,则可以使用新的字典重构结果:

代码语言:javascript
运行
复制
import json

result = {}

with open('/path/to/json/file') as f_json:
    data = json.load(f_json)
    for key in data:
        for ele in data[key]:
            result[ele['name']] = ele

然后您可以使用result来访问某个名称的相关属性:

代码语言:javascript
运行
复制
result['John']['age']
result['John']['country']
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58220158

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档