Выберите N-й элемент из выражения фильтра в JSONPath

Я пытался отфильтровать определенный элемент в моем JSON с помощью JSONPath, а затем выбрать только 1-й элемент в возвращаемом массиве результатов.

Мой baisc JSONPath выглядит примерно так:

$.store.book[?(@.category==fiction)].price

Я хочу добавить этот [0] фильтр следующим образом:

$.store.book[?(@.category==fiction)][0].price

но он не возвращает результатов, или если я поставлю [0] после последней «цены», я получу эту ошибку:

Фильтр: [0] ['price'] может применяться только к массивам

Я искал и не смог найти правильный синтаксис для извлечения 1-го элемента в массиве после применения фильтра, как в xpath.

Это базовый 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
    }
  }
}

person Roy_ro    schedule 19.05.2015    source источник
comment
Это не реализовано в json-path 2.2.0, см. github.com/json-path / JsonPath / issues / 272   -  person banterCZ    schedule 06.06.2017


Ответы (2)


На данный момент единственное решение:

List<Double> prices = JsonPath
   .parse(json)
   .read("$.store.book[?(@.category == 'fiction')].price");

Double firstPrice = prices.isEmpty() ? null : prices.get(0);
person kalle    schedule 21.05.2015

как насчет того, чтобы использовать jsonpath с Spring mvc, у меня в итоге

.andExpect(jsonPath("$[?(@.name.value == 'Item')].depth", is(Collections.singletonList(2))))

вместо

.andExpect(jsonPath("$[?(@.name.value == 'Item')][0].depth", is(2)))

который, кстати, работал у меня в более старых версиях (0.9.1)

person kayoubi    schedule 26.05.2015