当前位置 博文首页 > 阿伟~:一个非常棒的Go-Json解析库

    阿伟~:一个非常棒的Go-Json解析库

    作者:阿伟~ 时间:2021-01-25 14:55

    json是一种数据格式,经常被用作数据交换,页面展示,序列化等场景,基本每种语言都有对应的json解析框架,Go语言也不例外,并且内置了json库,基本能够满足一些普通开发场景,但有些复杂场景下就不太理想了,因此找一个好用的开源的json库就非常有必要了,先放地址

    https://github.com/bitly/go-simplejson
    

    内置json库的使用

    我们创建一个如下结构体,用来测试内置json库和开源的json库,一起看看使用上是来怎么操作的呢?

    //omitempty  这个属性可以在序列化时忽略0值和nil值
    // score 不能序列化,属于私有字段
    type Student struct {
        Id       int                `json:"id"` //如果想json后的id是字符串可以这样写  `json:"id,string"`
        Name     string             `json:"name"`
        Age      int                `json:"age"`
        score    map[string]float32 `json:"score"`
        Phone    string             `json:"phone,omitempty"`
        Birthday JsonTime           `json:"birthday"`
    }
    

    内置的json库基本上就两个方法 ToJson和FromJson,把一个对象转换为json字符串,把json字符串转化为对象,如下两个api,如果我们想要从json字符串中获取某个key时,或者想要知道某个value的类型时,此时内置库就不支持了,我们就需要想别的办法了

    result, err := json.Marshal(v interface{})
    err := json.Unmarshal(jsonStr []byte, v interface{})
    //序列化
    func ToJson(v interface{}) (string, error) {
        result, err := json.Marshal(v)
        if err != nil {
            return "", nil
        }
        return string(result), nil
    }
    //反序列化
    func FromJson(jsonStr []byte, v interface{}) error {
        err := json.Unmarshal(jsonStr, v)
        if err != nil {
            log.Fatalln(err)
            return err
        }
        return nil
    }
    

    simple-json的使用

    这个框架使用起来非常简单,并且源码也非常简洁,只有三个源码文件,三个测试文件,感兴趣的同学可以研究下源码实现,simple-json是一个json解析库,就是说对json字符串进行解析,本身不支持序列化和反序列化
    我们构造一个json字符串,然后使用simple-json根据我们的场景来解析这个字符串,得到我们想要的结果

    s := `{
            "tagA" : "json string",
            "tagB" : 1024,
            "tagD" : {
                "tagE":1000
            },
            "tagF":[
                "json array",
                1024,
                {"tagH":"json object"}
            ]
    }`
    

    首先我们获取一个json实例,框架本身支持多种方法获取一个json实力,可以直接创建,也可以在创建时直接指定一个json字符串,也可以通过文件的形式创建,这里我们使用使用第二种方式,也就是使用上面代码中的json2

    json1 := simplejson.New()
    json2 := simplejson.NewJson(bs [] byte)
    json3 := simplejson.NewFromReader(r io.Reader)
    

    1、第一个场景,获取key时tagA的值,下面代码中Get方法返回的还是Json实例,想要具体的值,得转换成值所对应得类型,假设我们已经知道这个值的类型,那么直接.String()就得到结果了

    tagAValue ,err := json2.Get("tagA").String()
    

    2、第二个场景, 获取数组中的key为tagH的值,首先获取tagF,返回Json实例,对应的是一个数组,获取下标为2的Json实例,再从这个Json实例中获取key为tagH的value
    j,err := json2.Get("tagF").GetIndex(2).Get("tagH").String()
    3、第三个场景,检查某一个key是否存在,第一个反馈的值是json实例,第二个返回的值是bool类型,true代表存在,false代表不存在,如果存在我们可以通过json实例直接转换成值的类型

    if json, ok := json2.CheckGet("tagD"); ok { //true ,有该字段
        result,_ := json.String()
        fmt.Println(ok, result)
    }
    

    4、第四个场景,获取嵌套的key,simple-json提供了按照路径搜索的方法,也就是一层一层往下查找,每一层都是一个json实例,如下我们获取tagE

    k, err := json2.GetPath("tagD", "tagE").Int64()
    

    5、还有一个其他场景,比如删除一个key,获取key的时候返回默认值等

    //删除key是tagA值
    json2.Del("tagA")
    //获取key是tagC的值,如果不存在,一定返回一个默认的字符串,当然也可以返回默认的bool值,int值,等
    n := json2.Get("tagC").MustString("default")
    

    simple-json的其他更多方法,使用场景大家可以更多地深入研究,欢迎留言探讨