首页 > 解决方案 > 报告每个(可选)子元素

问题描述

想解析以下内容:

{
  "issues": [
    { "id": "1", "fields": { "links": [] } },
    { "id": "2", "fields": { "links": [ { "inlink": { "id": "red" } } ] } },
    { "id": "3", "fields": { "links": [ { "outlink": { "id": "yellow" } } ] } },
    { "id": "4", "fields": { "links": [ { "inlink": { "id": "green" } }, { "outlink": { "id": "blue" } } ] } }
  ]
}

成表示元素的links元素,一对一,像这样(注意id 1缺少并id 4出现两次:

  { "id": "2", "link": { "linktype": "inlink", "id": "red" } },
  { "id": "3", "link": { "linktype": "outlink", "id": "yellow" } },
  { "id": "4", "link": { "linktype": "inlink", "id": "green" } },
  { "id": "4", "link": { "linktype": "outlink", "id": "blue" } }

以下jq适用于inlinkoutlink单独适用

.issues[] | .id as $id | .fields.links[] | .inlink.id as $lid | {$id,$lid}

给予

{ "id": "2", "lid": "red" }
{ "id": "3", "lid": null }
{ "id": "4", "lid": "green" }
{ "id": "4", "lid": null }

但无法弄清楚如何同时跟踪两种类型或引入 key linktype。有任何想法吗?

标签: jq

解决方案


jq解决方案:

jq -c '.issues[] | .id as $id
       | .fields.links[] | to_entries[]
       | {"id": $id, "link": {"linktype": .key, "id": .value.id}}' file

输出:

{"id":"2","link":{"linktype":"inlink","id":"red"}}
{"id":"3","link":{"linktype":"outlink","id":"yellow"}}
{"id":"4","link":{"linktype":"inlink","id":"green"}}
{"id":"4","link":{"linktype":"outlink","id":"blue"}}

推荐阅读