简体   繁体   English

Java Parser Json 作为数组多维

[英]Java Parser Json as array multidimensional

I have some troubles parsing Json.我在解析 Json 时遇到了一些麻烦。 This is the Json that I have:这是我拥有的 Json:

{
  "responseHeader": {
    "status": 0,
    "QTime": 1
  },
  "response": {
    "numFound": 3447,
    "start": 0,
    "docs": [
      {
        "sku": "5848-05855-0064",
        "skus": [
          "5848-05855-0064",
          "5848-05855-0064-5340"
        ]
      },
      {
        "sku": "5848-05849-0059",
        "skus": [
          "5848-05849-0059",
          "5848-05849-0059-5340"
        ]
      }
    ]
  },
  "facet_counts": {
    "facet_queries": {},
    "facet_fields": {},
    "facet_dates": {},
    "facet_ranges": {}
  }
}
    ]
  },
  "facet_counts": {
    "facet_queries": {},
    "facet_fields": {},
    "facet_dates": {},
    "facet_ranges": {}
  }
}

I could get "sku" value with the below code:我可以使用以下代码获得“sku”值:

String jsonData = responses.body().string();

JSONObject Jobject = new JSONObject(jsonData);      
Jobject = (JSONObject) Jobject.get("response");     
Object skuValues = Jobject.get("docs");

JSONArray jArray = (JSONArray) skuValues;       
JSONObject skuConfig = jArray.getJSONObject(1);
String sku = skuConfig.getString("sku");

But I couldn't get the "skus" values.但我无法获得“skus”值。 Can someone guide me on how I can get "skus" value from the JSON?有人可以指导我如何从 JSON 中获取“skus”值?

To retrieve the skus, you can do some thing like this:-要检索 skus,您可以执行以下操作:-

JSONArray skus = skuConfig.getJSONArray("skus");

and to get the values you can do something like this:-要获得值,您可以执行以下操作:-

skus1 = skus.getString(0);

Following worked for me:以下为我工作:

Gson gson = new Gson();
Map fromJson = gson.fromJson("{  \"responseHeader\": {    \"status\": 0,    \"QTime\": 1  },  \"response\": {    \"numFound\": 3447,    \"start\": 0,    \"docs\": [      {        \"sku\": \"5848-05855-0064\",        \"skus\": [          \"5848-05855-0064\",          \"5848-05855-0064-5340\"        ]      },      {        \"sku\": \"5848-05849-0059\",        \"skus\": [          \"5848-05849-0059\",          \"5848-05849-0059-5340\"        ]      }    ]  },  \"facet_counts\": {    \"facet_queries\": {},    \"facet_fields\": {},    \"facet_dates\": {},    \"facet_ranges\": {}  }}", Map.class);
JSONObject Jobject = new JSONObject(fromJson);      
StringMap Jobject1 = (StringMap) Jobject.get("response");     
Object skuValues = Jobject1.get("docs");

ArrayList jArray = (ArrayList) skuValues;       
StringMap skuConfig = (StringMap) jArray.get(0);
System.out.println(skuConfig);
System.out.println(skuConfig.get("skus"));

Point 1: Your Sample JSON is wrong, use the following link to verify and format JSON https://jsonformatter.curiousconcept.com/ Point 1:你的Sample JSON 有误,使用以下链接验证并格式化JSON https://jsonformatter.curiousconcept.com/

Point 2: Use following code第 2 点:使用以下代码

JSONObject Jobject;
        Jobject = new JSONObject(jsonData);
        Jobject = (JSONObject) Jobject.get("response");
        JSONArray docs = Jobject.getJSONArray("docs");

        for (int i = 0; i < docs.length(); i++) {
            JSONObject skuDoc = docs.getJSONObject(i);
            String skuValue = skuDoc.optString("sku");
            JSONArray skusArr = skuDoc.getJSONArray("skus");
            System.out.println(skusArr);
        }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM