dongming8867 2019-06-18 09:35
浏览 592
已采纳

如何使用mongo-go-driver有效地将bson转换为json?

I want to convert bson in mongo-go-driver to json effectively.

I should take care to handle NaN, because json.Marshal fail if NaN exists in data.

For instance, I want to convert below bson data to json.

b, _ := bson.Marshal(bson.M{"a": []interface{}{math.NaN(), 0, 1}})
// How to convert b to json?

The below fails.

// decode
var decodedBson bson.M
bson.Unmarshal(b, &decodedBson)
_, err := json.Marshal(decodedBson)
if err != nil {
    panic(err) // it will be invoked
    // panic: json: unsupported value: NaN
}
  • 写回答

1条回答 默认 最新

  • dtmtu02882 2019-06-18 10:21
    关注

    If you know the structure if your BSON, you can create a custom type that implements the json.Marshaler and json.Unmarshaler interfaces, and handles NaN as you wish. Example:

    type maybeNaN struct{
        isNan  bool
        number float64
    }
    
    func (n maybeNaN) MarshalJSON() ([]byte, error) {
        if n.isNan {
            return []byte("null"), nil // Or whatever you want here
        }
        return json.Marshal(n.number)
    }
    
    func (n *maybeNan) UnmarshalJSON(p []byte) error {
        if string(p) == "NaN" {
            n.isNan = true
            return nil
        }
        return json.Unmarshal(p, &n.number)
    }
    
    type myStruct struct {
        someNumber maybeNaN `json:"someNumber" bson:"someNumber"`
        /* ... */
    }
    

    If you have an arbitrary structure of your BSON, your only option is to traverse the structure, using reflection, and convert any occurrences of NaN into a type (possibly a custom type as described above)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