原文地址:https://blog.csdn.net/sinat_31057219/article/details/71518123

一、JSONObject和JSONArray的数据表示形式

JSONObject的数据是用 { } 来表示的,

例如:

{ "id" : "123", "courseID" : "huangt-test", "title" : "提交作业", "content" : null  }  

而JSONArray,顾名思义是由JSONObject构成的数组,用 [ { } , { } , …… , { } ] 来表示

例如:

 [{  "id" : "123", "courseID" : "huangt-test", "title" : "提交作业"},
{ "content" : null, "beginTime" : 1398873600000 "endTime" } ]

表示了包含2个JSONObject的JSONArray。

可以看到一个很明显的区别,一个最外面用的是 { } ,一个最外面用的是 [ ] ;

二、如何从字符串jsonString获得JSONObject对象和JSONArray对象

/*json字符串最外层是大括号时:*/
JSONObject jsonObject = new JSONObject(jsonStr); /*json字符串最外层是方括号时:*/
JSONArray jsonArray = new JSONArray(jsonStr);

三、如何从JSONArray中获得JSONObject对象

遇到方括号时,就要先获取JSONArray,然后再循环遍历出JSONObject

大家可以把JSONArray当成一般的数组来对待,只是获取的数据内数据的方法不一样。

 for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
}

注意:

/*JSONObject 获取jsonArray :需要数组的字段名*/
JSONArray jsonArray = jsonObject.getJSONArray("children"); /*jsonArray获取JSONObject : 需要遍历数组*/
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
}

四、通过JsonObject获取JSON内的具体数据:

int mid= jsonObject.getInt ( "id" ) ;
// 这里的mid得到的数据就是123. String mcourse=jsonObject.getString( " courseID") ;
// 这里的mcourse得到的数据就是huangt-test.

示例一:

{
"msg": "",
"code": "succeed",
"login_status": 0,
"mall_uid": "epet_0",
"mall_user": "",
"sys_time": 1494388655,
"push_alias": "",
"push_tags": "version3",
"categorys": [
{
"cateid": 53,
"name": "狗狗玩具",
"children": [
{
"type": "cateid",
"id": "210",
"name": "棉制玩具",
"photo": "http://i.epetbar.com/nowater/cates/2014-03/24/fcab37ead00d77bcdddf7dabe6c817d7.jpg"
},
{
"type": "cateid",
"id": "211",
"name": "橡胶玩具",
"photo": "http://i.epetbar.com/nowater/2016-07/21/14/874299e54a8cf1488d6b1bead8f8e9bb.jpg"
},
{
"type": "cateid",
"id": "212",
"name": "塑料玩具",
"photo": "http://i.epetbar.com/nowater/cates/2014-03/24/df1ed7120376370a4b5badaae61a0a7e.jpg"
},
{
"type": "cateid",
"id": "213",
"name": "手工玩具",
"photo": "http://i.epetbar.com/nowater/cates/2014-03/24/6709410560b999ab37ffb9747bb2ee71.jpg"
},
{
"type": "cateid",
"id": "3088",
"name": "食用玩具",
"photo": "http://i.epetbar.com/nowater/cates/2014-03/24/a5c7619872749790f6d6fd1ff3eccedc.jpg"
},
{
"type": "cateid",
"id": "4157",
"name": "木质玩具",
"photo": "http://i.epetbar.com/nowater/cates/2014-03/24/e9145de044fd5cec4c9b8ed47360d98f.jpg"
},
{
"type": "cateid",
"id": "4188",
"name": "梵米派",
"photo": "http://i.epetbar.com/nowater/cates/2015-07/28/45c339f6acb56364132b92f04b090c5c.jpg"
}
]
}
],
"topadv": {
"advid": "20605",
"src": "https://img2.epetbar.com/nowater/2017-04/05/14/19427a29344bcc0f385ca4718adca02f.jpg",
"title": "红脚丫",
"param": {
"mode": "web",
"param": "http://sale.epet.com/m/mould/activity/ztMTAzOA%3D%3D.html?tid=1038"
}
},
"owner": 53
}

解析如下:

注意:MyData类可以借助GsonFormat类生成实体类。

