Golang解析与生成JSON数据全攻略
本文全面解析了 Golang 如何处理 JSON 数据,为开发者提供了详尽的教程。文章重点介绍了 `encoding/json` 包的核心用法,包括如何将 JSON 字符串解析为 Go 结构体,以及如何将 Go 结构体序列化为 JSON 字符串。针对实际开发中常见的场景,例如嵌套结构和动态 JSON,文章也给出了相应的处理方案和代码示例。此外,还总结了处理 JSON 数据时需要注意的常见问题,例如字段名大小写、时间字段处理、空值处理以及错误检查,旨在帮助开发者快速掌握 Golang 中 JSON 数据的解析与生成技巧,提升 Web 应用和 API 接口的开发效率。
Go语言处理JSON数据的核心方法是使用encoding/json包。解析JSON字符串需定义对应结构体并用json.Unmarshal,注意字段首字母大写及标签映射;结构体转JSON用json.Marshal或json.MarshalIndent;嵌套结构需定义对应嵌套结构体;动态JSON可用map[string]interface{}接收;注意事项包括字段导出、时间处理、空值忽略及错误检查。
处理 JSON 数据是 Go 语言中非常常见的任务,特别是在开发 Web 应用或 API 接口时。Golang 标准库中的 encoding/json
包提供了完整的解析和生成 JSON 的功能。下面通过几个常见场景,带你快速掌握怎么用 Golang 处理 JSON。

解析 JSON 字符串到结构体
在实际开发中,我们经常需要将接收到的 JSON 数据转换成 Go 中的结构体(struct),以便于后续操作。
比如有如下 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) }
几点注意:

- 结构体字段名最好首字母大写,否则无法被正确赋值。
- 使用标签(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 中虽然不算特别简单,但只要结构清晰、标签写对,其实也挺顺手的。
好了,本文到此结束,带大家了解了《Golang解析与生成JSON数据全攻略》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

- 上一篇
- Java小程序数据同步与跨平台一致性方案

- 下一篇
- AI视频生成助力知识与情感解说案例解析
-
- Golang · Go教程 | 6分钟前 |
- Golang类型别名与自定义类型对比解析
- 154浏览 收藏
-
- Golang · Go教程 | 21分钟前 |
- Golanggo.sum文件作用与使用详解
- 180浏览 收藏
-
- Golang · Go教程 | 40分钟前 |
- Golang无指针算术,但支持安全指针操作
- 436浏览 收藏
-
- Golang · Go教程 | 56分钟前 |
- Golang协程创建方法及go关键字详解
- 351浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go语言TCP通信实战指南
- 195浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go语言并行HTTP请求高效处理方法
- 288浏览 收藏
-
- Golang · Go教程 | 1小时前 | golang 消息队列 消息持久化 NATSStreaming 客户端ID
- Golang集成NATSStreaming消息队列教程
- 157浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go返回结构体指针的四种常见场景
- 482浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang并行测试:RunParallel方法全解析
- 318浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golangpanic恢复失败怎么解决?recover用法详解
- 339浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Golang微服务日志与监控收集指南
- 306浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 514次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 24次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 30次使用
-
- 迅捷AIPPT
- 迅捷AIPPT是一款高效AI智能PPT生成软件,一键智能生成精美演示文稿。内置海量专业模板、多样风格,支持自定义大纲,助您轻松制作高质量PPT,大幅节省时间。
- 18次使用
-
- 酷宣AI
- 酷宣AI是一款专注于高颜值文章快速生成的智能工具。它能根据主题或文字智能排版,实现图文高清整合,并支持一键同步至微信公众号、导出PDF,大幅提升内容创作效率与美观度。
- 16次使用
-
- 花瓣网
- 花瓣网是中国领先的创意灵感与版权素材平台,提供海量正版素材、设计工具和灵感发现引擎,服务设计师、企业用户及创意从业者,助力高效创作。
- 21次使用
-
- Golangmap实践及实现原理解析
- 2022-12-28 505浏览
-
- 试了下Golang实现try catch的方法
- 2022-12-27 502浏览
-
- 如何在go语言中实现高并发的服务器架构
- 2023-08-27 502浏览
-
- go和golang的区别解析:帮你选择合适的编程语言
- 2023-12-29 502浏览
-
- 提升工作效率的Go语言项目开发经验分享
- 2023-11-03 502浏览