前面 写了一次 kotlin解析json 但是,真的写得太烂,直接删掉了,现在重新整理一下。顺便记录一下今天坑了我很久的小问题。

  1.首先从最简单的入手吧

  一个json的字符串:=====就叫做jsonString吧

 {
    "code": "200",
    "msg": "success",
    "debugMsg": "",
    "result": {
        "data": "1231414"
        }
  }

好了怎么解析呢???

  用一个函数即可

        fun get_key_string(key:String,jsonString:String):String {
var str: String = ""
try { val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getString(key)
} catch (e: JSONException) {
e.printStackTrace()
}
return str
}

  怎么用呢???

  val msg=get_key_string("msg","jsonString")

  第一个参数=====在json字符串中,你想要解析的key,我上面的例子有 code,msg,debugMsg,result,我选择的是msg

  第二个参数=====就是json字符串的名称,就是一个字符串,不要想得太复杂了

  msg解析后的结果=====success

  2.多重解析

  依旧是上面的例子吧=====json字符串名字依旧叫做jsonString

 {
    "code": "200",
    "msg": "success",
    "debugMsg": "",
    "result": {
        "data": "1231414"
        }
  }

  我想要得到data怎么办呢???

  很简单,两步即可。

  val result=get_key_String("result","jsonString")//=====这里的第二个参数依旧是jsonString

  val data=get_key_String("data","result")//=====注意这里的第二个参数已经变成了result了

  3.解析整型,boolean类型

  这个和解析String类型类似,直接上代码吧

  

         fun get_key_boolean(key:String,jsonString:String):Boolean {//解析成Boolean
var str: Boolean =true
try {
val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getBoolean(key)
} catch (e: JSONException) {
e.printStackTrace()
}
return str
} fun get_key_int(key:String,jsonString:String):Int {//解析成Int
var str: Int=0
try {
val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getInt(key)
} catch (e: JSONException) {
e.printStackTrace()
}
return str
}

  4.稍微牛逼一点的解析=====解析成List<Map<String,Any>>=====其实这个就比较通用了,很多东西直接用这个就可以了

  比如来一个复杂一点的jsonString吧

 

{
"code": "200",
"msg": "success",
"debugMsg": "",
"result": {
"data": [
       "key1": "string"
"key2": 123
"key3": true
                      ]

}
}

  这样一个jsonString,key1对应一个字符串,key2对应一个整型,key3对应一个布尔类型

  怎么解析呢???

fun getListMap(key: String, jsonString: String): List<Map<String, Any>> {
val list = ArrayList<Map<String, Any>>()
try {
val jsonObject = JSONObject(jsonString)
val jsonArray = jsonObject.getJSONArray(key)
for (i in 0..jsonArray.length() - 1) {
val jsonObject2 = jsonArray.getJSONObject(i)
val map = HashMap<String, Any>()
val iterator = jsonObject2.keys()
while (iterator.hasNext()) {
val json_key = iterator.next()
var json_value: Any? = jsonObject2.get(json_key)
if (json_value == null) {
json_value = ""
}
map.put(json_key, json_value)
}
list.add(map)
}
} catch (e: JSONException) { e.printStackTrace()
}
return list
}

  主要有2个步骤

  val result=get_key_string("result","jsonString")

  val data=getListMap("data","result")

  就这么666

  5.将所有的可以用到的方法封装起来吧

