android json 解析 kotlin
前面 写了一次 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的更多相关文章
- Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例
Android JSON解析库Gson和Fast-json的使用对比和图书列表小案例 继上篇json解析,我用了原生的json解析,但是在有些情况下我们不得不承认,一些优秀的json解析框架确实十分的 ...
- android json 解析简单实例
Android JSON解析跟JAVA 的JSON解析原理是一样的. Android自带的JSON方式跟方便,不需要导包啥的.不深究原理了,直接上代码: public class JsonActivi ...
- android json解析及简单例子+Android与服务器端数据交互+Android精彩案例【申明:来源于网络】
android json解析及简单例子+Android与服务器端数据交互+Android精彩案例[申明:来源于网络] android json解析及简单例子:http://www.open-open. ...
- Android JSON 解析关键代码
Android Json 解析其实还是蛮重要的知识点,为什么这么说呢,因为安卓通信大部分的协议都是使用 json 的方式传输,我知道以前大部分是使用的 xml ,但是时代在发展社会在进步,json 成 ...
- Android Json解析与总结
一.JSON定义 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写.同时也易于机器解析和生成. 它基于JavaScript Progra ...
- android json解析及简单例子
JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据 ...
- Android JSON 解析库的使用 - Gson 和 fast-json
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族 ...
- android Json解析详解
JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语 言的支持),从而可以在不同平台间进行数 ...
- android Json解析详解(详细代码)
JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据 ...
随机推荐
- 安装flask-mysqldb的时候,提示 mysql_config not found 的解决方法
解决办法: sudo apt-get install libmysqlclient-dev sudo updatedb locate mysql_config 然后进入mysql_config的路径( ...
- 使用compiz出现奔溃的一些应急办法
Linux Mint 17.1 CompizConfig is also installed by default so you can configure every aspect of Compi ...
- 2 cmd中startup显示运行不了显示“不是内部或外部命令”
解决方案: 1 在C:\Windows\System32中检查cmd.exe是否存在(如果存在的话)(检查cmd.exe是否被误删) 2 在我的电脑——属性——环境变量——在系统变量找到Path编辑前 ...
- javascript的Array.prototype.map()和jQuery的jQuery.map()
两个方法都可以根据现有数组创建新数组,但在使用过程中发现有些不同之处 以下面这个数据为例: var numbers = [1, 3, 4, 6, 9]; 1. 对undefined和null的处理 a ...
- SQL中如何避免书签查找
1.使用聚集索引 对于聚集索引,索引的叶子页面和表的数据页面相同.因此,当读取聚集索引键列的值时,数据引擎可以读取其他列的值而不需要任何导航.例如前面的区间数据查询的操作,SQLServer通过B树结 ...
- nrm—源管理工具
全局安装 npm install -g nrm 查看可选源 nrm ls 其中,带*的是当前使用的源,上面的输出表明当前源是hiknpm 切换源 nrm use taobao 新增源 nrm add ...
- pc-要实现相隔一定时间数据排序变化一次
有时候产品会有这种要求,就是展示的数据三天是正序的,一天是逆序的,解决是: 以某一个时间点为基准点,然后获取当前的时间,然后计算差值,分情况 //专利 JPView : function(Sorder ...
- Zend Studio 12.5.1原版安装破解
安装官方Zend Studio 12.5.1原版,关闭zend studio,然后将破解补丁com.zend.verifier_12.5.1.v20150514-2003.jar覆盖到 安装目录\pl ...
- 在mac下使用python抓取数据
2015已经过去,这是2016的第一篇博文! 祝大家新年快乐! 但是我还有好多期末考试! 还没开始复习,唉,一把辛酸泪! 最近看了一遍彦祖的文章叫做 iOS程序员如何使用Python写网路爬虫 所以自 ...
- cocoapods 类库管理利器
作为iOS开发者,第三方类库的使用是最经常的,但鉴于第三方类库的不断更新以及其可能需要依存其他类,如果要使用最新版那么我们需要重新下载再添加到项目中,无疑带来一些繁琐的麻烦,那么现在这里就有一款能解决 ...