1、通过Decoder来解析json串

package main

import (
"encoding/json"
"fmt"
"io"
"log"
"strings"
) func main() {
const jsonStream = `
{"Name":"Ed","Text":"Knock knock."}
{"Name":"Sam","Text":"Who's there?"}
`
type Message struct {
Name, Text string
} dec := json.NewDecoder(strings.NewReader(jsonStream))
for {
var m Message
if err := dec.Decode(&m); err == io.EOF {
break
} else if err != nil {
log.Fatal(err)
}
fmt.Printf("%s:%s\n", m.Name, m.Text)
}
}
//output
//Ed:Knock knock.
//Sam:Who's there?

2、marshal对struct进行json字符串化

package main

import (
"encoding/json"
"fmt"
"os"
) func main() {
type ColorGroup struct {
ID int
Name string
Colors []string
}
group := ColorGroup{
ID: 1,
Name: "Reds",
Colors: []string{"Crimson", "Red", "Ruby", "Marroon"},
}
b, err := json.Marshal(group)
if err != nil {
fmt.Println("err:", err)
}
os.Stdout.Write(b)
}
//output
//{"ID":1,"Name":"Reds","Colors":["Crimson","Red","Ruby","Marroon"]}
package main

import (
"encoding/json"
"fmt"
) type Color struct {
Red string `json:"r"` //json中key是r
Yel string `json:"yel,omitempty"`//json中key是yel,omitempty表示当Yel为空时,json中不输出
Blue string `json:"-"`//json序列化是忽略
Age string `json:",-"`//json序列化时使用默认的Age key,
name string `json:"name"`//小写的名字json序列化忽略,私有成员变量,json包无法访问
} func main() {
color := Color{
Red:"256",
Yel:"20",
Blue:"10",
Age:"10",
name:"chen",
}
bs,_ := json.Marshal(color)
fmt.Printf("%s\n",bs)
} //{"r":"256","yel":"20","Age":"10"}

3、Unmarshal 解析json

json规范中,没有区分整数和浮点数

package main

import (
"encoding/json"
"fmt"
) //指定反解析的json struct类型。 fansCount会转换为int64类型。不会有精度的丢失。
type User struct {
Name string
FansCount int64
} func main() {
const jsonStream = `
{"name":"ethancai", "fansCount": 9223372036854775807}`
var user User
err := json.Unmarshal([]byte(jsonStream),&user)
if err != nil {
fmt.Println("error:",err)
}
fmt.Printf("%+v \n",user)
} //{Name:ethancai FansCount:9223372036854775807}
package main

import (
"encoding/json"
"fmt"
"reflect"
) func main() {
const jsonStream = `{"name":"ethancai", "fansCount": 9223372036854775807}`
var user interface{} //不指定反序列化的类型,
err := json.Unmarshal([]byte(jsonStream),&user)
if err != nil {
fmt.Println("err",err)
}
m := user.(map[string]interface{}) fansCount := m["fansCount"] //没有类型,反序列化时会默认转换为float64,如果整数过大,会丢失精度
fmt.Printf("%+v\n",reflect.TypeOf(fansCount).Name())
fmt.Printf("%+v\n",fansCount.(float64))
}
//float64
//9.223372036854776e+18
package main

import (
"encoding/json"
"fmt"
) type User struct {
Name string
FansCount interface{} //不指定变量类型
}
func main() {
const jsonStream = `{"name":"ethancai", "fansCount": 9223372036854775807}`
var user User
err := json.Unmarshal([]byte(jsonStream),&user)
if err != nil {
fmt.Println("err",err)
}
fmt.Printf("%+v \n",user)
}
//{Name:ethancai FansCount:9.223372036854776e+18}

为了解决精度丢失的问题,需要引入json.Number类型

package main

import (
"encoding/json"
"fmt"
) type User struct {
Name string
FansCount json.Number //使用json.Number类型,本质是string类型。不会有精度丢失
}
func main() {
const jsonStream = `{"name":"ethancai", "fansCount": 9223372036854775807}`
var user User
err := json.Unmarshal([]byte(jsonStream),&user)
if err != nil {
fmt.Println("err",err)
}
fmt.Printf("%+v \n",user)
num ,_ := user.FansCount.Int64() //然后转换成想要的类型
fmt.Println(num)
}
//{Name:ethancai FansCount:9223372036854775807}
//9223372036854775807

