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

时间:2019-04-15 19:33:49

标签: json parsing go interface marshalling

源服务器以多个对象的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
    }

my fmt.print output 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的信息。我正在尝试各种索引方法,但是还没有运气。

1 个答案:

答案 0 :(得分: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
}