Java 多層嵌套JSON類(lèi)型數(shù)據(jù)全面解析
多層嵌套JSON類(lèi)型數(shù)據(jù)解析
簡(jiǎn)單來(lái)說(shuō):
“key”:“value” --> 此時(shí)value為String
“key":0 --> 此時(shí)value為int
“key”:{“k1”:“v1”} --> 此時(shí)value為JSONObject
“key”:[v] --> 此時(shí)value為JSONArray
以下舉例數(shù)據(jù)結(jié)構(gòu)
{
"error": 0,
"status": "success",
"results": [
{
"currentCity": "青島",
"index": [
{
"title": "穿衣",
"zs": "較冷",
"tipt": "穿衣指數(shù)",
"des": "建議著厚外套加毛衣等服裝。年老體弱者宜著大衣、呢外套加羊毛衫。"
},
{
"title": "紫外線強(qiáng)度",
"zs": "中等",
"tipt": "紫外線強(qiáng)度指數(shù)",
"des": "屬中等強(qiáng)度紫外線輻射天氣,外出時(shí)建議涂擦SPF高于15、PA+的防曬護(hù)膚品,戴帽子、太陽(yáng)鏡。"
}
]
}
]
}
解析代碼
public class Test {
public static void main(String[] args) {
String s = "{\"error\":0,\"status\":\"success\",\"results\":[{\"currentCity\":\"青島\",\"index\":[{\"title\":\"穿衣\",\"zs\":\"較冷\",\"tipt\":\"穿衣指數(shù)\",\"des\":\"建議著厚外套加毛衣等服裝。年老體弱者宜著大衣、呢外套加羊毛衫。\"},{\"title\":\"紫外線強(qiáng)度\",\"zs\":\"最弱\",\"tipt\":\"紫外線強(qiáng)度指數(shù)\",\"des\":\"屬弱紫外線輻射天氣,無(wú)需特別防護(hù)。若長(zhǎng)期在戶外,建議涂擦SPF在8-12之間的防曬護(hù)膚品。\"}],}]}";
JSONObject jsonObject = JSONObject.fromObject(s);
//提取出error為 0
int error = jsonObject.getInt("error");
System.out.println("error:" + error);
//提取出status為 success
String status = jsonObject.getString("status");
System.out.println("status:" + status);
//注意:results中的內(nèi)容帶有中括號(hào)[],所以要轉(zhuǎn)化為JSONArray類(lèi)型的對(duì)象
JSONArray result = jsonObject.getJSONArray("results");
for (int i = 0; i < result.size(); i++) {
//提取出currentCity為 青島
String currentCity = result.getJSONObject(i).getString("currentCity");
System.out.println("currentCity:" + currentCity);
//注意:index中的內(nèi)容帶有中括號(hào)[],所以要轉(zhuǎn)化為JSONArray類(lèi)型的對(duì)象
JSONArray index = result.getJSONObject(i).getJSONArray("index");
for (int j = 0; j < index.size(); j++) {
String title = index.getJSONObject(j).getString("title");
System.out.println("title:" + title);
String zs = index.getJSONObject(j).getString("zs");
System.out.println("zs:" + zs);
String tipt = index.getJSONObject(j).getString("tipt");
System.out.println("tipt:" + tipt);
String des = index.getJSONObject(j).getString("des");
System.out.println("des:" + des);
}
}
}
}
json解析多層嵌套并轉(zhuǎn)為對(duì)應(yīng)類(lèi)(List)
Json(隨便扒的格式,將就看~)
{
"code": 1,
"message": "查詢(xún)成功",
"data": [
{
"type": 1,
"question": "地層壓力與同井深的淡水靜液壓力之比稱(chēng)為地層的()。",
"answer": "1",
"id": 1,
"description": "題目描述",
"answers": [
{
"isCorrect": "1",
"answer_name": "A的選項(xiàng)內(nèi)容"
},
{
"isCorrect": "0",
"answer_name": "B的選項(xiàng)內(nèi)容"
},
{
"isCorrect": 0,
"answer_name": "C的選項(xiàng)內(nèi)容"
},
{
"isCorect": "0",
"answer_name": "D的選項(xiàng)內(nèi)容"
}
]
},
{
"type": 1,
"question": "起鉆時(shí),產(chǎn)生的抽吸壓力導(dǎo)致井底壓力()。",
"answer": "1",
"id": 1,
"description": "題目描述",
"answers": [
{
"isCorrect": 1,
"answer_name": "A的選項(xiàng)內(nèi)容"
},
{
"isCorrect": 0,
"answer_name": "B的選項(xiàng)內(nèi)容"
},
{
"isCorrect": 0,
"answer_name": "C的選項(xiàng)內(nèi)容"
},
{
"isCorrect": 0,
"answer_name": "D的選項(xiàng)內(nèi)容"
}
]
}
]
}
關(guān)鍵依賴(lài)
<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.72</version>
</dependency>
JSONObject param = testDate();
JSONObject param1 = testHeader("QUERY");
String rDate = HealthServerHandler.getInstance().post(url,param1.toJSONString(), param.toJSONString());
//這個(gè)依賴(lài)是com.google.code.gson;因?yàn)閳?bào)錯(cuò)原因未知(報(bào)錯(cuò)下面圖中顯示),更換了阿里的依賴(lài)
//RecOrder<ResultValue<PurchaseOrder, PageInfo>> recOrder = new Gson().fromJson(rDate, RecOrder.class);
//處理json將類(lèi)填充,入庫(kù)
JSONObject rDateJSON = JSONObject.parseObject(rDate);
//這里獲取的是"resultValue"標(biāo)簽下面“data”這個(gè)JSONArray
JSONArray data = rDateJSON.getJSONObject("resultValue").getJSONArray("data");
//這里獲取的是"resultValue"標(biāo)簽下面“pageInfo”這個(gè)JSONObject
JSONObject pageInfo = rDateJSON.getJSONObject("resultValue").getJSONObject("pageInfo");
//PurchaseOrder 是具體接收類(lèi)
List<PurchaseOrder> purchaseOrder = JSONArray.parseArray(data.toString(),PurchaseOrder.class);
PageInfo pageInfo1 = JSONObject.parseObject(pageInfo.toString(),PageInfo.class);
//茵PageInfo與PurchaseOrder并不在同一結(jié)構(gòu)內(nèi),需要二次添加
for (PurchaseOrder order : purchaseOrder) {
order.setPageCount(pageInfo1.getPageCount());
order.setPageNum(pageInfo1.getPageNum());
order.setTotal(pageInfo1.getTotal());
order.setPageSize(pageInfo1.getPageSize());
service.saveOrder(order);
}

