Не удалось создать запрос jsonpath для возврата первого объекта отфильтрованного массива
Используя ashphy json path оценщик и следующий JSON:
{ "store": {
"book": [
{ "category": "reference",
"author": "Nigel Rees",
"title": "Sayings of the Century",
"price": 8.95
},
{ "category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
},
{ "category": "fiction",
"author": "Herman Melville",
"title": "Moby Dick",
"isbn": "0-553-21311-3",
"price": 8.99
},
{ "category": "fiction",
"author": "J. R. R. Tolkien",
"title": "The Lord of the Rings",
"isbn": "0-395-19395-8",
"price": 22.99
}
],
"bicycle": {
"color": "red",
"price": 19.95
}
}
}
Я хотел бы написать запрос, который фильтрует категорию, например. "вымысел", а затем вернуть только первый элемент. Я не могу понять, как это понять.
Например, $..book[?(@.category == "fiction")]
, вернет массив из 3 книг, но мне просто нужна первая книга:
{ "category": "fiction",
"author": "Evelyn Waugh",
"title": "Sword of Honour",
"price": 12.99
}
Можно ли это сделать??? Очевидно, казалось, что добавить "[0]" до конца, но это не сработает.
Ответы
Ответ 1
Я исследовал сайт аналитики (Примечание: это от тестирования http://ashphy.com/JSONPathOnlineEvaluator/):
![enter image description here]()
Размещение индекса [0] вверх DOES работает. Сайт просто принимает то, что войдет в аргумент jsonPath (jsonObj, строка запроса), поэтому ссылка на индекс должна выйти за пределы этой оценки, которую сайт не делает.
jsonPath(foo, '$..book[?(@.category == "fiction")]')[0]