Проблема с составлением запроса jsonpath для возврата первого объекта отфильтрованного массива

Используя оценщик пути json ashphy и следующий 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]» в конец, но это не работает.


person Blazes    schedule 22.01.2015    source источник


Ответы (1)


Я изучил сайт аналитики (Примечание: это результаты тестирования http://ashphy.com/JSONPathOnlineEvaluator/). :

введите здесь описание изображения

Размещение индекса [0] работает. Сайт просто принимает то, что будет находиться внутри аргумента jsonPath(jsonObj, строка запроса), поэтому ссылка индекса должна выходить за пределы этой оценки, чего сайт не делает.

jsonPath(foo, '$..book[?(@.category == "fiction")]')[0]
person Diniden    schedule 16.02.2015
comment
Спасибо, но это не то, что я ищу - jsonPath возвращает массив, а [0] обращается к первому элементу массива. Мне нужен jsonPath для фильтрации одного элемента. У меня нет прямого доступа к массиву. - person Blazes; 17.02.2015