private List<MyData.CategorysBean.ChildrenBean> parseJSONOrgin(String string) {
List<MyData.CategorysBean.ChildrenBean> childrenBeanList = new ArrayList<MyData.CategorysBean.ChildrenBean>(); try {
JSONObject jsonObject = new JSONObject(string);
JSONArray jsonArray = jsonObject.getJSONArray("categorys");
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject1 = jsonArray.getJSONObject(i); JSONArray children = jsonObject1.getJSONArray("children");
for (int j = 0; j < children.length(); j++) {
JSONObject jsonObject2 = children.getJSONObject(j); MyData.CategorysBean.ChildrenBean childrenBean = new MyData.CategorysBean.ChildrenBean();
childrenBean.setName(jsonObject2.getString("name"));
childrenBean.setId(jsonObject2.getString("id"));
childrenBean.setPhoto(jsonObject2.getString("photo"));
childrenBean.setType(jsonObject2.getString("type")); childrenBeanList.add(childrenBean);
}
} } catch (JSONException e) {
e.printStackTrace();
} return childrenBeanList;
}

示例二:

[
{
"id": 582490,
"name": "单车自驾:魔幻张家界",
"photos_count": 128,
"start_date": "2016-04-05",
"end_date": "2016-04-08",
"days": 4,
"level": 4,
"views_count": 55199,
"comments_count": 34,
"likes_count": 441,
"source": "web",
"front_cover_photo_url": "http://p.chanyouji.cn/582490/1468260328216p1andi510ihgkc2f5hk6rf198.jpg",
"featured": false,
"user": {
"id": 313643,
"name": "huchichi",
"image": "http://tva2.sinaimg.cn/crop.0.12.282.282.50/5c5ee839gw1ec7kq4pasrj207v08d3zv.jpg"
}
},
{
"id": 666746,
"name": "【斯里兰卡10天】跨过山和大海",
"photos_count": 122,
"start_date": "2016-12-24",
"end_date": "2017-01-02",
"days": 10,
"level": 3,
"views_count": 33023,
"comments_count": 32,
"likes_count": 471,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/666746/1485787660939p1b7ntf07u16kdssn1tfl1ck1q1qd.jpg",
"featured": false,
"user": {
"id": 469471,
"name": "宇_RainyK",
"image": "http://a.chanyouji.cn/469471/1460020629.jpg"
}
},
{
"id": 665223,
"name": "上帝自留地探访 : 新西兰——快乐咔嚓声",
"photos_count": 250,
"start_date": "2016-11-30",
"end_date": "2016-12-04",
"days": 5,
"level": 3,
"views_count": 23981,
"comments_count": 30,
"likes_count": 533,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/1483013211/40p8jhlx7t4e8hntyhp4z31c0.jpg",
"serial_id": 664971,
"serial_position": 1,
"featured": false,
"user": {
"id": 131541,
"name": "片儿川",
"image": "http://a.chanyouji.cn/131541/1483887153821.jpg"
}
},
{
"id": 591454,
"name": "土耳其...我喜欢你,像风走了八千里",
"photos_count": 195,
"start_date": "2016-08-08",
"end_date": "2016-08-22",
"days": 15,
"level": 3,
"views_count": 18822,
"comments_count": 42,
"likes_count": 854,
"source": "web",
"front_cover_photo_url": "http://p.chanyouji.cn/1472368913/9896F012-522E-46C4-9F29-5F6D86C790DB.jpg",
"featured": false,
"user": {
"id": 208609,
"name": "晶晶姑姑娘娘",
"image": "http://a.chanyouji.cn/208609/1493099858.jpg"
}
},
{
"id": 589708,
"name": "浪迹非洲最南——“慢得啦”国闲游之一",
"photos_count": 128,
"start_date": "2016-07-23",
"end_date": "2016-07-24",
"days": 2,
"level": 3,
"views_count": 5858,
"comments_count": 4,
"likes_count": 65,
"source": "web",
"front_cover_photo_url": "http://p.chanyouji.cn/589708/1471963416200p1aqrtl1pq8js1ek0sn913uq1kdmh.jpg",
"serial_id": 589708,
"serial_position": 0,
"featured": false,
"user": {
"id": 103122,
"name": "牵着蜗牛散步的JOY",
"image": "http://tva1.sinaimg.cn/crop.0.17.640.640.50/794bd26ajw8e7tg9nfqb5j20hs0iqmxg.jpg"
}
},
{
"id": 598966,
"name": "霓虹国/留学生 梦游记录",
"photos_count": 88,
"start_date": "2016-08-28",
"end_date": "2017-05-07",
"days": 253,
"level": 3,
"views_count": 16648,
"comments_count": 10,
"likes_count": 72,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/1476365877/C9B59738-58E8-47C9-BCD1-5F2AC5CC9526.jpg",
"featured": false,
"user": {
"id": 694154,
"name": "Y-dec",
"image": "http://q.qlogo.cn/qqapp/100277927/5475C47B95A36891E2698462184F8785/100"
}
},
{
"id": 544528,
"name": "【我的年假】7 重庆—吃一顿地道火锅",
"photos_count": 385,
"start_date": "2016-08-31",
"end_date": "2016-09-03",
"days": 4,
"level": 3,
"views_count": 37214,
"comments_count": 55,
"likes_count": 530,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/544528/1474011393910p1asoupfpujrj1rnd5o813qo1jvi5.jpg",
"serial_id": 544528,
"serial_position": 0,
"featured": false,
"user": {
"id": 17010,
"name": "马兰头头2010",
"image": "http://a.chanyouji.cn/17010/1426768814.jpg"
}
},
{
"id": 665311,
"name": "就该这么玩【北海道】",
"photos_count": 118,
"start_date": "2016-12-05",
"end_date": "2016-12-12",
"days": 8,
"level": 3,
"views_count": 24644,
"comments_count": 6,
"likes_count": 108,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/1484295471/E2B2C32A-C910-490F-9F13-BC9D3B118C1B.jpg",
"featured": false,
"user": {
"id": 544219,
"name": "炘仔~",
"image": "http://a.chanyouji.cn/544219/1489641072.jpg"
}
},
{
"id": 668998,
"name": "漫步成都一一我的寻(熊)猫之旅",
"photos_count": 108,
"start_date": "2017-02-06",
"end_date": "2017-02-12",
"days": 7,
"level": 3,
"views_count": 15222,
"comments_count": 30,
"likes_count": 146,
"source": "app",
"front_cover_photo_url": "http://p.chanyouji.cn/1487129075/720F81CB-EE64-4681-8564-A9A6864AAD33.jpg",
"featured": false,
"user": {
"id": 261578,
"name": "小柠12345",
"image": "http://tva1.sinaimg.cn/crop.27.0.238.238.50/bb9ff9e8gw1eggbljiopfj208w06oaam.jpg"
}
},
{
"id": 297060,
"name": "「吃遍日本」大阪·神户·名古屋",
"photos_count": 125,
"start_date": "2015-04-25",
"end_date": "2015-05-02",
"days": 8,
"level": 4,
"views_count": 56384,
"comments_count": 121,
"likes_count": 948,
"source": "web",
"front_cover_photo_url": "http://p.chanyouji.cn/297060/1440912374444p19tuh3ukup7t1l5c1j0u8r6kfs2.jpg",
"featured": false,
"user": {
"id": 312316,
"name": "CaitlinGao",
"image": "http://tva3.sinaimg.cn/crop.0.0.640.640.50/96246e0bjw8ensjycmsdmj20hs0hsjs7.jpg"
}
}
]

