使用Jackson-json解析一個(gè)嵌套的json字符串
Jackson-json解析一個(gè)嵌套的json字符串
最近想嘗試一下java的爬蟲的編寫,于是不可避免的遇到了要處理json數(shù)據(jù)的問題,于是乎用到了Jackson-json這個(gè)jar包
關(guān)于這個(gè)jar包
先在工程中導(dǎo)入這個(gè)jar包,然后創(chuàng)建一個(gè)ObjectMapper對(duì)象
ObjectMapper objectmapper=new ObjectMapper;
然后讀入我的json字符串(str)
得到JsonNode對(duì)象
JsonNode node=mapper.readTree(str);
之后就是處理這個(gè)JsonNode對(duì)象了
但是我的json字符串長這樣

把節(jié)點(diǎn)展開

但其實(shí)我只要shops屬性下的json,所以這里相當(dāng)于json對(duì)象的嵌套
所以我讀進(jìn)來的這個(gè)node其實(shí)就只有一個(gè)Json,我得一步一步往下取,當(dāng)我取到shops時(shí)就會(huì)出現(xiàn)40個(gè)Json
JsonNode lastnode=node.get("result").get("1584548").get("result").get(0).get("shops");
要注意的一點(diǎn)是
//必須確保node是一個(gè)json數(shù)組,不能像頂層那樣只是一個(gè)json,不然直接用索引取會(huì)得到null,而且下標(biāo)從零開始
取到shops時(shí)就簡單了,貼上代碼
JsonNode newnode=null;
List<Shop> shoplist=new ArrayList<>();
for(int i=0;i<lastnode.size();i++) {
newnode=lastnode.get(i);
Shop shop=new Shop();
shop.setWord(newnode.get("item_title").asText());
shop.setImg(newnode.get("item_pic").asText());
shop.setPrice(newnode.get("item_current_price").asLong());
shoplist.add(shop);
}
for(int j=0;j<shoplist.size();j++) {
System.out.println(shoplist.get(j));
}
最后的結(jié)果

java解析多層嵌套json字符串
java分別解析下面兩個(gè)json字符串


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ù)類型(字符串, 數(shù)字, 對(duì)象, 數(shù)組, 布爾值或 null)
* value如果是字符串,用jsonobj.getString("key")獲取
* value如果是數(shù) 字,用jsonobj.getIntValue("key"),jsonobj.getFloatValue("key"),jsonobj.getInteger("key")等基本數(shù)據(jù)類型及其包裝類的方法獲取
* 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í)際場景中想得到什么類型就分別運(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\":[ \"菜鳥教程\", \"菜鳥工具\(yùn)", \"菜鳥微信\" ] },\n" +
" { \"name\":\"Taobao\", \"info\":[ \"淘寶\", \"網(wǎng)購\" ] }\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));
}
}
//測試類
public static void main(String[] args) {
strWritedToJSONObject();
//writeStrToJSONObject();
//strToJsonArray();
}
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Jackson使用示例-Bean、XML、Json之間相互轉(zhuǎn)換
- 一篇文章了解Jackson注解@JsonFormat及失效解決辦法
- Java中對(duì)象?和?json?互轉(zhuǎn)四種方式?json-lib、Gson、FastJson、Jackson
- 利用Jackson解決Json序列化和反序列化問題
- Java利用Jackson輕松處理JSON序列化與反序列化
- Jackson中json格式的字符串與對(duì)象的互相轉(zhuǎn)換方式
- 如何自定義Jackson序列化?@JsonSerialize
- JSON中fastjson、jackson、gson如何選擇
- jackson 如何將實(shí)體轉(zhuǎn)json json字符串轉(zhuǎn)實(shí)體
- 使用jackson實(shí)現(xiàn)對(duì)象json之間的相互轉(zhuǎn)換(spring boot)
- Jackson庫進(jìn)行JSON?序列化時(shí)遇到了無限遞歸(Infinite?Recursion)的問題及解決方案
相關(guān)文章
Spring Cloud Gateway 獲取請(qǐng)求體(Request Body)的多種方法
這篇文章主要介紹了Spring Cloud Gateway 獲取請(qǐng)求體(Request Body)的多種方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Mybatis-Plus主鍵插入null值報(bào)錯(cuò)問題及解決
這篇文章主要介紹了Mybatis-Plus主鍵插入null值報(bào)錯(cuò)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
使用bat啟動(dòng)springboot項(xiàng)目并解決亂碼問題
這篇文章主要介紹了window中使用bat啟動(dòng)springboot項(xiàng)目,并解決亂碼問題2021-06-06
詳解Java刪除Map中元素java.util.ConcurrentModificationException”異常解決
這篇文章主要介紹了詳解Java刪除Map中元素java.util.ConcurrentModificationException”異常解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
Mybatis攔截器注解@Intercepts與@Signature注解使用
本文主要介紹了Mybatis攔截器注解@Intercepts與@Signature注解使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
Java開發(fā)者結(jié)合Node.js編程入門教程
這篇文章主要介紹了Java開發(fā)者結(jié)合Node.js編程入門教程,我將先向您展示如何使用Java EE創(chuàng)建一個(gè)簡單的Rest服務(wù)來讀取 MongoDB數(shù)據(jù)庫。然后我會(huì)用node.js來實(shí)現(xiàn)相同的功能,需要的朋友可以參考下2014-09-09
關(guān)于Maven依賴沖突解決之exclusions
這篇文章主要介紹了關(guān)于Maven依賴沖突解決之exclusions用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
Mybatis中and和循環(huán)or混用操作(or轉(zhuǎn)換成in)
這篇文章主要介紹了Mybatis中and和循環(huán)or混用操作(or轉(zhuǎn)換成in),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07

