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的其他更多方法,使用场景大家可以更多地深入研究,欢迎留言探讨

01-25 22:03