读取map [string] interface {}中的数据

问题描述 投票:-1回答:1

源服务器以多个对象接口的Json格式返回数据,我们如何解析这些数据?

我使用JSON map [string] interface {}类型的变量来保存服务器的结果

 The data return from Server.
"data": [
       {
        "group": "PAA_TEST",
        "id": "2018-04-10T09:24:18.000000Z",
        "name": "PAA_STATION",
        "released": true,
        "version": 33
    },
    {
        "group": "PAA_TEST",
        "id": "2018-03-19T10:50:21.000000Z",
        "name": "PAA_STATION",
        "released": false,
        "version": 32
    }

我的fmt.print输出outputdata [“data”] //其中输出数据是JSON map [string] interface {}

    [
       map[group:PAA_TEST id:2018-04-10T09:24:18.000000Z name:PAA_STATION 
       released:true version:33] 
       map[group:PAA_TEST id:2018-03-19T10:50:21.000000Z name:PAA_STATION 
       released:false version:32] 
   ]

我们如何迭代多个Map接口?例如,如果我只想处理发布状态为true的信息。我正在尝试各种索引方法,但没有运气。

json parsing go interface marshalling
1个回答
0
投票

最好的解决方案是将JSON直接解码为与数据结构匹配的Go类型。这避免了挖掘map[string]interface{}所需的类型断言。

我假设常见函数看起来像这样:

func request(path string, ... more arguments) (map[string]interface{}}, error) {
      ...
      resp, err := client.Do(req)
      if err != nil {
         return nil, err
      }
      defer resp.Body.Close()
      ...
      var result map[string]interface{}
      err := json.NewDecoder(resp.Body).Decode(&result)
      return result, err
}

更改函数以将结果指针作为参数:

func request(pv interface{}, path string, ... more arguments) error {
      ...
      resp, err := client.Do(req)
      if err != nil {
         return err
      }
      defer resp.Body.Close()
      ...
      err := json.NewDecoder(resp.Body).Decode(pv)
      return err
}

像这样调用这个修改过的函数:

var result struct { 
    Data []struct{ 
        Group, ID, Name string
        Released bool
        Version int 
    }
}
err := request(&result, "some/path", ... more arguments )
if err != nil {
    // handle error
}

for _, d := range result.Data {
   if !d.Released {
       continue
   }
   fmt.Println(d.Group, d.ID, d.Name, d.Version)
   ... process d
}
© www.soinside.com 2019 - 2024. All rights reserved.