package jansonDemo;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
public class TestJSON {
/**
* JSON實(shí)際上也是鍵值對(duì)("key":"value")
* key 必須是字符串,value 可以是合法的 JSON 數(shù)據(jù)類(lèi)型(字符串, 數(shù)字, 對(duì)象, 數(shù)組, 布爾值或 null)
* value如果是字符串,用jsonobj.getString("key")獲取
* value如果是數(shù) 字,用jsonobj.getIntValue("key"),jsonobj.getFloatValue("key"),jsonobj.getInteger("key")等基本數(shù)據(jù)類(lèi)型及其包裝類(lèi)的方法獲取
* value如果是布爾值,用jsonobj.getBoolean("key"),jsonobj.getBooleanValue("key")獲取
* value如果是數(shù) 組,用jsonobj.getJSONArray("key")獲取
* value如果是Object對(duì)象,用jsonobj.get("key"),獲取
* value如果是JSONObject對(duì)象,用jsonobj.getJSONObject("key")獲取
*/
/**
* 該方法用于將已有的json字符串轉(zhuǎn)換為json對(duì)象,并取出該對(duì)象中相應(yīng)的key對(duì)應(yīng)的value值
* 將已有的字符串轉(zhuǎn)換成jsonobject,用JSON.parseObject(jsonStr)方法
* json中只要是{}就代表一個(gè)JSONObject,[]就代表一個(gè)JSONArray
* 獲取JSONObject對(duì)象用JSONObject jsonobject.getJSONObject("key")方法
* 獲取JSONArray對(duì)象用JSONObject jsonobject.getJSONArray("key")方法
*/
private static void strWritedToJSONObject() {
//以下是一個(gè)json對(duì)象中嵌套一個(gè)json子對(duì)象
String myJsonObj = "{\n" +
" \"name\":\"runoob\",\n" +
" \"alexa\":10000,\n" +
" \"sites\": {\n" +
" \"site1\":\"www.runoob.com\",\n" +
" \"site2\":\"m.runoob.com\",\n" +
" \"site3\":\"c.runoob.com\"\n" +
" }\n" +
"}";
JSONObject jsonobj = JSON.parseObject(myJsonObj); //將json字符串轉(zhuǎn)換成jsonObject對(duì)象
/***獲取JSONObject中每個(gè)key對(duì)應(yīng)的value值時(shí),可以根據(jù)實(shí)際場(chǎng)景中想得到什么類(lèi)型就分別運(yùn)用不到的方法***/
System.out.println(jsonobj.get("name")); //取出name對(duì)應(yīng)的value值,得到的是一個(gè)object
System.out.println(jsonobj.getString("name")); //取出name對(duì)應(yīng)的value值,得到的是一個(gè)String
System.out.println(jsonobj.getIntValue("alexa")); //取出name對(duì)應(yīng)的value值,得到的是一個(gè)int
System.out.println(jsonobj.get("sites")); //取出sites對(duì)應(yīng)的value值,得到的是一個(gè)object
System.out.println(jsonobj.getString("sites"));
System.out.println(jsonobj.getJSONObject("sites")); //取出sites對(duì)應(yīng)的value值,得到一個(gè)JSONObject子對(duì)象
System.out.println(jsonobj.getJSONObject("sites").getString("site2")); //取出嵌套的JSONObject子對(duì)象中site2對(duì)應(yīng)的value值,必須用getJSONObject()先獲取JSONObject
/**
* 以下是一個(gè)json對(duì)象中包含數(shù)組,數(shù)組中又包含json子對(duì)象和子數(shù)組
*/
String myJsonObj2 = "{\n" +
" \"name\":\"網(wǎng)站\",\n" +
" \"num\":3,\n" +
" \"sites\": [\n" +
" { \"name\":\"Google\", \"info\":[ \"Android\", \"Google 搜索\", \"Google 翻譯\" ] },\n" +
" { \"name\":\"Runoob\", \"info\":[ \"菜鳥(niǎo)教程\", \"菜鳥(niǎo)工具\(yùn)", \"菜鳥(niǎo)微信\" ] },\n" +
" { \"name\":\"Taobao\", \"info\":[ \"淘寶\", \"網(wǎng)購(gòu)\" ] }\n" +
" ]\n" +
"}";
JSONObject jsonobj2 = JSON.parseObject(myJsonObj2); //將json字符串轉(zhuǎn)換成jsonObject對(duì)象
System.out.println(jsonobj2.get("sites"));
System.out.println(jsonobj2.getString("sites"));
System.out.println(jsonobj2.getJSONArray("sites")); //取出sites對(duì)應(yīng)的value值,得到一個(gè)JSONOArray對(duì)象
//System.out.println(jsonobj2.getJSONObject("sites")); 不能用該方法,因?yàn)閟ites是一個(gè)JSONOArray對(duì)象
//取出json對(duì)象中sites對(duì)應(yīng)數(shù)組中第一個(gè)json子對(duì)象的值
System.out.println(jsonobj2.getJSONArray("sites").getJSONObject(0)); //得到結(jié)果:{"name":"Google","info":["Android","Google 搜索","Google 翻譯"]}
System.out.println(jsonobj2.getJSONArray("sites").get(0));
System.out.println(jsonobj2.getJSONArray("sites").getString(0));
//取出json對(duì)象中sites對(duì)應(yīng)數(shù)組中第一個(gè)json子對(duì)象下面info對(duì)應(yīng)的嵌套子數(shù)組值
System.out.println(jsonobj2.getJSONArray("sites").getJSONObject(0).getJSONArray("info")); //得到結(jié)果:["Android","Google 搜索","Google 翻譯"]
//取出json對(duì)象中sites對(duì)應(yīng)數(shù)組中第一個(gè)json子對(duì)象下面info對(duì)應(yīng)的嵌套子數(shù)組中第二個(gè)值
System.out.println(jsonobj2.getJSONArray("sites").getJSONObject(0).getJSONArray("info").getString(1)); //得到結(jié)果:Google 搜索
//依次取出json對(duì)象中sites對(duì)應(yīng)數(shù)組中的值
JSONArray array = jsonobj2.getJSONArray("sites");
getJsonArrayItem(array);
//依次取出json對(duì)象中sites對(duì)應(yīng)數(shù)組中第二個(gè)json子對(duì)象下面info對(duì)應(yīng)的嵌套子數(shù)組值
JSONArray arr = jsonobj2.getJSONArray("sites").getJSONObject(1).getJSONArray("info");
getJsonArrayItem(arr);
}
/**
* 手動(dòng)添加對(duì)象到一個(gè)JSONObject
*/
private static void writeStrToJSONObject() {
JSONObject jsonObject = new JSONObject();
jsonObject.put("name","tom");
jsonObject.put("age",20);
JSONArray jsonArray = new JSONArray();
JSONObject jsonArrayObject1 = new JSONObject();
jsonArrayObject1.put("name","alibaba");
jsonArrayObject1.put("info","www.alibaba.com");
JSONObject jsonArrayObject2 = new JSONObject();
jsonArrayObject2.put("name","baidu");
jsonArrayObject2.put("info","www.baidu.com");
jsonArray.add(jsonArrayObject1);
jsonArray.add(jsonArrayObject2);
jsonObject.put("sites",jsonArray);
System.out.println(jsonObject);
}
/**
* 將字符串轉(zhuǎn)為JSONArray
*/
private static void strToJsonArray() {
String arrayStr = "[\n" +
" {\n" +
" \"name\":\"alibaba\",\n" +
" \"info\":\"www.alibaba.com\"\n" +
" },\n" +
" {\n" +
" \"name\":\"baidu\",\n" +
" \"info\":\"www.baidu.com\"\n" +
" }\n" +
" ]";
JSONArray array = JSON.parseArray(arrayStr);
System.out.println(array);
}
/**
* 依次取出JSONArray中的值
*/
private static void getJsonArrayItem(JSONArray array) {
for (int i=0; i<array.size(); i++) {
System.out.println(array.get(i));
}
}
//測(cè)試類(lèi)
public static void main(String[] args) {
strWritedToJSONObject();
//writeStrToJSONObject();
//strToJsonArray();
}
}
JAVABEAN轉(zhuǎn)JSONObject
String jsonString=JSONObject.toJSONString(param); JSONObject jSONObject=JSONObject.parseObject(jsonString);
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
logback的使用和logback.xml詳解(小結(jié))
Logback是由log4j創(chuàng)始人設(shè)計(jì)的另一個(gè)開(kāi)源日志組件,這篇文章主要介紹了logback的使用和logback.xml詳解(小結(jié)),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-11-11
java自動(dòng)根據(jù)文件內(nèi)容的編碼來(lái)讀取避免亂碼
這篇文章主要介紹了java自動(dòng)根據(jù)文件內(nèi)容的編碼來(lái)讀取避免亂碼,需要的朋友可以參考下2014-02-02
Java創(chuàng)建類(lèi)模式_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java創(chuàng)建類(lèi)模式的相關(guān)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
Spring Task定時(shí)任務(wù)的實(shí)現(xiàn)詳解
這篇文章主要介紹了SpringBoot定時(shí)任務(wù)功能詳細(xì)解析,這次的功能開(kāi)發(fā)過(guò)程中也算是對(duì)其內(nèi)涵的進(jìn)一步了解,以后遇到定時(shí)任務(wù)的處理也更清晰,更有效率了,對(duì)SpringBoot定時(shí)任務(wù)相關(guān)知識(shí)感興趣的朋友一起看看吧2022-08-08
Android中比較常見(jiàn)的Java super關(guān)鍵字
這篇文章主要為大家介紹了Android中比較常見(jiàn)的Java super關(guān)鍵字,具有一定的學(xué)習(xí)參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01
Java?C++分別實(shí)現(xiàn)滑動(dòng)窗口的最大值
這篇文章主要介紹了分別通過(guò)Java和C++實(shí)現(xiàn)滑動(dòng)窗口最大值,即給定一個(gè)數(shù)組?nums?和滑動(dòng)窗口的大小?k,請(qǐng)找出所有滑動(dòng)窗口里的最大值。感興趣的可以了解一下2021-12-12
mybatis中的延遲加載類(lèi)型及設(shè)定詳解
這篇文章主要介紹了mybatis中的延遲加載類(lèi)型及設(shè)定詳解,MyBatis中的延遲加載,也稱(chēng)為懶加載,是指在進(jìn)行關(guān)聯(lián)查詢(xún)時(shí),按照設(shè)置延遲規(guī)則推遲對(duì)關(guān)聯(lián)對(duì)象的select查詢(xún),延遲加載可以有效的減少數(shù)據(jù)庫(kù)壓力,需要的朋友可以參考下2023-10-10
mybatis判斷l(xiāng)ist不為空/大小的問(wèn)題
這篇文章主要介紹了mybatis判斷l(xiāng)ist不為空/大小的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
Java實(shí)現(xiàn)Huffman編碼的示例代碼
Huffman編碼是一種編碼方式,本文主要介紹了Java實(shí)現(xiàn)Huffman編碼的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08