class JsonUtil {
companion object { fun get_key_string(key:String,jsonString:String):String {
var str: String = "" try { val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getString(key) } catch (e: JSONException) {
e.printStackTrace()
}
return str
} fun get_key_boolean(key:String,jsonString:String):Boolean {
var str: Boolean =true
try {
val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getBoolean(key)
} catch (e: JSONException) {
e.printStackTrace()
}
return str
} fun get_key_int(key:String,jsonString:String):Int {
var str: Int=0
try {
val jsonObj:JSONObject= JSONObject(jsonString)
str=jsonObj.getInt(key)
} catch (e: JSONException) {
e.printStackTrace()
}
return str
} fun getList(key: String, jsonString: String): List<String> {
val list = ArrayList<String>()
try {
val jsonObject = JSONObject(jsonString)
val jsonArray = jsonObject.getJSONArray(key)
for (i in 0..jsonArray.length() - 1) {
val msg = jsonArray.getString(i)
list.add(msg)
}
} catch (e: JSONException) {
e.printStackTrace()
} return list
} fun getListMap(key: String, jsonString: String): List<Map<String, Any>> {
val list = ArrayList<Map<String, Any>>()
try {
val jsonObject = JSONObject(jsonString)
val jsonArray = jsonObject.getJSONArray(key)
for (i in 0..jsonArray.length() - 1) {
val jsonObject2 = jsonArray.getJSONObject(i)
val map = HashMap<String, Any>()
val iterator = jsonObject2.keys()
while (iterator.hasNext()) {
val json_key = iterator.next()
var json_value: Any? = jsonObject2.get(json_key)
if (json_value == null) {
json_value = ""
}
map.put(json_key, json_value)
}
list.add(map)
}
} catch (e: JSONException) { e.printStackTrace()
}
return list
} fun get_ask_Item(key:String,jsonString:String): ArrayList<MyAsk>? {
var myAsk=ArrayList<MyAsk>()
try{
val jsonObject=JSONObject(jsonString)
val jsonArray=jsonObject.getJSONArray(key)
for(i in 0..jsonArray.length()-1){
val json_ask=jsonArray.getJSONObject(i)
var my_ask=MyAsk()
val commentCount=json_ask.getString("commentCount")
val commentID=json_ask.getString("commentID")
val content=json_ask.getString("content")
val createTime=json_ask.getString("createTime")
val gender=json_ask.getString("gender")
val icon=json_ask.getString("icon")
val id=json_ask.getString("id")
val isFavorite=json_ask.getString("isFavorite")
val isZan=json_ask.getString("isZan")
val label=json_ask.getString("label")
val link=json_ask.getString("link")
val nickname=json_ask.getString("nickname")
val publisherID=json_ask.getString("publisherID")
val reward=json_ask.getString("reward")
val type=json_ask.getString("type")
val zan=json_ask.getString("zan") val image_array=json_ask.getJSONArray("image")
var image_list:ArrayList<String>?=null
for(j1 in 0..image_array.length()-1){
val image_item=image_array.getString(j1)
image_list?.add(image_item)
} val thumbnailImage_array=json_ask.getJSONArray("thumbnailImage")
var image_list2:ArrayList<String>?=null
for(j2 in 0..thumbnailImage_array.length()-1){
val image_item=thumbnailImage_array.getString(j2)
image_list2?.add(image_item)
} my_ask.commentID=commentID
my_ask.commentCount=commentCount
my_ask.content=content
my_ask.createTime=createTime
my_ask.gender=gender
my_ask.icon=icon
my_ask.id=id
my_ask.favoriteIs=isFavorite
my_ask.zan=zan
my_ask.zanIs=isZan
my_ask.label=label
my_ask.link=link
my_ask.nickname=nickname
my_ask.publisherID=publisherID
my_ask.reward=reward
my_ask.type=type
my_ask.image=image_list
my_ask.thumbnailImage=image_list2 myAsk?.add(my_ask)
}
return myAsk
}catch (e:JSONException){
e.printStackTrace()
}
return myAsk
} } }

  最后一种是自定义式解析,因为项目中的jsonString可以非常复杂,所以要自己定义一个类,然后用类似的方法来解析即可。

  因为我博客名也叫做Jason_Jan对于json还是比较情有独钟的,可以说json真的很棒

  

  推荐两个第三方库

  Ason=====github链接:https://github.com/afollestad/ason

  GsonFormat=====github链接:https://github.com/zzz40500/GsonFormat

android json 解析 kotlin的更多相关文章

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

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

  2. android json 解析简单实例

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

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

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

  4. Android JSON 解析关键代码

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

  5. Android Json解析与总结

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

  6. android json解析及简单例子

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

  7. Android JSON 解析库的使用 - Gson 和 fast-json

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族 ...

  8. android Json解析详解

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

  9. android Json解析详解(详细代码)

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

随机推荐

  1. 安装flask-mysqldb的时候,提示 mysql_config not found 的解决方法

    解决办法: sudo apt-get install libmysqlclient-dev sudo updatedb locate mysql_config 然后进入mysql_config的路径( ...

  2. 使用compiz出现奔溃的一些应急办法

    Linux Mint 17.1 CompizConfig is also installed by default so you can configure every aspect of Compi ...

  3. 2 cmd中startup显示运行不了显示“不是内部或外部命令”

    解决方案: 1 在C:\Windows\System32中检查cmd.exe是否存在(如果存在的话)(检查cmd.exe是否被误删) 2 在我的电脑——属性——环境变量——在系统变量找到Path编辑前 ...

  4. javascript的Array.prototype.map()和jQuery的jQuery.map()

    两个方法都可以根据现有数组创建新数组,但在使用过程中发现有些不同之处 以下面这个数据为例: var numbers = [1, 3, 4, 6, 9]; 1. 对undefined和null的处理 a ...

  5. SQL中如何避免书签查找

    1.使用聚集索引 对于聚集索引,索引的叶子页面和表的数据页面相同.因此,当读取聚集索引键列的值时,数据引擎可以读取其他列的值而不需要任何导航.例如前面的区间数据查询的操作,SQLServer通过B树结 ...

  6. nrm—源管理工具

    全局安装 npm install -g nrm 查看可选源 nrm ls 其中,带*的是当前使用的源,上面的输出表明当前源是hiknpm 切换源 nrm use taobao 新增源 nrm add ...

  7. pc-要实现相隔一定时间数据排序变化一次

    有时候产品会有这种要求,就是展示的数据三天是正序的,一天是逆序的,解决是: 以某一个时间点为基准点,然后获取当前的时间,然后计算差值,分情况 //专利 JPView : function(Sorder ...

  8. Zend Studio 12.5.1原版安装破解

    安装官方Zend Studio 12.5.1原版,关闭zend studio,然后将破解补丁com.zend.verifier_12.5.1.v20150514-2003.jar覆盖到 安装目录\pl ...

  9. 在mac下使用python抓取数据

    2015已经过去,这是2016的第一篇博文! 祝大家新年快乐! 但是我还有好多期末考试! 还没开始复习,唉,一把辛酸泪! 最近看了一遍彦祖的文章叫做 iOS程序员如何使用Python写网路爬虫 所以自 ...

  10. cocoapods 类库管理利器

    作为iOS开发者,第三方类库的使用是最经常的,但鉴于第三方类库的不断更新以及其可能需要依存其他类,如果要使用最新版那么我们需要重新下载再添加到项目中,无疑带来一些繁琐的麻烦,那么现在这里就有一款能解决 ...