解析如下:

注意:最外层是个方括号。


private List<News> parseJSONOrgin(String json) {
List<News> list = new ArrayList<News>();
try {
JSONArray jsonArray = new JSONArray(json);
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject = jsonArray.getJSONObject(i);
News news = new News();
news.setSource(jsonObject.getString("source"));
news.setFront_cover_photo_url(jsonObject.getString("front_cover_photo_url"));
news.setName(jsonObject.getString("name"));
news.setStart_date(jsonObject.getString("start_date"));
list.add(news);
}
} catch (JSONException e) {
e.printStackTrace();
}
return list;
}

JSONObject获取Float Double类型数据的准确性:

原始数据:{"status":0,"result":[{"x":114.2307489832,"y":29.579081808346}]}  

logger.error(obj.getFloatValue("x"));  

114.23075  

logger.error(obj.getDoubleValue("x"));  

114.23075103759766  

以上2个方法都无法获得完全一致的数值。

Double.valueOf(obj.get("x").toString())  

//这段代码可以准确的获取对应数值。 

示例:

homeTopBannerModel.slide_time =Float.valueOf(jSONObjectTopSlide.get("slide_time").toString());

Android-json解析:原生JSONObject+JSONArray的使用【转】的更多相关文章

  1. android JSON解析之JSONObject与GSON

    1.写在前面 JSON数据是android网络开发中常见的数据格式,JSON最常见的传输方法是使用HTTP协议,关于android开发中HTTP协议的使用方法可参考我的另一篇随笔android网络编程 ...

  2. android json解析(JSONObject方法实现)

    今天刚刚学到json解析,看了一整天,大概了解到json就是你通过一个API(我用的聚合数据的API)发送一个请求,接着会收到json数据,比如说天气预报吧,他会给你发送一大段字符串,大概是未来几天的 ...

  3. java 字符串解析为json 使用org.json包的JSONObject+JSONArray

    参考: https://blog.csdn.net/xingfei_work/article/details/76572550 java中四种json解析方式 JSONObject+JSONArray ...

  4. Android Json解析与总结

    一.JSON定义 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Progra ...

  5. Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例

    Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例 继上篇json解析,我用了原生的json解析,但是在有些情况下我们不得不承认,一些优秀的json解析框架确实十分的 ...

  6. android json 解析简单实例

    Android JSON解析跟JAVA 的JSON解析原理是一样的. Android自带的JSON方式跟方便,不需要导包啥的.不深究原理了,直接上代码: public class JsonActivi ...

  7. Android JSON 解析关键代码

    Android Json 解析其实还是蛮重要的知识点,为什么这么说呢,因为安卓通信大部分的协议都是使用 json 的方式传输,我知道以前大部分是使用的 xml ,但是时代在发展社会在进步,json 成 ...

  8. android json解析及简单例子+Android与服务器端数据交互+Android精彩案例【申明:来源于网络】

    android json解析及简单例子+Android与服务器端数据交互+Android精彩案例[申明:来源于网络] android json解析及简单例子:http://www.open-open. ...

  9. android json解析及简单例子

    JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据 ...

