使用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í)際場(chǎng)景中想得到什么類型就分別運(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)); } } //測(cè)試類 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-01Mybatis-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-01Mybatis攔截器注解@Intercepts與@Signature注解使用
本文主要介紹了Mybatis攔截器注解@Intercepts與@Signature注解使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07Java開發(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-12Mybatis中and和循環(huán)or混用操作(or轉(zhuǎn)換成in)
這篇文章主要介紹了Mybatis中and和循環(huán)or混用操作(or轉(zhuǎn)換成in),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07