为了账号安全,请及时绑定邮箱和手机立即绑定

从 golang 中的嵌套动态键 json 中获取数据

从 golang 中的嵌套动态键 json 中获取数据

Go
墨色风雨 2022-01-04 13:51:11
我是新手,我正在尝试从 json 结构中提取特定的密钥,如下所示。{    "cluster_name": "escluster",    "nodes": {        "Sd2AvEXsswjTn6ErRYjg": {            "timestamp": 1460624696217,            "name": "master1",            "transport_address": "10.0.0.1:9300",            "host": "10.0.0.1:9300",            "ip": [                "10.0.0.1:9300",                "NONE"            ],            "attributes": {                "data": "false",                "master": "true"            },            "os": {                "timestamp": 1460624696217,                "cpu_percent": 0,                "load_average": 0,                "mem": {                    "total_in_bytes": 163987664,                    "free_in_bytes": 136357264,                    "used_in_bytes": 26629400,                    "free_percent": 84,                    "used_percent": 16                },                "swap": {                    "total_in_bytes": 0,                    "free_in_bytes": 0,                    "used_in_bytes": 0                }            }        },        "yzabB-OaTfOqvgAELIMq1Q": {            "timestamp": 1460624938213,            "name": "data_1",            "transport_address": "10.0.0.2:9300",            "host": "10.0.0.2",            "ip": [                "10.0.0.2:9300",                "NONE"            ],            "attributes": {                "master": "false"            },            "os": {                "timestamp": 1460624938213,                "cpu_percent": 0,                "load_average": 0.29,                "mem": {                    "total_in_bytes": 623840000,                    "free_in_bytes": 4127648,                    "used_in_bytes": 666012352,                    "free_percent": 1,                    "used_percent": 99                },                           }        },由于节点名称是动态的,我想为每个节点检索mem。我发现这是 为了检索数据,但它不是动态密钥。我们如何才能做到这一点。
查看完整描述

1 回答

?
幕布斯6054654

TA贡献1876条经验 获得超7个赞

学习如何在 Go 中处理数据的一个很好的参考:http : //blog.golang.org/json-and-go


关于您的问题,在我看来,您的数据结构相对较好……我mem在以下操场示例中设置了提取每个节点部分的示例:


http://play.golang.org/p/0O5U-3N_tA


它的要点是任何被强烈指定的都可以编码为structs。动态的(例如您的节点名称)可以编码为映射。两者可以任意混合,这样:


type Node struct {

    Timestamp        uint64            `json:timestamp`

    Name             string            `json:name`

    TransportAddress string            `json:transport_address`

    Host             string            `json:host`

    Ip               []string          `json:ip`

    Attributes       map[string]string `json:attributes`

    Os               *OsInfo           `json:os`

}


type Payload struct {

    Name  string           `json:cluster_name`

    Nodes map[string]*Node `json:nodes`

}

可以捕获节点的一般结构(通过其struct定义)和它们被动态索引的事实(通过节点本身存储在动态map.


一旦解组,处理你的数据以提取你的内存信息就很简单了:它只是众所周知的结构和映射:


var p Payload

if err := json.Unmarshal([]byte(payload), &p); err != nil {

    log.Fatal(err)

}

for k, node := range p.Nodes {

    fmt.Printf("%s: %s\n", k, node.Os.Mem)

}

按预期输出:


Sd2AvEXsswjTn6ErRYjg: map[total_in_bytes:%!s(uint64=163987664) free_in_bytes:%!s(uint64=136357264) used_in_bytes:%!s(uint64=26629400) free_percent:%!s(uint64=84) used_percent:%!s(uint64=16)]

yzabB-OaTfOqvgAELIMq1Q: map[used_percent:%!s(uint64=99) total_in_bytes:%!s(uint64=623840000) free_in_bytes:%!s(uint64=4127648) used_in_bytes:%!s(uint64=666012352) free_percent:%!s(uint64=1)]

q5CdgUF2TRewujr-0RPMgQ: map[total_in_bytes:%!s(uint64=163898764) free_in_bytes:%!s(uint64=139705616) used_in_bytes:%!s(uint64=24194588) free_percent:%!s(uint64=85) used_percent:%!s(uint64=15)]

(您当然可以先提取/重新格式化您的数据,并在Payload完成后立即丢弃该对象)


查看完整回答
反对 回复 2022-01-04
  • 1 回答
  • 0 关注
  • 152 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信