当前位置: 首页 > 面试题库 >

在Go中解组数组的JSON数组

章宏恺
2023-03-14
问题内容

我想解析一些json数据。数据如下所示:

{“ id”:“ someId”,“ key_1”:“ value_1”,“ key_2”:“ value_2”,“ key_3”:“
value_3”,“点数”:[[1487100466412,“ 50.032178”,“ 8.526018”,300
,0.0,26,0],[1487100471563,“ 50.030869”,“
8.525949”,300,0.0,38,0],[1487100475722,“ 50.028514”,“
8.525959”,225,0.0,69,-900],[ 1487100480834,“ 50.025827”,“
8.525793”,275,0.0,92,-262],…]}

我建立了一个go结构:

type SomeStruct struct {
   ID   string `json:"id"`
   Key1 string `json:"key_1"`
   Key2 string `json:"key_2"`
   Key3 string `json:"key_3"`
   Points []Point `json:"points"`
}

type Point struct {
   Timestamp int64 `json:"0"`
   Latitude float64 `json:"1,string"`
   Longitude float64 `json:"2,string"`
   Altitude int `json:"3"` 
   Value1 float64 `json:"4"`
   Value2 int `json:"5"`
   Value3 int `json:"6"`      
}

我解组json数据

var track SomeStruct
error := json.Unmarshal(data,&track)
if(error != nil){
    fmt.Printf("Error while parsing data: %s", error)
}

json:无法将数组解编为Point类型的Go值{someId value_1 value_2 value_3 [{0 0 0 0 0 0 0 0}
{0 0 0 0 0 0 0} {0 0 0 0 0 0 0} …]}

因此,第一个json键已正确解析,但是我无法弄清楚如何获取点数据,该数据是一个数组数组。

生成结构也是这里的建议之一,除了我不使用嵌套结构,而是使用单独的类型。使用建议的嵌套结构没有什么不同: JSON-to-
Go

为此,我需要实现自己的Unmarshaller吗?

=======更新解决方案============

为Point结构实现UnmarshalJSON接口就足够了。下面的示例未包含正确的错误处理,但显示了方向。

操场上的例子

package main

import (
    "encoding/json"
    "fmt"
    "strconv"
)

type SomeStruct struct {
    ID     string  `json:"id"`
    Key1   string  `json:"key_1"`
    Key2   string  `json:"key_2"`
    Key3   string  `json:"key_3"`
    Points []Point `json:"points"`
}

type Point struct {
    Timestamp int64
    Latitude  float64
    Longitude float64
    Altitude  int
    Value1    float64
    Value2    int16
    Value3    int16
}

func (tp *Point) UnmarshalJSON(data []byte) error {
    var v []interface{}
    if err := json.Unmarshal(data, &v); err != nil {
        fmt.Printf("Error whilde decoding %v\n", err)
        return err
    }
    tp.Timestamp = int64(v[0].(float64))
    tp.Latitude, _ = strconv.ParseFloat(v[1].(string), 64)
    tp.Longitude, _ = strconv.ParseFloat(v[2].(string), 64)
    tp.Altitude = int(v[3].(float64))
    tp.Value1 = v[4].(float64)
    tp.Value2 = int16(v[5].(float64))
    tp.Value3 = int16(v[6].(float64))

    return nil
}

func main() {

    const data =    `{"id":"someId","key_1":"value_1","key_2":"value_2","key_3":"value_3","points":[[1487100466412,"50.032178","8.526018",300,0.0,26,0],[1487100471563,"50.030869","8.525949",300,0.0,38,0],[1487100475722,"50.028514","8.525959",225,0.0,69,-900],[1487100480834,"50.025827","8.525793",275,0.0,92,-262]]}`

var something SomeStruct
json.Unmarshal([]byte(data), &something)

fmt.Printf("%v", something)
}

问题答案:

为此,我需要实现自己的Unmarshaller吗?

是。

您正在尝试将数组解组到struct(Point)中,这意味着您需要告诉JSON解组器数组值如何映射到struct值。

另请注意,您的标签Point定义不正确。json标记引用键名,但是数组没有键(在JavaScript中可以像访问键一样访问,但这不是JavaScript)。换句话说,json:"0"仅当JSON看起来像时才起作用{"0":123}。如果您实现自己的拆组器,则可以摆脱那些json标签。



 类似资料:
  • 问题内容: 嗨,我在解组嵌套的JSON数组时遇到问题。我应该创建什么结构?我想避免使用尽可能多的东西,但是我真的不知道在这种情况下是否有可能。 杰森,我想解组: 和我想用来解组的结构: 链接到示例:https : //play.golang.org/p/owuMptNrix 问题答案: 是的,答案只是一小部分: 好感谢你的问题,我发现这个错误的工具,我总是用它的Json操作一起去,它可以为你节省很

  • 问题内容: 我从REST JSON响应中获得以下字符串: 其余响应定义来自Facebook:FB REST链接 我正在使用在Jetty中运行的Google App Engine + GAELYK。 在服务器上的Groovy 中将上述内容转换为 地图* 数组 的最佳方法是什么。(这可能必须通过响应来递归) * 我正在寻找不包含很多库的简单东西。(我没有行家) 问题答案: 编辑:自1.8.0以来的Gr

  • 问题内容: 我有以下JSON,我想将其解析为类数组: 这是我想做的但失败的事情: 编译器抱怨v [“ level”] <<无效操作。interface()类型的索引。 问题答案: 此代码中有许多错误。首先,json是无效的json。您缺少顶级对象中密钥对之间的逗号。我添加了逗号并为您漂亮地打印了它: 你的下一个问题(你问的那个)是做一个。这意味着当您在范围循环中对它进行索引时,类型为。您需要使用再

  • 问题内容: 我有一项通过REST为我提供属性的服务。现在,我想将身体解组为属性结构。请查看此操场示例:单击。当我只有一个财产时,可以轻松将其编组为。但是,服务器发出的ACTUAL响应有所不同。我要解组的实际响应是这样的: 不幸的是,我不知道如何解组。有人可以指出正确的方向吗? 问题答案: 您需要解组一片属性:http : //play.golang.org/p/eRgjfBHypH

  • 问题内容: 我正在使用JSON,它返回三种不同的对象类型“项目”,“类别”和“修饰符”。可以在此处查看JSON的示例。我为三种类型的对象创建了模型。但是当我解组时,我选择了一种类型来解组整个JSON。(我知道这不可能是正确的方法…)然后,我尝试根据不同的类型来解析不同的项目,如json字段“类型”,然后将该对象附加到适当类型的切片中。我遇到错误,因为我不知道如何解组其中具有不同字段且具有不同类型的

  • 问题内容: json:无法将数组解组为类型的Go值 配置json: 和我的golang代码是这样的: json解析代码: 问题答案: 您的类型是造成问题的原因。摆脱它,它的工作原理是: 游乐场:https://play.golang.org/p/Prt1j7ePCZ。