释义
JSON是一种轻量级的数据交换语言,以文字为基础,且易于让人阅读。尽管JSON是Javascript的一个子集,但JSON是独立于语言的文本格式,并且采用了类似于C语言家族的一些习惯。
其他语言转过来的童鞋,特别是Android开发者是无可避免使用到Json的解析工作,而在Golang中对Json的操作也是非常简单的,下面详细介绍一下Json解析在Golang中的运用。
说明 : 实例中使用的api来自http://gank.io/api
Json格式
{
"_id": "59e905da421aa90fe2f02bcf",
"createdAt": "2017-10-20T04:06:50.148Z",
"desc": "Hacktoberfest - open source 參與項目推薦",
"publishedAt": "2017-10-20T10:26:24.673Z",
"source": "web",
"type": "拓展资源",
"url": "https://github.com/WeiChiaChang/Daily-Digest-Collection/issues/11",
"used": true,
"who": "WesleyChang"
}
准备工作
- 驱动
encoding/json //json驱动
net/http //网络驱动 - struct
在Golang中一般struct属性 命名规则你随意。 首字母大小写都是可以的。
如果Json中一些字段命名跟自己的风格不一样可以通过 在字段后添加`json:"xxx"`,然后解析到对应的jsonObject的值到自己命名的字段中。 其中“`”,不是单引号,而是TAB键上面的英文半角的点。
如下示例:
type GankMain struct {
Id string `json:"_id"`
CreatedAt time.Time `json:"createdAt"`
Desc string `json:"desc"`
PublishedAt time.Time `json:"publishAt"`
Source string `json:"source"`
Type string `json:"type"`
Url string `json:"url"`
Used bool `json:"used"`
Who string `json:"who"` }
type Results struct {
Error bool `json:"error"`
Results []GankMain `json:"results"` }
- 通过网络获取Json
//拿到resp对象
resp, err := http.Get("http://gank.io/api/data/all/10/1")
//判断是否出错
if err != nil {
return
}
//判断是否请求成功
if resp.StatusCode != http.StatusOK {
resp.Body.Close()
return nil, fmt.Errorf("请求出错:%s", resp.Status)
}
至此,已经拿到了json对象了,它就在resp.Body()对象中,下面开始做解析操作。
开始解析
准备接收解析结果的对象
var result Results
一行代码搞定
eror := json.NewDecoder(resp.Body).Decode(&result)
于是就拿到了,我们要的结果 result.
此处有一个比较有意思的地方,就是Decode函数中传入的result 返回的是error,此处也是C的特性,传参在函数中赋值之后,在外部的result对象也是已经赋值了。对于java程序员理解起来费解,记住即可。
打印看下,结果如下:
&{false [{59ec7dc4421aa90fe50c018f 2017-10-22 19:15:16.956 +0000 UTC 【阿斗】绝地求生电影版?一群杀人犯孤岛吃鸡,阿斗带你看懂《逃出冰魔岛》 0001-01-01 00:00:00 +0000 UTC chrome 休息视频 http://www.bilibili.com/video/av15581509/ true LHF} {59efe9fb421aa90fe72535c1 2017-10-25 09:33:47.784 +0000 UTC 堪比阿里插件的Android Studio插件集合(IDE通用)(上) 0001-01-01 00:00:00 +0000 UTC web Android https://mp.weixin.qq.com/s?__biz=MzIwMzYwMTk1NA==&mid=2247487640&idx=1&sn=3752d389f908a6116341a03e6f3c6730 true 陈宇明} {59eff4ad421aa90fef2034cb 2017-10-25 10:19:25.884 +0000 UTC Android开源框架榜单——百大框架排行榜 0001-01-01 00:00:00 +0000 UTC web Android https://github.com/ShaunSheep/Android_100_TOP-Projects true Chaofun} {59eff996421aa90fe2f02bf1 2017-10-25 10:40:22.6 +0000 UTC 婚礼大屏互动,微信请柬一站式解决方案 0001-01-01 00:00:00 +0000 UTC web 前端 https://github.com/iammapping/wedding true 鑫花璐放} {59f0010c421aa90fef2034cc 2017-10-25 11:12:12.416 +0000 UTC MVVM + FLUX Reactive Facade ViewKit 0001-01-01 00:00:00 +0000 UTC chrome iOS https://github.com/geekaurora/ReactiveListViewKit true daimajia} {59f0054a421aa90fe2f02bf4 2017-10-25 11:30:18.697 +0000 UTC 2017-10-25 0001-01-01 00:00:00 +0000 UTC chrome 福利 http://7xi8d6.com1.z0.glb.clouddn.com/20171025112955_lmesMu_katyteiko_25_10_2017_11_29_43_270.jpeg true 代码家} {59f00605421aa90fef2034cd 2017-10-25 11:33:25.66 +0000 UTC Burp Suite 开放了新的数据库打通 API 接口,快速辅助渗透测试。 0001-01-01 00:00:00 +0000 UTC chrome 拓展资源 https://github.com/vulnersCom/burp-vulners-scanner true 代码家} {59f00673421aa90fe2f02bf5 2017-10-25 11:35:15.934 +0000 UTC 够长的 Shadow 效果。 0001-01-01 00:00:00 +0000 UTC chrome Android https://github.com/florent37/LongShadow true 代码家} {59eb735f421aa90fef2034b1 2017-10-22 00:18:39.652 +0000 UTC 造价1万亿元的世界第一高楼,高4千米住100万人,2050年完工 0001-01-01 00:00:00 +0000 UTC chrome 休息视频 http://www.bilibili.com/video/av15580072/ true LHF} {59edb49b421aa90fe50c0197 2017-10-23 17:21:31.325 +0000 UTC 前端每周清单第 36 期:深入 Vue 2.5 类型增强、Puppeteer 端到端测试、PayPal 跨域套装 0001-01-01 00:00:00 +0000 UTC web 前端 https://zhuanlan.zhihu.com/p/30379534 true 王下邀月熊(Chevalier)}]}
补充
上述实例使用的直接读取流Json的操作,json.NewDecoder(r io.Reader)
,如果需要直接操作字符串,则可以使用json.Unmarshal(data []byte, v interface{})
将字符串转换byte数组,传入解析成的struct
对象;即可
参考文档
维基百科Json:https://zh.wikipedia.org/wiki/JSON
Go语言程序设计 许式伟等译 人民邮电出版社第一版 290p。