通过Android简单的JSON解析(一)我们大概了解了最简单的JSON数据解析方法,这次我们稍微把这个JSON数据变复杂点:
这次的JSON数据比之前多了包含对象的jsonArray对象和jsonObject对象
String json = "{"+ " \"query\": \"Pizza\", "
+ " \"locations\": [ 94043, 90210 ] ,"
+ " \"name\" : { \"first\" : \"M\", \"se\" : \"yu\"} ,"
+ " \"array\" : [ { \"a\" : 1} , { \"b\" : 2 } ] "
+ "}";
直接上代码:
package com.example.myjsondemo;
import org.json.JSONArray;
import org.json.JSONObject;
import org.json.JSONTokener;
import android.os.Bundle;
import android.util.Log;
import android.app.Activity;
public class MainActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// String json = "{"
// + " \"query\": \"Pizza\", "
// + " \"locations\": [ 94043, 90210 ] "
// + "}";
String json = "{" + " \"query\": \"Pizza\", "
+ " \"locations\": [ 94043, 90210 ] ,"
+ " \"name\" : { \"first\" : \"M\", \"se\" : \"yu\"} ,"
+ " \"array\" : [ { \"a\" : 1} , { \"b\" : 2 } ] "
+ "}";
try {
// 通过JSONTokener的nextValue()获得JSONObject对象
JSONObject object = (JSONObject) new JSONTokener(json).nextValue();
// 获取"query"键对应的value值
String query = object.getString("query");
Log.v("json", "-->query =" + query);
// 返回索引对应的value值
JSONArray locations = object.getJSONArray("locations");
for (int i = 0; i < locations.length(); i++) {
// 遍历JSONArray,取出Value值
int id = locations.getInt(i);
Log.v("json", "-->id =" + id);
}
//解析name对象中的key/value数据
String firstName = object.getJSONObject("name").getString("first");
String seName = object.getJSONObject("name").getString("se");
Log.v("json", "-->firstName = " + firstName + " seName=" + seName);
//解析array对象数组中的key/value数据
//getJSONObject(0)中的参数为数组的下标
int number1 = object.getJSONArray("array").getJSONObject(0).getInt("a");
int number2 = object.getJSONArray("array").getJSONObject(1).getInt("b");
Log.v("json", "-->number1="+ number1 + " number2=" + number2);
} catch (Exception e) {
// TODO: handle exception
Log.v("json", "-->Exception Exception");
}
}
}
打印信息为:
V/json ( 2614): -->query =Pizza
V/json ( 2614): -->id =94043
V/json ( 2614): -->id =90210
V/json ( 2614): -->firstName = M seName=yu
V/json ( 2614): -->number1=1 number2=2