Не удалось создать запрос 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]