{
"dataObject": [
{
"id": 263626,
"role": {
"id": 12054,
"name": "Edit",
"description": ""
},
"resource": {
"id": 5756,
"type": "resource"
}
},
{
"id": 263364,
"role": {
"id": 12054,
"name": "Edit",
"description": ""
},
"resource": {
"id": 5728,
"type": "resource"
}
}
]
}
我有一个如下所示的 JSON 对象。我需要从 dataObject
中提取 json 对象,该对象具有 name:Edit
和 id:5756
。
如何使用 JSON 路径实现此目的?
尝试了 $..[?(@.name="Edit", @.id=5756)]
但没有成功。
Java代码:
JsonPath.parse(json).read("$..[?(@.name='Edit'), (@.id=5756)]")
最佳答案
尝试使用父对象名称和逻辑运算符AND
。结果路径将是
$..[?((@.resource.id == 5756) && (@.role.name == '编辑'))]
。
它在单元测试中对我有用 com.jayway.jsonpath:json-path:2.4.0
@Test
public void testParse() {
String json = "{\n" +
" \"dataObject\": [\n" +
" {\n" +
" \"id\": 263626,\n" +
" \"role\": {\n" +
" \"id\": 12054,\n" +
" \"name\": \"Edit\",\n" +
" \"description\": \"\"\n" +
" },\n" +
" \"resource\": {\n" +
" \"id\": 5756,\n" +
" \"type\": \"resource\"\n" +
" }\n" +
" },\n" +
" {\n" +
" \"id\": 263364,\n" +
" \"role\": {\n" +
" \"id\": 12054,\n" +
" \"name\": \"Edit\",\n" +
" \"description\": \"\"\n" +
" },\n" +
" \"resource\": {\n" +
" \"id\": 5728,\n" +
" \"type\": \"resource\"\n" +
" }\n" +
" }\n" +
" ]\n" +
"}";
DocumentContext parse = JsonPath.parse(json);
Object read = parse.read("$..[?((@.resource.id == 5756) && (@.role.name == 'Edit'))]");
assertNotNull(read);
}
关于java - 从 JSONPath 数组的不同对象中查询具有特定值的键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57985530/