前面 写了一次 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. Django组件:用户认证组件

    一丶用户认证 1.auth模块 from django.contrib import auth django.contrib.auth中提供了许多方法,这里主要介绍其中的三个: (1).authent ...

  2. mysql对库,表,数据类型的操作以及完整性约束

    一丶对库的操作 求救语法: help create database; 1.创建数据库 CREATE DATABASE 数据库名 charset utf8; 2.数据库的命名规则: 可以由字母.数字. ...

  3. socket网络套节字---聊天室

    一:服务端: 1.创建客户端: package com.ywh.serversocket; import java.io.InputStream; import java.io.OutputStrea ...

  4. Python开发环境Wing IDE如何进行命令行调试

    Wing IDE专业的调试探针提供了一种强大的方法来发现和解决复杂的错误.这很像Python Shell但允许用户直接参与进已经暂停的调试程序中: 通过键入在刚才发生异常的地方键入下列数值进行尝试: ...

  5. 观察者模式(Observe Pattern)

    观察者模式: 当对象存在一对多关系时,使用观察者模式(Observe Pattern).例如:当一个对象被修改时,会通知它的依赖对象. 介绍: 1.意图:定义对象的一种一对多的依赖关系,当一个对象的状 ...

  6. HDevEngine in .NET Applications MultiThreading

    Basics To use HDevEngine in Visual Studio .NET, you must add a reference to the HALCON/.NET assembly ...

  7. LeetCode Remove Duplicates from Sorted Array删除整型数组中的重复元素并返回剩下元素个数

    class Solution { public: int removeDuplicates(int A[], int n) { ],*e=&A[]; //s指向开头第一个,e往后遍历相同的 i ...

  8. Windows底层开发前期学习准备工作

    1.若对Windows底层开发没有兴趣,不建议继续深究, 若有些兴趣可以继续. 2. 先广泛打基础,比如C/ASM/C++/MFC,再学习Windows核心编程,对R3上的一些开发有所熟悉,再系统的学 ...

  9. POJ 3469 Dual Core CPU(最小割模型的建立)

    分析: 这类问题的一遍描述,把一些对象分成两组,划分有一些代价,问最小代价.一般性的思路是, 把这两组看成是S点和T点,把划分的代价和割边的容量对应起来求最小割. 把S和可模版tem之间到达关系看作是 ...

  10. hdu-1598 find the most comfortable road---kruskal+枚举下界

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1598 题目大意: XX星有许多城市,城市之间通过一种奇怪的高速公路SARS(Super Air Ro ...