亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解析Kotlin?JSON格式

 更新時(shí)間:2023年03月29日 15:25:13   作者:須須草  
這篇文章主要介紹了Kotlin?JSON格式解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

Kotlin JSON解析

開(kāi)發(fā)環(huán)境就是下面這個(gè)…

在這里插入圖片描述

一、添加依賴

build.gradle.kts文件中添加下面依賴。

dependencies {
    implementation("com.google.code.gson:gson:2.4")
}

二、解析JSON格式字符串

主要解析的格式如下,上面data類(lèi)與下面這個(gè)格式是配套對(duì)著的。
{"type":"allData","Dev-Area":"0757","Dev-User":"100001","Dev-Addr":"005","content":{"YxG":"0000000100000000","Ia":0.0,"Ib":0.0,"Ic":0.0,"Io":0.000},"time":1679830981975}
這條JSON格式報(bào)文中"content"內(nèi)還有其他的成員,如"YxG"、"Ia"等,所以json_packet_data內(nèi)有json_packet_content這個(gè)變量。

import com.google.gson.annotations.SerializedName

data class json_packet_content(
    @SerializedName("YxG")
    var yx:String?=null
)

data class json_packet_data(
    //序列名稱為
    @SerializedName("Dev-Area")
    var Area:String? = null,
    //設(shè)備名稱為
    @SerializedName("Dev-User")
    var User:String? = null,
    //設(shè)備名稱為
    @SerializedName("Dev-Addr")
    var Addr:String? = null,
    var type :String? = null,

    @SerializedName("content")
    var json_content: json_packet_content? = null
)

@SerializedName可以指定解析成員變量名稱,所以我這里將json_content這個(gè)變量定向?yàn)楂@取content里面的變量。其中type json成員變量同名,所以不需要重新定向,不過(guò)加上去@SerializedName("type")也不是不可以。

下面是主要程序部分

import com.google.gson.Gson
import com.google.gson.annotations.SerializedName

fun main(args: Array<String>) {

    val jsonTestString= """{"type":"allData","Dev-Area":"0757","Dev-User":"100001","Dev-Addr":"005","content":{"YxG":"0000000100000000","Ia":0.0,"Ib":0.0,"Ic":0.0,"Io":0.000},"time":1679830981975}"""
    try {
        val parseGson = Gson().fromJson(jsonTestString, json_packet_data::class.java)
        println(parseGson)
    }catch (e:com.google.gson.JsonParseException){
        println("解析異常")
    }
}

運(yùn)行效果如下

在這里插入圖片描述

然后把data類(lèi)里面的數(shù)據(jù)轉(zhuǎn)換一下,即可完成獲取相應(yīng)的數(shù)據(jù)。

還有另外一種情況,解析數(shù)組??!
{"type": [{"wait": "ss"}, {"ss": "22"}]}
情況就比如下面這個(gè)代碼一樣處理,使用List泛型??!

import com.google.gson.Gson
import com.google.gson.annotations.SerializedName

data class inter_json(
    var wait:String?=null,
    var ss:String?=null
)

data class json_mode(
    var type:List<inter_json>?=null
)

fun main(args: Array<String>) {
    val mystring = """{"type": [{"wait": "ss"}, {"ss": "22"}]}"""
    try {
        val parseGson = Gson().fromJson(mystring, json_mode::class.java)
        println(parseGson)
    }catch (e:com.google.gson.JsonParseException){
        println("解析異常")
    }
}

可以看出來(lái),操作方便簡(jiǎn)單,非常的爽?。?!

二、生成JSON格式字符串

主要是解析麻煩,生成還是比較多方法的…比如直接字符串相加…略…

到此這篇關(guān)于Kotlin JSON格式解析的文章就介紹到這了,更多相關(guān)Kotlin JSON格式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論