【问题标题】:Get parent object using jsonpath query使用 jsonpath 查询获取父对象
【发布时间】:2016-05-27 15:11:51
【问题描述】:

我有下面的json:

{
"data": [
    {
        "name": "product1",
        "details": ["lorem ipsum", [
            {
                "code": "prd1"       
            },
            {
                "code": "prd11"
            }]
        ]
    },
    {
        "name": "product2",
        "details": ["lorem ipsum", [
            {
                "code": "prd2"
            },
            {
                "code": "prd22"
            }]
        ]
    }
]

}

我想根据代码检索产品的名称,所以 我写了这个查询

$.data..[?(@.code=="prd1")]

结果:

[
{
    "code": "prd1"
}]

预期结果:

[{name: "product1"}]

【问题讨论】:

    标签: javascript json regex xpath jsonpath


    【解决方案1】:

    您应该向上移动树,直到到达特定键的值。
    首先,我们需要到达第一个命名的祖先,即details,然后 - 获取它的第一个父级,它持有所需的name 属性。
    这可以使用ancestor() 函数和parent() 函数来完成:

    $.data..[?(@.code=="prd1")].ansector("details").parent()['name'];
    

    【讨论】:

    • 感谢您的回复,但我使用的是原生 jsonpath 查询(我认为 ansector 和 parent 是 JS 函数)
    猜你喜欢
    • 1970-01-01
    • 2017-06-12
    • 2022-01-05
    • 2023-02-01
    • 2014-06-29
    • 2012-05-15
    • 2021-12-12
    • 2019-05-21
    • 1970-01-01
    相关资源
    最近更新 更多