go语言jsON处理核心是encoding/json库,需掌握结构体标签、嵌套解析、错误处理及流式读写;字段须导出,用json:"name"映射,omitempty忽略零值,inline内嵌,RawMessage延迟解析。

Go语言处理JSON文件的核心是标准库 encoding/json,关键在于理解结构体标签、嵌套数据解析、错误处理和流式读写。不需要第三方库,但得用对方法。
定义结构体并正确使用JSON标签
Go通过结构体字段标签(如 json:"name")控制序列化/反序列化行为。字段必须首字母大写(导出),否则无法被JSON包访问。
- 基础映射:字段名不一致时用标签对齐,例如
UserName String `json:"user_name"` - 忽略字段:用
json:"-"完全跳过该字段;用json:",omitempty"在值为零值(空字符串、0、nil等)时省略输出 - 嵌套结构:直接内嵌结构体或指针,JSON会自动展开;若需保留原字段名,加
json:",inline"
读取JSON文件到结构体(反序列化)
推荐先用 os.ReadFile 一次性读入内存,再用 json.Unmarshal 解析。适合中小文件;大文件考虑 json.Decoder 流式解析。
- 检查错误不能省略:解析失败常见于字段类型不匹配、JSON格式错误、未导出字段
- 支持多种输入源:文件、http响应体、字符串(用
strings.NewReader转换) - 示例:
err := json.Unmarshal(data, &user),user必须是指针
将结构体写入JSON文件(序列化)
用 json.Marshal 得到字节切片,再写入文件;需要格式化输出(带缩进)则用 json.MarshalIndent。
立即学习“go语言免费学习笔记(深入)”;
- 写文件前确保目录存在:
os.MkdirAll(filepath.Dir(filename), 0755) - 写入后调用
file.Sync()可选,确保数据落盘(尤其日志类场景) - 中文不转义:设置
json.Encoder.SetEscapehtml(false)(配合json.NewEncoder使用)
处理动态或未知结构的JSON
当字段不确定或需灵活遍历时,用 map[string]Interface{} 或 json.RawMessage 延迟解析。