我想知道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”和那些值 但是,错误是不断发生的。 怎么解决?
答案 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");
}