Как искать/найти в JSON с java

У меня есть строка JSON ниже, я хочу найти/поиск критериев в строке JSON.

1). Чтобы найти Количество присутствующих ключей. 2). Чтобы получить значения данного ключа (если у нас есть массив)

{
"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
    }
},
 "expensive": 10
}

Я ищу решение, такое как синтаксис Groovy GPath

  • store.book - размер этого массива.
  • store.book[*].category - сколько раз ключ присутствует в массиве.
  • store.bicycle - если он найден, он должен вернуть истинное значение

person Ssire    schedule 11.03.2015    source источник


Ответы (4)


Вы также можете использовать проект JsonPath, предоставленный REST Assured. В этом проекте JsonPath используются выражения Groovy GPath. В Maven вы можете зависеть от него следующим образом:

<dependency>
    <groupId>com.jayway.restassured</groupId>
    <artifactId>json-path</artifactId>
    <version>2.4.0</version>
</dependency>

Примеры:

Чтобы получить список всех категорий книг:

List<String> categories = JsonPath.from(json).get("store.book.category");

Получить первую категорию книг:

String category = JsonPath.from(json).get("store.book[0].category");

Получить последнюю категорию книг:

String category = JsonPath.from(json).get("store.book[-1].category");

Получить все книги по цене от 5 до 15:

List<Map> books = JsonPath.from(json).get("store.book.findAll { book -> book.price >= 5 && book.price <= 15 }");

GPath очень мощен, и вы можете использовать функции более высокого порядка и все структуры данных Groovy в своих выражениях пути.

person Johan    schedule 16.03.2015
comment
Есть ли какая-либо документация для этого? groovy.codehaus.org/GPath больше не существует. - person Varun Mulloli; 25.08.2015
comment
На веб-сайте REST Assured есть некоторая документация. См. здесь: github.com /jayway/весьма уверенный/вики/ - person Johan; 25.08.2015

Я бы попробовал следующую библиотеку

https://github.com/jayway/JsonPath

http://jsonpath.herokuapp.com/?path=%24.store.book[*]

дает вам все книги

person David Michael Gang    schedule 11.03.2015
comment
Привет, Дэвид, я использую только тот же, но я ищу код Java для вышеуказанной проблемы. Например, если я даю параметру метода как store.book[*].category этот ключ JSON, он должен указать, сколько ключей присутствует с этим как java int - person Ssire; 11.03.2015
comment
Я думаю, вы получаете их в виде списка, а затем можете использовать docs.oracle.com/javase/7/docs/api/java/util/ функция - person David Michael Gang; 11.03.2015
comment
Спасибо @David Michael Gang, я нашел решение. еще раз спасибо за ваш ценный вклад - person Ssire; 12.03.2015

Прежде всего, вы должны добавить зависимость

<dependency>
    <groupId>org.json</groupId>
    <artifactId>json</artifactId>
    <version>20090211</version>
</dependency>

Затем вы можете использовать этот код:

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import org.json.XML;

public class Main {

    public static int PRETTY_PRINT_INDENT_FACTOR = 4;
    public static String TEST_XML_STRING =
        "<Result><ResultParameters><ResultParameter><Key>TransEndDate</Key><Value>20170731</Value></ResultParameter><ResultParameter><Key>Failed Reason</Key><Value>Operator 03058361178\03058365278 has no permission to perform the Check Balance service.</Value></ResultParameter><ResultParameter><Key>TransEndTime</Key><Value>123611</Value></ResultParameter></ResultParameters><ResultCode>2000</ResultCode><ResultType>0</ResultType><OriginatorConversationID>S_X20130129210125</OriginatorConversationID><ResultDesc>Initiator authentication error.</ResultDesc><TransactionID>000749213589</TransactionID><ConversationID>AG_20170731_00004c28e51f1f822e9e</ConversationID></Result>";

    public static void main(String[] args) {
        try {
            JSONObject xmlJSONObj = XML.toJSONObject(TEST_XML_STRING);
            String jsonPrettyPrintString = xmlJSONObj.toString(PRETTY_PRINT_INDENT_FACTOR);
            System.out.println(jsonPrettyPrintString);


            System.out.println("Element="+xmlJSONObj.getJSONObject("Result").getInt("ResultCode"));

        } catch (JSONException je) {
            System.out.println(je.toString());
        }
    }
}

// in it i am searching an element which is present in a json object 
person Usman Yaqoob    schedule 31.07.2017

Во-первых, добавьте зависимость json-path в pom

<dependency>
     <groupId>com.jayway.jsonpath</groupId>
     <artifactId>json-path</artifactId>
     <version>2.2.0</version>
</dependency>

Создайте утилиту в базовом классе, которую можно использовать повторно:

 public static String getValueFromJsonPath(String apiResponse, String jsonPath) {
        return JsonPath.read(apiResponse, jsonPath);
    }

Один из примеров использования этого метода:

getValueFromJsonPath(apiResponse, "$.store.book[0].category");

ПРИМЕЧАНИЕ. Создайте перегруженный метод с различными типами возврата в зависимости от ожидаемого результата (например, List для получения списка из json).

person Navpreet Singh    schedule 17.07.2020