在Go程序中输出JSON(称为“foo”)时,它可能是有益的使结果具有可读性,以便更好地解释。虽然通常通过管道输出来使用 jq 命令行工具来实现此目的,但本文提供了一种使用 Go 内置的编码/json 包的替代解决方案。
encoding/json 包提供了本机支持无需外部工具即可生成缩进的 JSON。通过利用 json.MarshalIndent() 函数或调用 json.Encoder.SetIndent() (自 Go 1.7 起可用),您可以实现所需的结果。
例如,要将映射缩进为可读的 JSON:
m := map[string]interface{}{"id": "uuid1", "name": "John Smith"} data, err := json.MarshalIndent(m, "", " ") if err != nil { panic(err) } fmt.Println(string(data))
或者,您可以将 json.Encoder 与SetIndent():
enc := json.NewEncoder(os.Stdout) enc.SetIndent("", " ") if err := enc.Encode(m); err != nil { panic(err) }
您还可以使用 json.Indent() 格式化现有的 JSON 字符串:
src := `{"id":"uuid1","name":"John Smith"}` dst := &bytes.Buffer{} if err := json.Indent(dst, []byte(src), "", " "); err != nil { panic(err) } fmt.Println(dst.String())
这些函数中的 prefix 和 indent 参数决定缩进样式。每个新行之前都会有前缀,而每层嵌套都会重复缩进。
通过利用这些方法,您可以轻松地在 Go 中生成人类可读的 JSON,而无需额外的工具或依赖项,从而增强了可读性和JSON 输出的可用性。
以上是如何在 Go 中使 JSON 输出可读?的详细内容。更多信息请关注PHP中文网其他相关文章!