如何使用GSON获取JSON数组中的值

时间:2018-06-10 16:30:38

标签: java json gson

我想知道JSON数组中的选择值。

我的JSON是

{
  "meta": {
    "is_end": true,
    "total_count": 1,
    "pageable_count": 1
  },
  "documents": [
    {
      "road_address": {
        "undergroun_yn": "N",
        "road_name": "충대로",
        "underground_yn": "N",
        "region_2depth_name": "청주시 서원구",
        "zone_no": "28644",
        "sub_building_no": "",
        "region_3depth_name": "개신동",
        "main_building_no": "1",
        "address_name": "충북 청주시 서원구 충대로 1",
        "y": "36.63003935314667",
        "x": "127.45479196889647",
        "region_1depth_name": "충북",
        "building_name": "충북대학교"
      },
      "address_name": "충북 청주시 서원구 충대로 1",
      "address": {
        "b_code": "4311210900",
        "region_3depth_h_name": "성화.개신.죽림동",
        "main_address_no": "12",
        "h_code": "4311259000",
        "region_2depth_name": "청주시 서원구",
        "main_adderss_no": "12",
        "sub_address_no": "",
        "region_3depth_name": "개신동",
        "address_name": "충북 청주시 서원구 개신동 12",
        "y": "36.6284039605616",
        "x": "127.45921419389084",
        "mountain_yn": "N",
        "zip_code": "361763",
        "region_1depth_name": "충북",
        "sub_adderss_no": ""
      },
      "y": "36.63003935314667",
      "x": "127.45479196889647",
      "address_type": "ROAD_ADDR"
    }
  ]
}

但是,发生了这样的代码错误:“ java.lang.IllegalStateException:Not a JSON Object” 所以,我尝试解决它们并进行多种搜索。 我不使用'meta'的一部分只使用JSON中的'documents'。 比,我写的java代码。 我的原始代码是

JsonElement jsonElement = parser.parse(html.toString()).getAsJsonObject();
JsonObject rootObj = jsonElement.getAsJsonObject();


        JsonObject element = rootObj.get("documents").getAsJsonObject();
        String y = element.getAsJsonObject().get("x").toString();
        String x = element.getAsJsonObject().get("y").toString();

        System.out.println(y);
        System.out.println(x);
        System.out.println(html.toString());
        return html.toString();

我知道“文档”是JSON数组,所以我修改了我的代码。 我修改过的java代码是

    JsonElement jsonElement = parser.parse(html.toString()).getAsJsonObject();
    JsonObject rootObj = jsonElement.getAsJsonObject();
    String y = rootObj.getAsJsonArray().get(Integer.parseInt("x")).toString();
    String x = rootObj.getAsJsonArray().get(Integer.parseInt("y")).toString();

        System.out.println(y);
        System.out.println(x);
        System.out.println(html.toString());
        return html.toString();

但也发生错误,说“ java.lang.IllegalStateException:Not a JSON Array ” 我希望得到像

这样的结果
{
"documents": [
        {
          "road_address": {
            "undergroun_yn": "N",
            "road_name": "충대로",
            "underground_yn": "N",
            "region_2depth_name": "청주시 서원구",
            "zone_no": "28644",
            "sub_building_no": "",
            "region_3depth_name": "개신동",
            "main_building_no": "1",
            "address_name": "충북 청주시 서원구 충대로 1",
            "y": "36.63003935314667",
            "x": "127.45479196889647",
            "region_1depth_name": "충북",
            "building_name": "충북대학교"
          },
          "address_name": "충북 청주시 서원구 충대로 1",
          "address": {
            "b_code": "4311210900",
            "region_3depth_h_name": "성화.개신.죽림동",
            "main_address_no": "12",
            "h_code": "4311259000",
            "region_2depth_name": "청주시 서원구",
            "main_adderss_no": "12",
            "sub_address_no": "",
            "region_3depth_name": "개신동",
            "address_name": "충북 청주시 서원구 개신동 12",
            "y": "36.6284039605616",
            "x": "127.45921419389084",
            "mountain_yn": "N",
            "zip_code": "361763",
            "region_1depth_name": "충북",
            "sub_adderss_no": ""
          },
          "y": "36.63003935314667",
          "x": "127.45479196889647",
          "address_type": "ROAD_ADDR"
        }
      ]
    }
}

并获取键“x”,“y”和那些值 但是,错误是不断发生的。 怎么解决?

1 个答案:

答案 0 :(得分:3)

您应该遍历JSONArray以查找JSONObject,然后读取x和y值。

JsonElement jsonElement = parser.parse(html.toString()).getAsJsonObject();
JsonObject rootObj = jsonElement.getAsJsonObject();
JsonArray documents = (JsonArray) rootObj.get("documents");
Iterator < JsonElement > itr = documents.iterator();
while (itr.hasNext()) {
 JsonObject jsonObject = (JsonObject) itr.next();
 double x = jsonObject.getDouble("x");
 double y = jsonObject.getDouble("y");
}