当前位置:首页 > 文章列表 > Golang > Go教程 > GolangJSON处理:解析与生成教程详解

GolangJSON处理:解析与生成教程详解

2025-08-06 22:05:31 0浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《Golang处理JSON数据:解析与生成完整教程》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

Go语言处理JSON数据的核心方法是使用encoding/json包。解析JSON字符串需定义对应结构体并用json.Unmarshal,注意字段首字母大写及标签映射;结构体转JSON用json.Marshal或json.MarshalIndent;嵌套结构需定义对应嵌套结构体;动态JSON可用map[string]interface{}接收;注意事项包括字段导出、时间处理、空值忽略及错误检查。

怎样用Golang处理JSON数据 解析与生成JSON的完整示例

处理 JSON 数据是 Go 语言中非常常见的任务,特别是在开发 Web 应用或 API 接口时。Golang 标准库中的 encoding/json 包提供了完整的解析和生成 JSON 的功能。下面通过几个常见场景,带你快速掌握怎么用 Golang 处理 JSON。

怎样用Golang处理JSON数据 解析与生成JSON的完整示例

解析 JSON 字符串到结构体

在实际开发中,我们经常需要将接收到的 JSON 数据转换成 Go 中的结构体(struct),以便于后续操作。

比如有如下 JSON 字符串:

怎样用Golang处理JSON数据 解析与生成JSON的完整示例
{
  "name": "Tom",
  "age": 25,
  "email": "tom@example.com"
}

我们可以定义一个对应的结构体,并使用 json.Unmarshal 来解析:

package main

import (
    "encoding/json"
    "fmt"
)

type User struct {
    Name  string `json:"name"`
    Age   int    `json:"age"`
    Email string `json:"email"`
}

func main() {
    data := `{"name":"Tom","age":25,"email":"tom@example.com"}`
    var user User

    err := json.Unmarshal([]byte(data), &user)
    if err != nil {
        fmt.Println("解析失败:", err)
        return
    }

    fmt.Printf("%+v\n", user)
}

几点注意:

怎样用Golang处理JSON数据 解析与生成JSON的完整示例
  • 结构体字段名最好首字母大写,否则无法被正确赋值。
  • 使用标签(tag)来指定 JSON 字段名,这样即使结构体字段名不同也能正确映射。

将结构体生成 JSON 字符串

反过来,我们也可以把 Go 的结构体数据序列化为 JSON 字符串,用于接口返回或者日志输出。

继续上面的例子:

user := User{
    Name:  "Jerry",
    Age:   30,
    Email: "jerry@example.com",
}

jsonData, _ := json.Marshal(user)
fmt.Println(string(jsonData))

输出结果就是标准的 JSON 格式:

{"name":"Jerry","age":30,"email":"jerry@example.com"}

如果你希望输出格式更美观,可以使用 json.MarshalIndent

jsonData, _ := json.MarshalIndent(user, "", "  ")
fmt.Println(string(jsonData))

处理嵌套结构和动态 JSON

有时候 JSON 数据结构比较复杂,比如包含嵌套对象或者数组,这时候就需要定义嵌套结构体来匹配。

例如这个 JSON:

{
  "name": "Alice",
  "hobbies": ["reading", "coding"],
  "address": {
    "city": "Beijing",
    "zip": "100000"
  }
}

对应的结构体可以这样写:

type Address struct {
    City string `json:"city"`
    Zip  string `json:"zip"`
}

type Person struct {
    Name    string   `json:"name"`
    Hobbies []string `json:"hobbies"`
    Address Address  `json:"address"`
}

解析方式与前面一致,只是结构变复杂了而已。

如果遇到不确定结构的 JSON,比如某些字段可能缺失或类型不固定,可以用 map[string]interface{} 或者 interface{} 类型来接收:

var result map[string]interface{}
json.Unmarshal(data, &result)

这种方式灵活性高,但牺牲了一定的类型安全性,适合做中间层处理。


常见问题和注意事项

  • 字段名大小写影响:只有导出字段(首字母大写)才会参与 JSON 编解码。
  • 时间字段处理:如果是 time.Time 类型,默认会转成 RFC3339 时间格式,你也可以自定义格式。
  • 空值处理:结构体字段为空时,生成的 JSON 默认也会保留该字段,如需忽略空值可以在 tag 后加 omitempty,例如:json:"email,omitempty"
  • 错误处理很重要:特别是从网络读取 JSON 时,一定要检查 Unmarshal 是否出错。

基本上就这些内容了。JSON 处理在 Golang 中虽然不算特别简单,但只要结构清晰、标签写对,其实也挺顺手的。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《GolangJSON处理:解析与生成教程详解》文章吧,也可关注golang学习网公众号了解相关技术文章。

电脑主机风扇狂转故障排查与解决电脑主机风扇狂转故障排查与解决
上一篇
电脑主机风扇狂转故障排查与解决
Java异常处理技巧与常见错误
下一篇
Java异常处理技巧与常见错误
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    118次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    114次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    130次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    122次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    127次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码