随机推荐

  1. third party sales process 继续说

    Trading company: A vendor或production plant: B END Customer: C third party sales与individual purchasin ...

  2. 更新SAS 9.4(64位) SID的简单方法(可以使用至2018.04.30)

    打开SAS,在程序窗口输入: PROC SETINIT RELEASE='9.4'; SITEINFO NAME='NATIONAL PINGTUNG UNI OF SCIENCE&TECH' ...

  3. js浮点数运算封装, 起因财务部分精确计算

    目录 背景 具体代码 背景 项目中用到浮点数,Int 等 js中 Number类型比较多, 加上牵涉到财务软件, 前台js运算等. 有时候会出现精确度的问题 , 公共方法中有好事者写的方法. 此处拿来 ...

  4. 通过表达式树把datareader和datatable转换为实体

    续上两篇文章,使用emit构造dynamic method,把 datareader转换为实体,以避免直接使用反射来实现带来的性能损失.代码看似没有纰漏,但是实际上我在framwork4下运行时,调用 ...

  5. Java 6- Java 运算符

    计算机的最基本用途之一就是执行数学运算,作为一门计算机语言,Java也提供了一套丰富的运算符来操纵变量.我们可以把运算符分成以下几组: 算术运算符 关系运算符 位运算符 逻辑运算符 赋值运算符 其他运 ...

  6. 字符串切分 String.Split 和 Regex.Split(小技巧)

    当切割字符串的是单个字符时可使用String.Split string strSample="ProductID:20150215,Categroy:Food,Price:15.00&quo ...

  7. JVM总结-异常处理

    众所周知,异常处理的两大组成要素是抛出异常和捕获异常.这两大要素共同实现程序控制流的非正常转移. 抛出异常可分为显式和隐式两种.显式抛异常的主体是应用程序,它指的是在程序中使用“throw”关键字,手 ...

  8. 有趣的console.log(console.log输出彩色字,图片等)

    亲们支持我的新博客哦==>原文地址 ) 逛网站的时候经常发现很多网站控制台打印了很好玩的内容 比如我的网站 →calamus 或者知乎→ 平时是不是只用console调试或者打印别的信息了,没有 ...

  9. AJAX发送 PUT和DELETE请求参数传递注意点,了解一下

    ajax发送put 和 delete 请求时,需要传递参数,如果参数在url地址栏上,则可以正常使用, 如果在 data:中需要传递参数,(浏览器会使用表单提交的方式进行提交) 则需要注意此时应作如下 ...

  10. ORA-01940:无法删除当前已链接的用户(转)

    (1)查看用户的连接状况 select username,sid,serial# from v$session ------------------------------------------ 如 ...