在 Golang 中,将 JSON 整数值解析为浮点数是一个常见问题。默认的encoding/json包不区分整数和浮点数,导致与数据库交互时出现数据类型冲突和写入失败。为了解决这个问题,我们可以采用替代方法来解析 JSON 值。
一种解决方案是利用通用 Go 机制对于自定义 JSON 值。通过实现区分整数和浮点数的自定义 JSON 类型,我们可以控制数据类型转换过程。下面显示了一个示例实现:
type MyInt int64 func (mi MyInt) MarshalJSON() ([]byte, error) { return []byte(strconv.FormatInt(int64(mi), 10)), nil }
此自定义类型在将整数值编组为 JSON 时将其转换为字符串。要将 JSON 值解组为自定义类型,我们可以使用 json.Unmarshal 函数:
var raw map[string]interface{} err := json.Unmarshal([]byte(str), &raw) parsed := make(map[string]interface{}, len(raw)) for key, val := range raw { s := string(val) i, err := strconv.ParseInt(s, 10, 64) if err == nil { parsed[key] = MyInt(i) continue } // Handle other types as needed }
另一种方法涉及使用 json.Number,一种表示 JSON 数字的类型。它提供了将数字转换为 int64 和 float64 值的方法,允许我们手动处理类型转换:
var parsed map[string]interface{} d := json.NewDecoder(strings.NewReader(str)) d.UseNumber() err := d.Decode(&parsed) for key, val := range parsed { n, ok := val.(json.Number) if !ok { continue } if i, err := n.Int64(); err == nil { parsed[key] = i continue } if f, err := n.Float64(); err == nil { parsed[key] = f continue } }
以上是如何在 Golang 中将 JSON 整数解析为整数而不是浮点数?的详细内容。更多信息请关注PHP中文网其他相关文章!