go-json处理的问题的更多相关文章

  1. 使用TSQL查询和更新 JSON 数据

    JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...

  2. 【疯狂造轮子-iOS】JSON转Model系列之二

    [疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...

  3. 【疯狂造轮子-iOS】JSON转Model系列之一

    [疯狂造轮子-iOS]JSON转Model系列之一 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 之前一直看别人的源码,虽然对自己提升比较大,但毕竟不是自己写的,很容易遗 ...

  4. Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)

    背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...

  5. .NET Core系列 : 2 、project.json 这葫芦里卖的什么药

    .NET Core系列 : 1..NET Core 环境搭建和命令行CLI入门 介绍了.NET Core环境,本文介绍.NET Core中最重要的一个配置文件project.json的相关内容.我们可 ...

  6. 一个粗心的Bug,JSON格式不规范导致AJAX错误

    一.事件回放  今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...

  7. JSON.parse()和JSON.stringify()

    1.parse 用于从一个字符串中解析出json 对象.例如 var str='{"name":"cpf","age":"23&q ...

  8. json与JavaScript对象互换

    1,json字符串转化为JavaScript对象: 方法:JSON.parse(string) eg:var account = '{"name":"jaytan&quo ...

  9. .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...

  10. WebApi接口 - 响应输出xml和json

    格式化数据这东西,主要看需要的运用场景,今天和大家分享的是webapi格式化数据,这里面的例子主要是输出json和xml的格式数据,测试用例很接近实际常用情况:希望大家喜欢,也希望各位多多扫码支持和点 ...

随机推荐

  1. easyUI使用datagrid-detailview.js实现二级列表嵌套

    本文为博主原创,转载请注明: 在easyUI中使用datagrid-detailview.js可快速实现二级折叠列表,示例如下: 注意事项: 原本在谷歌浏览器进行示例测试的,url请求对应的json文 ...

  2. ranch 源码分析(一)

    以前写了一个ranch的处理流程,http://www.cnblogs.com/tudou008/p/5197314.html ,就只有一张图,不是很清晰,现在有空做个源码分析. ranch的源码(版 ...

  3. Caffarelli 关于自由边界正则性的论文C1

    Caffarelli 关于自由边界正则性的论文 接下来主要想叙述一下Caffarelli的C1文章中的一些想法,这是最近这几天看的文献. 对于从自由边界的Lipschitz正则性到$C^{1,\alp ...

  4. Vue 结合 Axios 接口超时统一处理

    引语:当网路慢的时候.又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助. axios基本用法就不多说了 ...

  5. 版本控制git第一篇

    一.git的下载与安装 参考:https://blog.51cto.com/wangfeng7399/2352524 Git 是一个开源的分布式版本控制软件,用以有效.高速的处理从很小到非常大的项目版 ...

  6. 关于Java的特点之多态

    多态--概念 所谓多态,就是指一个引用(类型)在不同情况下的多种状态.也可以理解成:多态是指通过指向父类的指针,来调用在不同子类中实现的方法. 实现多态有两种方式:1.继承:2.接口 多态--注意事项 ...

  7. 路由器桥接尝试WDS

    第一步:设置主路由器192.168.1.1. 第二步:设置副路由器. 进入副路由器的设置界面 点击「网络参数」->「LAN口设置」 把副路由器的LAN地址设置为192.168.1.2防止与主路由 ...

  8. effective java——12考虑实现coparable接口

    float和double类型的主要设计目标是为了科学计算和工程计算.他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的.然而,它们没有提供完全精确的结果,所以不应该 ...

  9. Asp .Net Core 2.0 登录授权以及多用户登录

    用户登录是一个非常常见的应用场景 .net core 2.0 的登录方式发生了点变化,应该是属于是良性的变化,变得更方便,更容易扩展. 配置 打开项目中的Startup.cs文件,找到Configur ...

  10. 使用map()的小陷阱:parseInt

    假设我们想要把一个字符串数组的每一项转换成整数,我们很自然就想到了把parseInt作为回调函数传给map()函数,但这样做可能会出现意想不到的结果: var strArr = ["1&qu ...