JSON路径表达式



我有以下JSON负载:

{
    "inputs" : [{
            "attributeX" : [{
                    "id1" : "value11",
                }, {
                    "id1" : "value12",
                }
            ],
            "attributeY" : [{
                    "id" : "valueY1",
                    "attributeZ" : [{
                            "pathZ" : "/Path1/Path2[00163E038C2E1EE299C1C394370BCFA0]/Description",
                            "value" : "valueXYZ",
                        }
                    ],
                }
            ]
        }
    ]
}

我想写一个JSON路径表达式,以便获得pathZ的值。但是[]中的部分值是动态的。是否在以下JSON路径表达式中指定了一个通配符?

$.inputs.[*].attributeY.[*].attributeZ[?(@.pathZ=='/Path1/Path2**<HOW_CAN_I_SPECIFY_A_WILDCARD_HERE>**/Description')].value

您可以在JSON Path表达式中使用正则表达式来匹配PathZ值的开始和结束,而不匹配中间值。这就是表达式的样子:

$.inputs.[*].attributeY.[*].attributeZ[?(new RegExp('^/Path1/Path2.*/Description$').test(@.pathZ))].value

我在这里使用在线JSON查询工具对此进行了测试:http://www.jsonquerytool.com/sample/jsonpathregex

最新更新