dlb*_*dlb 3 arrays json numbers go unmarshalling
我正在尝试解组从Web服务获得的一些json数据.我已经简化了下面代码中显示的问题.我的问题是我可以在代码工作中制作版本(c).
我知道它适用于单个数字值,如"timestamp"所示,方法是在json注释中添加选项",string".但我无法弄清楚这是如何或是否适用于字符串编码数字的数组.(参见代码中列出的示例json中的"转换")
package main
import (
"encoding/json"
"fmt"
)
//version (a)
type JsonData1 struct {
TimeStamp uint64 `json:"timestamp,string"`
Conversions [][2]string `json:"conversions"`
}
//version (b)
type JsonData2 struct {
TimeStamp uint64 `json:"timestamp,string"`
Conversions [][2]json.Number `json:"conversions"`
}
//version (c)
type JsonData3 struct {
TimeStamp uint64 `json:"timestamp,string"`
Conversions [][2]float32 `json:"conversions"`
}
const incomingJson string = `{"timestamp": "1407178369", "conversions": [["1.021", "2.124"], ["2.432", "3.923"], ["3.234", "5.001"]]}`
func main() {
var data1 JsonData1
if err1 := json.Unmarshal([]byte(incomingJson), &data1); err1 != nil {
fmt.Println("Error unmarshaling with struct JsonData1")
fmt.Println("--> ", err1.Error())
} else {
fmt.Println("Success unmarshaling with struct JsonData1")
fmt.Println("--> ", data1)
}
var data2 JsonData2
if err2 := json.Unmarshal([]byte(incomingJson), &data2); err2 != nil {
fmt.Println("Error unmarshaling with struct JsonData2")
fmt.Println("--> ", err2.Error())
} else {
fmt.Println("Success unmarshaling with struct JsonData2")
fmt.Println("--> ", data2)
}
var data3 JsonData3
if err3 := json.Unmarshal([]byte(incomingJson), &data3); err3 != nil {
fmt.Println("Error unmarshaling with struct JsonData3")
fmt.Println("--> ", err3.Error())
} else {
fmt.Println("Success unmarshaling with struct JsonData3")
fmt.Println("--> ", data3)
}
}
Run Code Online (Sandbox Code Playgroud)
如果我编译并运行代码,我得到这个输出:
Success unmarshaling with struct JsonData1
--> {1407178369 [[1.021 2.124] [2.432 3.923] [3.234 5.001]]}
Success unmarshaling with struct JsonData2
--> {1407178369 [[1.021 2.124] [2.432 3.923] [3.234 5.001]]}
Error unmarshaling with struct JsonData3
--> json: cannot unmarshal string into Go value of type float32
Run Code Online (Sandbox Code Playgroud)
您可以在此处运行代码:http://play.golang.org/p/4TC0IgCI8H
有没有办法实现对struct version(c)的解组?谢谢你的帮助!
我知道这样做最简单的方法是定义一个新类型,然后UnmarshalJSON为它定义:
type Conversions [][2]float64
func (c *Conversions) UnmarshalJSON(b []byte) error {
tmp := [][2]json.Number{}
if err := json.Unmarshal(b, &tmp); err != nil {
return err
}
*c = make(Conversions, len(tmp))
for i, a := range tmp {
var (
pair [2]float64
err error
)
pair[0], err = a[0].Float64()
if err != nil {
return err
}
pair[1], err = a[1].Float64()
if err != nil {
return err
}
(*c)[i] = pair
}
return nil
}
Run Code Online (Sandbox Code Playgroud)
游乐场,见版本(d).这不是最完美的方法,可以改进算法以减少资源使用,但你明白了.
| 归档时间: |
|
| 查看次数: |
3237 次 |
| 最近记录: |