[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597543322,
                "creation_date": 1597543322,
                "answer_id": 63432447,
                "question_id": 63432348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have a couple of options:\r\n\r\n1. You can specify the second index of the amphorae array, that is if you are sure the &quot;ALLOCATED&quot; part will always be the second index of the amphorae array\r\n\r\n```\r\n    .amphorae[1] | &quot;\\(.status)=\\(.id),\\(.loadbalancer_id)&quot;\r\n```\r\n\r\n2. This is a little bit more complex, but will always ensure you get only the element of the amphorae array where the status key is &#39;ALLOCATED&#39;\r\n\r\n```\r\n.amphorae | map(select(.status == &quot;ALLOCATED&quot;))[] | &quot;\\(.status)=\\(.id),\\(.loadbalancer_id)&quot;\r\n```",
                "title": "JSON parse with jq and filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597543322,
        "creation_date": 1597541900,
        "question_id": 63432348,
        "body_markdown": "I am learning jq. I have content as below:\r\n\r\n    {\r\n       &quot;amphorae_links&quot;:[\r\n    \r\n       ],\r\n       &quot;amphorae&quot;:[\r\n          {\r\n             &quot;status&quot;:&quot;BOOTING&quot;,\r\n             &quot;loadbalancer_id&quot;:null,\r\n             &quot;created_at&quot;:&quot;2020-06-23T08:56:56&quot;,\r\n             &quot;vrrp_id&quot;:null,\r\n             &quot;id&quot;:&quot;6d66935e-6d39-40c9-bb0d-dd6a734dc77b&quot;\r\n          },\r\n          {\r\n             &quot;status&quot;:&quot;ALLOCATED&quot;,\r\n             &quot;loadbalancer_id&quot;:&quot;79970c9a-b0ba-4cde-a7e6-16b61641a7b8&quot;,\r\n             &quot;created_at&quot;:&quot;2020-06-25T06:41:56&quot;,\r\n             &quot;vrrp_id&quot;:1,\r\n             &quot;id&quot;:&quot;872c08ee-9b21-4b26-9550-c2ffb4a1ad59&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\nI want to have an output like \r\n\r\n    &quot;ALLOCATED=872c08ee-9b21-4b26-9550-c2ffb4a1ad59,79970c9a-b0ba-4cde-a7e6-16b61641a7b8&quot;\r\n\r\n\r\nI tried to use below, but I don&#39;t know how to remove the line with status as &quot;BOOTING&quot;.\r\n\r\n    .amphorae[] | &quot;\\(.status)=\\(.id),\\(.loadbalancer_id)&quot;\r\n\r\n\r\nThanks anyone for the helping.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63432348/json-parse-with-jq-and-filter",
        "title": "JSON parse with jq and filter"
    },
    {
        "tags": [
            "json",
            "file",
            "object",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1597692387,
                "post_id": 63457122,
                "comment_id": 112211551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597699364,
                "creation_date": 1597699364,
                "answer_id": 63458832,
                "question_id": 63457122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out in the comments, you can use the -s option, which is usually fine, but for very large JSON objects, it might be more economical to use `inputs`, e.g. with `reduce`:\r\n\r\n    jq -n &#39;reduce inputs as $in (null; . + $in)&#39; a.json b.json\r\n\r\nArbitrarily many files (or an arbitrarily long streams of JSON objects) can be processed in this way.  \r\n\r\nOf course, if the JSON objects do not have distinct keys, the above will potentially lose information, and an alternative to `+` for merging objects might be appropriate.\r\n",
                "title": "jq - merge two files on all top keys"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597720743,
        "creation_date": 1597691042,
        "last_edit_date": 1597720743,
        "question_id": 63457122,
        "body_markdown": "Given:\r\n\r\n**a.json**:\r\n\r\n```js\r\n{&quot;a&quot;: 1}\r\n```\r\n\r\n**b.json**:\r\n\r\n```js\r\n{&quot;b&quot;: 2}\r\n```\r\n\r\nRequired contents of **merged.json**:\r\n\r\n```js\r\n{&quot;a&quot;: 1, &quot;b&quot;: 2}\r\n```\r\n\r\nQuestion:\r\n\r\nWhat&#39;s the `jq` syntax to merge **a.json** and **b.json** into **merged.json**?\r\n\r\nTried:\r\n\r\n```js\r\njq &#39;.* += input.*&#39; a.json b.json\r\n```\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63457122/jq-merge-two-files-on-all-top-keys",
        "title": "jq - merge two files on all top keys"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597737808,
                "post_id": 63463982,
                "comment_id": 112224110,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13383595,
                    "reputation": 387,
                    "user_id": 9658138,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "장수환",
                    "link": "https://stackoverflow.com/users/9658138/%ec%9e%a5%ec%88%98%ed%99%98"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597738544,
                "post_id": 63463982,
                "comment_id": 112224426,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1597739020,
                "post_id": 63463982,
                "comment_id": 112224646,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1597737445,
                "creation_date": 1597737445,
                "answer_id": 63464212,
                "question_id": 63463982,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `with_entries` or multiple `select`s there. The following program does exactly the same thing and is way shorter.\r\n```\r\n.RED[] | select(.attr1 == &quot;aaaa&quot; and .attr2 == &quot;bbbb&quot;) .attr3\r\n```",
                "title": "Extract a field if it is accompanied by specific key-value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1597743387,
        "creation_date": 1597736538,
        "last_edit_date": 1597743387,
        "question_id": 63463982,
        "body_markdown": "    //test.json\r\n    {\r\n    &quot;RED&quot;:\r\n      [\r\n        {\r\n          &quot;attr1&quot;: &quot;aaaa&quot;,\r\n          &quot;attr2&quot;: &quot;bbbb&quot;,\r\n          &quot;attr3&quot;: &quot;cccc&quot;\r\n        },\r\n        {\r\n          &quot;attr1&quot;: &quot;aaaa&quot;,\r\n          &quot;attr2&quot;: &quot;dddd&quot;,\r\n          &quot;attr3&quot;: &quot;eeee&quot;\r\n        }\r\n      ],\r\n    &quot;WHITE&quot;:\r\n      [\r\n        {\r\n          &quot;attr1&quot;: &quot;aaaa&quot;,\r\n          &quot;attr2&quot;: &quot;bbbb&quot;,\r\n          &quot;attr3&quot;: &quot;cccc&quot;\r\n        },\r\n        {\r\n          &quot;attr1&quot;: &quot;aaaa&quot;,\r\n          &quot;attr2&quot;: &quot;dddd&quot;,\r\n          &quot;attr3&quot;: &quot;eeee&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to get a value that meets (key=RED &amp;&amp; attr1=&quot;aaaa&quot; &amp;&amp; attr2=&quot;bbbb&quot;)\r\n\r\nSo I have written jq command like this :\r\n\r\n    jq -r &#39;with_entries(select([.key] | inside([&quot;RED&quot;]))) | .[] | .[] | select(.attr1==&quot;aaaa&quot;) | select(.attr2==&quot;bbbb&quot;) | .attr3&#39; test.json\r\n\r\nthis command works well. but I think that command is a little long.\r\nHow can I shorten the command without reducing readability?\r\n(* This is my first time using JQ)",
        "link": "https://stackoverflow.com/questions/63463982/extract-a-field-if-it-is-accompanied-by-specific-key-value-pairs",
        "title": "Extract a field if it is accompanied by specific key-value pairs"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8805101,
                    "reputation": 3137,
                    "user_id": 6580047,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XyMdy.jpg?s=256",
                    "display_name": "Gustavo Kawamoto",
                    "link": "https://stackoverflow.com/users/6580047/gustavo-kawamoto"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597766538,
                "post_id": 63472280,
                "comment_id": 112238530,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7752783,
                    "reputation": 455,
                    "user_id": 5868190,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://graph.facebook.com/1964404870451295/picture?type=large",
                    "display_name": "Noim",
                    "link": "https://stackoverflow.com/users/5868190/noim"
                },
                "reply_to_user": {
                    "account_id": 8805101,
                    "reputation": 3137,
                    "user_id": 6580047,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XyMdy.jpg?s=256",
                    "display_name": "Gustavo Kawamoto",
                    "link": "https://stackoverflow.com/users/6580047/gustavo-kawamoto"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597766744,
                "post_id": 63472280,
                "comment_id": 112238664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597767050,
                "creation_date": 1597767050,
                "answer_id": 63472570,
                "question_id": 63472280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That can be done using bash loops:\r\n\r\n    #!/bin/bash\r\n    # saving the json so we can manipulate it freely\r\n    data=&quot;$(cat data.json)&quot;\r\n    for k in $(echo &quot;$data&quot; | jq &#39;.remove&#39; | jq -r keys[]) # getting all the keys from remove\r\n    do\r\n        # skipping the key if it isn&#39;t supposed to be removed\r\n        [ $(echo &quot;$data&quot; | jq .remove.$k) == &#39;false&#39; ] &amp;&amp; continue\r\n        data=&quot;$(echo &quot;$data&quot; | jq &quot;del(.dic.$k)&quot;)&quot; # removing the key\r\n    done\r\n    echo &quot;$data&quot; # final json without the keys\r\n",
                "title": "remove keys that are present in sibling object and have a certain value"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1607335896,
                "last_edit_date": 1607335896,
                "creation_date": 1597767708,
                "answer_id": 63472740,
                "question_id": 63472280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need anything other than JQ for that.\r\n```\r\n[.remove | path(.[] | select(.))] as $p | .dic |= delpaths($p)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/4cCuXMQn9W)&lt;/sup&gt;\r\n\r\nIf there might be other values in `remove` than **true** and **false**, use\r\n```\r\nselect(. == true)\r\n```\r\ninstead of\r\n```\r\nselect(.)\r\n```",
                "title": "remove keys that are present in sibling object and have a certain value"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1597801197,
                "creation_date": 1597801197,
                "answer_id": 63478834,
                "question_id": 63472280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward and efficient solution using jq alone:\r\n```\r\n(.remove | with_entries(select(.value == true))) as $remove\r\n| .dic |= with_entries(select($remove[.key] | not))\r\n```",
                "title": "remove keys that are present in sibling object and have a certain value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 5,
        "last_activity_date": 1607335896,
        "creation_date": 1597766084,
        "last_edit_date": 1597813533,
        "question_id": 63472280,
        "body_markdown": "I have the following input file:\r\n\r\n    {\r\n        &quot;dic&quot;: {\r\n            &quot;a&quot;: &quot;&quot;,\r\n            &quot;b&quot;: &quot;&quot;,\r\n            &quot;c&quot;: &quot;&quot;,\r\n            &quot;d&quot;: &quot;&quot;\r\n        },\r\n        &quot;remove&quot;: {\r\n            &quot;b&quot;: true,\r\n            &quot;c&quot;: false,\r\n            &quot;d&quot;: true\r\n        }\r\n    }\r\n\r\nI want to remove with jq all elements of the dictionary `dic` which are also in the dictionary `remove` with the value true.\r\n\r\nThis would be the output:\r\n\r\n    {\r\n        &quot;dic&quot;: {\r\n            &quot;a&quot;: &quot;&quot;,\r\n            &quot;c&quot;: &quot;&quot;\r\n        },\r\n        &quot;remove&quot;: {\r\n            &quot;b&quot;: true,\r\n            &quot;c&quot;: false,\r\n            &quot;d&quot;: true\r\n        }\r\n    }\r\n\r\nI am not sure how to do this. I would first need to clean the `remove` dic and only get the keys with the value true. Then I would need to somehow only delete these keys from `dic`.",
        "link": "https://stackoverflow.com/questions/63472280/remove-keys-that-are-present-in-sibling-object-and-have-a-certain-value",
        "title": "remove keys that are present in sibling object and have a certain value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597794333,
                "creation_date": 1597794333,
                "answer_id": 63478133,
                "question_id": 63477501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this?\r\n\r\n    jq -S &#39;.[] |= sort_by(.foo)&#39;\r\n\r\nOutput\r\n\r\n    {\r\n      &quot;&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;d&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;f&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;g&quot;\r\n        }\r\n      ],\r\n      &quot;ab&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;def&quot;\r\n        }\r\n      ],\r\n      &quot;c&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;def&quot;\r\n        }\r\n      ],\r\n      &quot;e&quot;: [\r\n        {\r\n          &quot;foo&quot;: &quot;def&quot;\r\n        },\r\n        {\r\n          &quot;foo&quot;: &quot;xyz&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "jq: sort object values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597803917,
                "creation_date": 1597803917,
                "answer_id": 63479156,
                "question_id": 63477501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@user197693 had a great answer. A suggestion I got in a private message elsewhere was to use\r\n\r\n    jq -S &#39;with_entries(.value |= sort_by(.foo))&#39;",
                "title": "jq: sort object values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597823366,
                "creation_date": 1597823366,
                "answer_id": 63482323,
                "question_id": 63477501,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If for some reason using the `-S` command-line option is not a satisfactory option, you can also perform the by-key sort using the `to_entries | sort_by(.key) | from_entries` idiom. So a complete solution to the problem would be:\r\n\r\n```\r\n.[] |= sort_by(.foo)\r\n| to_entries | sort_by(.key) | from_entries\r\n```",
                "title": "jq: sort object values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1597823366,
        "creation_date": 1597789822,
        "question_id": 63477501,
        "body_markdown": "I want to sort this data structure by the object keys (easy with `-S` and sort the object values (the arrays) by the &#39;foo&#39; property.\r\n\r\nI can sort them with\r\n\r\n```\r\njq -S &#39;\r\n  . as $in\r\n  | keys[]\r\n  | . as $k\r\n  | $in[$k] | sort_by(.foo)\r\n    &#39; &lt; test.json\r\n```\r\n\r\n... but that loses the keys.  \r\n\r\nI&#39;ve tried variations of adding `  | { &quot;\\($k)&quot;: . }`, but then I end up with a list of objects instead of one object.  I also tried variations of adding to $in (same problem) or using `$in = $in * { ... }`, but that gives me syntax errors.\r\n\r\nThe one solution I did find was to just have the separate objects and then pipe it into `jq -s add`, but ... I really wanted it to work the other way. :-)\r\n\r\nTest data below:\r\n\r\n```\r\n{\r\n    &quot;&quot;: [\r\n        { &quot;foo&quot;: &quot;d&quot; },\r\n        { &quot;foo&quot;: &quot;g&quot; },\r\n        { &quot;foo&quot;: &quot;f&quot; }\r\n    ],\r\n    &quot;c&quot;: [\r\n        { &quot;foo&quot;: &quot;abc&quot; },\r\n        { &quot;foo&quot;: &quot;def&quot; }\r\n    ],\r\n    &quot;e&quot;: [\r\n        { &quot;foo&quot;: &quot;xyz&quot; },\r\n        { &quot;foo&quot;: &quot;def&quot; }\r\n    ],\r\n    &quot;ab&quot;: [\r\n        { &quot;foo&quot;: &quot;def&quot; },\r\n        { &quot;foo&quot;: &quot;abc&quot; }\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/63477501/jq-sort-object-values",
        "title": "jq: sort object values"
    },
    {
        "tags": [
            "rest",
            "shell",
            "jq",
            "partition"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597820308,
                "post_id": 63481172,
                "comment_id": 112254515,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1597822378,
                "post_id": 63481172,
                "comment_id": 112255320,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1597826548,
                "post_id": 63481172,
                "comment_id": 112257271,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597821804,
                "creation_date": 1597821804,
                "answer_id": 63481916,
                "question_id": 63481172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you have this formatting, splitting can be done by unpacking the array and saving the desired number of objects to separate files, e.g.:\r\n```\r\n&lt;input.json jq -c &#39;.[]&#39; | split -l500\r\n```\r\nWhich creates `xaa` with the first 500 objects, `xab` with the next 500 objects, etc. If you want to repackage the objects in an array, use the `-s` option to `jq`, e.g.: `jq -s . xaa`.",
                "title": "Partition JSON data using jq and then send Rest query"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1597828997,
                "last_edit_date": 1597828997,
                "creation_date": 1597822234,
                "answer_id": 63482033,
                "question_id": 63481172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have not shared any HW information of the system you are running this on. At the minimum you need to do some sort of multiprocessing to make this faster instead of running (1000000/500) curl requests altogether.\r\n\r\nOne way, would be to use GNU `xargs` which has a built-in to run number of parallel instances of a given process using the `-P` flag and number of lines of input to read from at any time with the `L` flag. \r\n\r\nTo start with you can do something like below to instruct curl to run on 500 lines at a time and invoke 20 such invocations in parallel. So at a given tick, approximately (500 *20) lines of input are processed. You can tune the numbers depending on your HW capability both on the host and the server side.\r\n\r\n    xargs -L 500 -P 20 curl -X POST -H &quot;Content-Type: application/json&quot;  http://sample-url -d @- &lt; &lt;(jq -c &#39;range(0;length;500) as $i | .[$i: $i+500]&#39; json)\r\n\r\nModified `jq` filter to pack the JSON payload as an array of objects (credit [peak&#39;s answer](https://stackoverflow.com/a/63482061/5291015)). The earlier version `jq -c &#39;.[]&#39; json` might not work as the individual chunk of lines passed at a time doesn&#39;t represent a valid JSON.\r\n\r\nNote: Not tested due to performance constraints. ",
                "title": "Partition JSON data using jq and then send Rest query"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1597825634,
                "last_edit_date": 1597825634,
                "creation_date": 1597822335,
                "answer_id": 63482061,
                "question_id": 63481172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s an intrinsic tradeoff here between space and time efficiency. In the following, the focus is on the latter.\r\n\r\nAssuming that each call to `curl` must send a JSON array, a time-efficient solution can be constructed along the following lines:\r\n```\r\n&lt; array.json jq -c &#39;\r\n  def batch($n): length as $l | range(0;length;$n) as $i | .[$i: $i+n];\r\n  batch(500)\r\n&#39; | while read -r json\r\ndo\r\n    echo &quot;$json&quot; | curl -X POST -H &quot;Content-Type: application/json&quot; -d -@ ....\r\ndone\r\n```\r\nHere `....` signifies additional appropriate curl arguments.\r\n\r\n## GNU parallel\r\nYou might also want to consider using GNU [tag:parallel], e.g.:\r\n```\r\n&lt; array.json jq -c &#39;\r\n  def batch($n):\r\n    length as $l\r\n    | range(0;length;$n) as $i\r\n    | .[$i: $i+n];\r\n  batch(500)\r\n&#39; | parallel --pipe -N1 curl -X POST -H &quot;Content-Type: application/json&quot;  -d @- ....\r\n```\r\n    \r\n",
                "title": "Partition JSON data using jq and then send Rest query"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1597822983,
                "creation_date": 1597822983,
                "answer_id": 63482218,
                "question_id": 63481172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to do this from the shell, you could use `jq` to split your JSON and pass it to `xargs` to call `curl` for each object returned. \r\n\r\n    jq -c &#39;.[]&#39; temp.json | xargs -I {} curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d &#39;{}&#39;\r\n\r\nThis will send *one* `curl` request for each object. However, if you e.g. want to send the first 500 objects in *a single* `curl` request, you can specify a subarray in the `jq` filter. To send all of your JSON objects you will then somehow need to repeat the command, as afaik `jq` has no built-in way to split the input into chunks of objects.\r\n\r\n    jq -c &#39;.[0:500]&#39; temp.json | xargs -I {} curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d &#39;{}&#39;\r\n    jq -c &#39;.[500:1000]&#39; temp.json | xargs -I {} curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d &#39;{}&#39;\r\n    jq -c &#39;.[1000:1500]&#39; temp.json | xargs -I {} curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d &#39;{}&#39;\r\n    [...]\r\n",
                "title": "Partition JSON data using jq and then send Rest query"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1597828997,
        "creation_date": 1597818548,
        "last_edit_date": 1597822697,
        "question_id": 63481172,
        "body_markdown": "I have a json file like below \r\n\r\n    [\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        },\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        },\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        }\r\n    \t{\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        },\r\n        {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        }\r\n    \t    {\r\n            &quot;field&quot;: {\r\n                &quot;empID&quot;: &quot;sapid&quot;,\r\n                &quot;location&quot;: &quot;India&quot;,            \r\n            }\r\n        }\r\n    \t.... upto 1 million\r\n    ]\r\n\r\nI have to use this json as an input for a rest request For example\r\n\r\n    curl &lt;REST Server URL with temp.json as input&gt; &quot;Content-Type: application/json&quot; -d @temp.json\r\n\r\nMy server will not accept 1 million json object at a time. \r\nI am looking for an approach where i have to extract the first 500 objects from the main json and send it in one rest query and then next 500 object in second rest query and so on.\r\n\r\nCan you please suggest how can i achieve this by jq? ",
        "link": "https://stackoverflow.com/questions/63481172/partition-json-data-using-jq-and-then-send-rest-query",
        "title": "Partition JSON data using jq and then send Rest query"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597847236,
                "last_edit_date": 1597847236,
                "creation_date": 1597846819,
                "answer_id": 63489060,
                "question_id": 63486554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Store the values in appropriate variables while traversing the JSON and put the final result into an array. \r\n\r\nRun the `jq` command in `-r/--raw-output` mode when using `join(&quot; &quot;)`. You could also use `@csv` or `@tsv` instead, to put the results in CSV or TSV format.\r\n\r\n    .Volumes[] | \r\n    .Size as $s | \r\n    .VolumeType as $v | \r\n    .Tags[] | select(.Key == &quot;Name&quot;).Value as $k | \r\n    [$k, $s, $v] | join(&quot; &quot;)\r\n\r\n&lt;sup&gt;[jqplay - Demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/AiAOuqyFaC",
                "title": "Generating tabular output from jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1597907111,
        "creation_date": 1597838573,
        "last_edit_date": 1597907111,
        "question_id": 63486554,
        "body_markdown": "I have a json file and I need to extract some data from  it. \r\n```\r\n{\r\n    &quot;Volumes&quot;: [\r\n        {\r\n            &quot;Attachments&quot;: [],\r\n            &quot;Encrypted&quot;: true,\r\n            &quot;Size&quot;: 100,\r\n            &quot;SnapshotId&quot;: &quot;&quot;,\r\n            &quot;State&quot;: &quot;available&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;kubernetes-dynamic-pvc-claim1&quot;\r\n                },\r\n\r\n                {\r\n                    &quot;Key&quot;: &quot;kubernetes.io/created-for/pv/name&quot;,\r\n                    &quot;Value&quot;: &quot;pvc-claim1&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeType&quot;: &quot;io1&quot;,\r\n            &quot;MultiAttachEnabled&quot;: false\r\n        },\r\n        {\r\n            &quot;Attachments&quot;: [],\r\n            &quot;Encrypted&quot;: true,\r\n            &quot;Size&quot;: 200,\r\n            &quot;SnapshotId&quot;: &quot;&quot;,\r\n            &quot;State&quot;: &quot;available&quot;,\r\n            &quot;Tags&quot;: [\r\n                {\r\n                    &quot;Key&quot;: &quot;kubernetes.io/created-for/pv/name&quot;,\r\n                    &quot;Value&quot;: &quot;pvc-claim2&quot;\r\n                },\r\n                {\r\n                    &quot;Key&quot;: &quot;Name&quot;,\r\n                    &quot;Value&quot;: &quot;kubernetes-dynamic-pvc-claim2&quot;\r\n                }\r\n            ],\r\n            &quot;VolumeType&quot;: &quot;gp2&quot;,\r\n            &quot;MultiAttachEnabled&quot;: false\r\n        }\r\n\r\n    ]\r\n}\r\n\r\n```\r\n\r\nI wanted to extract Tags values, whose keys are Name: For eg:\r\n\r\nI wanted to get only kubernetes-dynamic-pvc-claim1 and kubernetes-dynamic-pvc-claim2.\r\n\r\nI wanted results like:\r\n```\r\nkubernetes-dynamic-pvc-claim1\r\nkubernetes-dynamic-pvc-claim2\r\n```\r\n\r\nHow do I do that ? I have been struggling with jq and tried something like;\r\n```\r\n&#39;jq -r .&#39;Volumes[].Tags[0].Value&#39;\r\n```\r\nBut it is not giving me result as expected.\r\n\r\nAlso, how do I get output with Size and VOlumetype on their side as below ?\r\n\r\nI wanted results like:\r\n```\r\nkubernetes-dynamic-pvc-claim1  100  io1\r\nkubernetes-dynamic-pvc-claim2  200  gp2 \r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63486554/generating-tabular-output-from-jq",
        "title": "Generating tabular output from jq"
    },
    {
        "tags": [
            "json",
            "parent-child",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1597845367,
                "creation_date": 1597845367,
                "answer_id": 63488601,
                "question_id": 63488357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can select the object matching the condition and append to that object. Something like below. The key is to use `+=` the modification assignment to not lose the other objects\r\n\r\n    (.components[] | select(.details.age == &quot;25&quot;)) += { &quot;description&quot;: &quot;5 years less than 30&quot; }\r\n\r\n&lt;sup&gt;[jqplay - Demo](https://jqplay.org/s/_m0fNNG-8x)&lt;/sup&gt;",
                "title": "Add key value to parent subelement if child has specific key:value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1597861392,
                "creation_date": 1597861392,
                "answer_id": 63492880,
                "question_id": 63488357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward (&quot;no magic&quot;) and efficient solution:\r\n\r\n    .components |= \r\n      map(if .details.age==&quot;25&quot; then .description = &quot;5 years less than 30&quot; else . end)",
                "title": "Add key value to parent subelement if child has specific key:value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597895391,
        "creation_date": 1597844632,
        "last_edit_date": 1597895391,
        "question_id": 63488357,
        "body_markdown": "I&#39;m trying to understand what&#39;s the best way to add a json element to child&#39;s parent \r\nif that child contains a specific key:value and finally print the entire json using jq\r\nI try to explain better with an example.\r\nThe input json is:\r\n\r\n    {\r\n      &quot;family&quot;: {\r\n        &quot;surname&quot;: &quot;Smith&quot;\r\n      },\r\n      &quot;components&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;brown&quot;,\r\n            &quot;eyes&quot;: &quot;brown&quot;,\r\n            &quot;age&quot;: &quot;56&quot;\r\n          },\r\n          &quot;role&quot;: &quot;father&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Mary&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;blonde&quot;,\r\n            &quot;eyes&quot;: &quot;green&quot;,\r\n            &quot;age&quot;: &quot;45&quot;\r\n          },\r\n          &quot;role&quot;: &quot;mother&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;George&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;blonde&quot;,\r\n            &quot;eyes&quot;: &quot;brown&quot;,\r\n            &quot;age&quot;: &quot;25&quot;\r\n          },\r\n          &quot;role&quot;: &quot;child&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to add:\r\n&quot;description&quot;: &quot;5 years less than 30&quot;\r\nat the same level of &quot;details&quot; if &quot;age&quot; is equal to &quot;25&quot; and then print the result:\r\n\r\n    {\r\n      &quot;family&quot;: {\r\n        &quot;surname&quot;: &quot;Smith&quot;\r\n      },\r\n      &quot;components&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;brown&quot;,\r\n            &quot;eyes&quot;: &quot;brown&quot;,\r\n            &quot;age&quot;: &quot;56&quot;\r\n          },\r\n          &quot;role&quot;: &quot;father&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Mary&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;blonde&quot;,\r\n            &quot;eyes&quot;: &quot;green&quot;,\r\n            &quot;age&quot;: &quot;45&quot;\r\n          },\r\n          &quot;role&quot;: &quot;mother&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;George&quot;,\r\n          &quot;details&quot;: {\r\n            &quot;hair&quot;: &quot;blonde&quot;,\r\n            &quot;eyes&quot;: &quot;brown&quot;,\r\n            &quot;age&quot;: &quot;25&quot;\r\n          },\r\n          &quot;role&quot;: &quot;child&quot;,\r\n          &quot;description&quot;: &quot;5 years less than 30&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nThe only solution I&#39;ve found was to apply the update but printing only the &quot;components&quot; content;\r\nthen I&#39;ve removed from the JSON and finally inserted the modified &quot;components&quot; content previously saved, in this way:\r\n\r\n    cat sample.json | jq -c &#39; .components[] | select(.details.age==&quot;25&quot;) |= . + {description: &quot;5 years less than 30&quot; } &#39; &gt; /tmp/saved-components.tmp\r\n    cat sample.json | jq --slurpfile savedcomponents /tmp/saved-components.tmp &#39;del(.components) | . + { components: [ $savedcomponents ] }&#39;\r\n\r\nI don&#39;t think it&#39;s the best way to solve these kind of problems, so I&#39;d like to know what is\r\nthe right &quot;jq approach&quot;.\r\nI forgot to say: I prefer to use jq only, not other tools\r\n\r\nThan you\r\n\r\nMarco\r\n",
        "link": "https://stackoverflow.com/questions/63488357/add-key-value-to-parent-subelement-if-child-has-specific-keyvalue",
        "title": "Add key value to parent subelement if child has specific key:value"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1597934279,
                "post_id": 63505416,
                "comment_id": 112299895,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1597987088,
                "post_id": 63505416,
                "comment_id": 112316481,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597998871,
                "last_edit_date": 1597998871,
                "creation_date": 1597942094,
                "answer_id": 63509715,
                "question_id": 63505416,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Part 1\r\nThe first part of the question is easily answered by expanding .Body just once:\r\n```\r\n[.[] | {Region: .Header.Region, Tenants: [.Body[] | {tenantUuid, tenantState}] }]\r\n```\r\n\r\n## Part 2 \r\nTo simplify the exposition here, let&#39;s filter the result obtained above. If we want to modify .Tenants to include only objects with .tenantState == &quot;DISABLED&quot; we could add the following filter to the pipeline:\r\n```\r\nmap( .Tenants |= map(select(.tenantState == &quot;DISABLED&quot;)) )\r\n```\r\n\r\nThe Q, however, suggests that empty arrays should be excluded from the final result, so we could further tack on:\r\n\r\n    map( select(.Tenants != []) )\r\n\r\n## In summary\r\nPutting the above together:\r\n```\r\n[.[] | {Region: .Header.Region, Tenants: [.Body[] | {tenantUuid, tenantState}] }]\r\n| map( .Tenants |= map(select(.tenantState == &quot;DISABLED&quot;)) )\r\n| map( select(.Tenants != []) )\r\n```\r\n\r\nOf course, it would be more efficient to perform the selection earlier in the pipeline -- by all means, have at it!\r\n",
                "title": "JQ: deleting unnecessary keys and re-formatting the JSON - most efficient ways"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1597998871,
        "creation_date": 1597927541,
        "question_id": 63505416,
        "body_markdown": "I have two questions to ask. Here is the JSON file below. \r\n\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Region&quot;: &quot;DC1&quot;\r\n        },\r\n        &quot;Body&quot;: [\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 682,\r\n                &quot;minAgentVersion&quot;: &quot;1.191.0.20180101-000000&quot;,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC1-Tenant1&quot;\r\n            },\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 957,\r\n                &quot;minAgentVersion&quot;: &quot;1.185.0.20180101-000000&quot;,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;DISABLED&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC1-Tenant2&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Region&quot;: &quot;DC2&quot;\r\n        },\r\n        &quot;Body&quot;: [\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 690,\r\n                &quot;minAgentVersion&quot;: &quot;1.163.0.20180101-000000&quot;,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC2-t4-p1&quot;\r\n            },\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 2441,\r\n                &quot;minAgentVersion&quot;: &quot;1.161.0.20180101-000000&quot;,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC2-t5-p2&quot;\r\n            }\r\n        ]\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Region&quot;: &quot;DC3&quot;\r\n        },\r\n        &quot;Body&quot;: [\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 2046,\r\n                &quot;minAgentVersion&quot;: &quot;1.169.0.20180101-000000&quot;,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC3-r1-p1&quot;\r\n            },\r\n            {\r\n                &quot;agentMetaInfoDtos&quot;: [],\r\n                &quot;avgTraffic&quot;: 0,\r\n                &quot;minAgentVersion&quot;: null,\r\n                &quot;standardAgentVersion&quot;: null,\r\n                &quot;tenantState&quot;: &quot;FORSAKEN&quot;,\r\n                &quot;tenantUuid&quot;: &quot;DC3-r2-d1&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\nFirst, I want to delete unnecessary keys and re-format the JSON. I want to have the result look like following\r\n```\r\n[\r\n  {\r\n    &quot;Region&quot;: &quot;DC1&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant1&quot;\r\n      },\r\n      {\r\n        &quot;tenantState&quot;: &quot;DISABLED&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant2&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Region&quot;: &quot;DC2&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC2-t4-p1&quot;\r\n      },\r\n      {\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC2-t5-p2&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Region&quot;: &quot;DC3&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC3-r1-p1&quot;\r\n      },\r\n      {\r\n        &quot;tenantState&quot;: &quot;FORSAKEN&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC3-r2-d1&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n\r\n```\r\n\r\nMy brute-force (let&#39;s say dumb) filter is the following - delete everyting not needed an (BTW, below are just subset of keys I need to delete, there are more):\r\n```\r\ndel (.[].Body[].agentMetaInfoDtos) | del (.[].Body[].avgTraffic)  | del (.[].Body[].minAgentVersion) | del (.[].Body[].standardAgentVersion) | del (.[].Body[].serverDistribution)  |  [.[] | {&quot;Region&quot;: .Header.Region, Tenants:[ .Body[]] } ]\r\n```\r\nBut there should be a much better way to do this - just selecting only what is needed instead of deleting everything else. BTW, in the ``Body[]`` section it is always the same number of keys, it is content in ``agentMetaInfoDtos[]`` and other arrays/keys which are different. ``tenantState`` can have five different values.\r\n\r\nFirst, tried to use the following filter trying to select the right keys, instead of deleting everything else:\r\n```\r\n[.[] | {Region: .Header.Region, Tenants:[ {tenantUuid: .Body[].tenantUuid, tenantState: .Body[].tenantState} ] }] \r\n```\r\nBut the result is the duplication of key/values as below. \r\n\r\nI am sure there are multiple ways to accomplish what I want, could someone give a crash course or at least point in the right direction?\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Region&quot;: &quot;DC1&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant1&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant1&quot;,\r\n        &quot;tenantState&quot;: &quot;DISABLED&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant2&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant2&quot;,\r\n        &quot;tenantState&quot;: &quot;DISABLED&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Region&quot;: &quot;DC2&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC2-t4-p1&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC2-t4-p1&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC2-t5-p2&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC2-t5-p2&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;Region&quot;: &quot;DC3&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC3-r1-p1&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC3-r1-p1&quot;,\r\n        &quot;tenantState&quot;: &quot;FORSAKEN&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC3-r2-d1&quot;,\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;\r\n      },\r\n      {\r\n        &quot;tenantUuid&quot;: &quot;DC3-r2-d1&quot;,\r\n        &quot;tenantState&quot;: &quot;FORSAKEN&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nAnd the second question - even when I had the result, after that I wanted to filter it out further to have only the entries with the state DISABLED. So I used the filter\r\n`` map(select (.Tenants[].tenantState == &quot;DISABLED&quot; ))`` but the result displays both Active and disabled tenants in the DC3 as seen below.\r\n\r\nAny hint what I am doing wrong here?\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Region&quot;: &quot;DC1&quot;,\r\n    &quot;Tenants&quot;: [\r\n      {\r\n        &quot;tenantState&quot;: &quot;ACTIVE&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant1&quot;\r\n      },\r\n      {\r\n        &quot;tenantState&quot;: &quot;DISABLED&quot;,\r\n        &quot;tenantUuid&quot;: &quot;DC1-Tenant2&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/63505416/jq-deleting-unnecessary-keys-and-re-formatting-the-json-most-efficient-ways",
        "title": "JQ: deleting unnecessary keys and re-formatting the JSON - most efficient ways"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1597935508,
                "last_edit_date": 1597935508,
                "creation_date": 1597935056,
                "answer_id": 63507703,
                "question_id": 63507581,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We had a very similar question yesterday, [my answer to that](https://stackoverflow.com/a/63472740/10248678) can be adapted for this case as shown below.\r\n```\r\n$ jq &#39;delpaths([input | path(.[])])&#39; a.json b.json &gt; diff.json\r\n$ cat diff.json\r\n{\r\n  &quot;a&quot;: 1\r\n}\r\n```",
                "title": "remove top-level JSON keys that are present in second JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1597935508,
        "creation_date": 1597934675,
        "last_edit_date": 1597935225,
        "question_id": 63507581,
        "body_markdown": "I am trying to use `jq` to remove keys from the first file that exist in the second file.\r\n\r\nGiven:\r\n\r\n**a.json**:\r\n\r\n```js\r\n{&quot;a&quot;: 1, &quot;b&quot;: 2}\r\n```\r\n\r\n**b.json**:\r\n\r\n```js\r\n{&quot;b&quot;: true}\r\n```\r\n\r\nRequired contents of **diff.json**:\r\n\r\n```js\r\n{&quot;a&quot;: 1}\r\n```\r\n\r\nQuestion:\r\n\r\nWhat&#39;s the `jq` syntax to subtract these two JSONs?\r\n\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63507581/remove-top-level-json-keys-that-are-present-in-second-json",
        "title": "remove top-level JSON keys that are present in second JSON"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597947991,
                "last_edit_date": 1597947991,
                "creation_date": 1597946465,
                "answer_id": 63510817,
                "question_id": 63510772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Check if **message** points to an object which has the key **action** whose value is **foo** instead, and take logical complement of the result. There&#39;s no harm in typing a few more letters.\r\n```\r\nselect(.message | type == &quot;object&quot; and has(&quot;action&quot;) and .action == &quot;foo&quot; | not)\r\n```",
                "title": "How do I filter on an optional property value only if it exists?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1597948652,
                "creation_date": 1597948652,
                "answer_id": 63511313,
                "question_id": 63510772,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the alternative operator `//` to provide a default value for `action` when it does not exist (whether because it is missing or because the value is not an object in the first place):\r\n\r\n    jq &#39;select((.message.action? // &quot;foo&quot;) != &quot;foo&quot;)&#39;\r\n\r\nThis will accept either `{&quot;message&quot;: &quot;hi&quot;}` or `{&quot;message&quot;: {&quot;action&quot;: &quot;not foo&quot;}}`, but not `{&quot;message&quot;: {&quot;action&quot;: &quot;foo&quot;}}`.",
                "title": "How do I filter on an optional property value only if it exists?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1597974911,
        "creation_date": 1597946238,
        "last_edit_date": 1597974911,
        "question_id": 63510772,
        "body_markdown": "I have JSON such as:\r\n\r\n```{ &quot;message&quot;: &quot;hi&quot; }```\r\n\r\nBut it can also be of the format:\r\n\r\n```{ &quot;message&quot;: { &quot;action&quot;: &quot;foo&quot; } }```\r\n\r\nI want to filter out any records where the message.action == &quot;foo&quot; IF message.action even exists.\r\n\r\nIf I use the command:\r\n\r\n```\r\njq &#39;select(.message.action? == null or .message.action? != &quot;foo&quot; )&#39;\r\n```\r\n\r\nThen I get zero results. This appears to be because once you check for action, it then filters out any messages that are not objects, but I still want to be able to display ```{ message: &quot;hi&quot; }```",
        "link": "https://stackoverflow.com/questions/63510772/how-do-i-filter-on-an-optional-property-value-only-if-it-exists",
        "title": "How do I filter on an optional property value only if it exists?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1597986459,
                "last_edit_date": 1597986459,
                "creation_date": 1597982435,
                "answer_id": 63516334,
                "question_id": 63516078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the keys of the objects determine different values, you could do this rather nicely if you streamed the values in. Then you just need to parse out the parts of the paths and build up the results.\r\n\r\nStream, parse, then output.\r\n\r\n```\r\n$ jq --stream -r &#39;\r\nselect(length == 2) as [[$backend, $product, $subservice, $env, $aws_service], $value]\r\n  | {$env, $aws_service, $product, $backend, $subservice}\r\n  | &quot;aws_cost{\\([to_entries[] | &quot;\\(.key)=\\(.value|tojson)&quot;] | join(&quot;,&quot;))} \\($value)&quot;\r\n&#39; input.json\r\n```\r\n```\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;KMS&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 0.21\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;DynamoDB&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 235.91\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;ElastiCache&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 108.85\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;Elastic Load Balancing&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 324.29\r\naws_cost{env=&quot;env2&quot;,aws_service=&quot;KMS&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 0.21\r\naws_cost{env=&quot;env2&quot;,aws_service=&quot;Elastic Load Balancing&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 3.78\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;KMS&quot;,product=&quot;product2&quot;,backend=&quot;backend2&quot;,subservice=&quot;subservice2&quot;} 0.21\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;ElastiCache&quot;,product=&quot;product2&quot;,backend=&quot;backend2&quot;,subservice=&quot;subservice2&quot;} 108.85\r\naws_cost{env=&quot;env1&quot;,aws_service=&quot;Elastic Load Balancing&quot;,product=&quot;product2&quot;,backend=&quot;backend2&quot;,subservice=&quot;subservice2&quot;} 41.18\r\naws_cost{env=&quot;env2&quot;,aws_service=&quot;KMS&quot;,product=&quot;product2&quot;,backend=&quot;backend2&quot;,subservice=&quot;subservice2&quot;} 0.21\r\naws_cost{env=&quot;env2&quot;,aws_service=&quot;Elastic Load Balancing&quot;,product=&quot;product2&quot;,backend=&quot;backend2&quot;,subservice=&quot;subservice2&quot;} 3.78\r\n```",
                "title": "jq - How to iterate through nested keys with different names?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1597982693,
                "creation_date": 1597982693,
                "answer_id": 63516371,
                "question_id": 63516078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I came up with two ways to do it, one a little bit esoteric, the other a little bit brute-force. I&#39;m providing both so that you can choose your favorite (and try to understand both).\r\n\r\nEstoteric:\r\n\r\n    . as $data |\r\n    paths(scalars) | . as $path |\r\n    &quot;aws_cost{env=\\&quot;\\($path[3])\\&quot;,aws_service=\\&quot;\\($path[4])\\&quot;,product=\\&quot;\\($path[1])\\&quot;,backend=\\&quot;\\($path[0])\\&quot;,subservice=\\&quot;\\($path[2])\\&quot;} \\($data | getpath($path))&quot;\r\n\r\n`paths(scalars)` produces paths to all of the leaf nodes (not objects or arrays) in the input. Each path is an array like `[&quot;backend1&quot;,&quot;product1&quot;,&quot;subservice1&quot;,&quot;env1&quot;,&quot;KMS&quot;]`. You can see where we go with this — use the path itself to format the tag list, and use `getpath` to fetch the actual value. Some `as` shuffling is used so that `getpath` has the right `.` to operate on.\r\n\r\nBrute force:\r\n\r\n    to_entries[] | .key as $backend | .value | \r\n    to_entries[] | .key as $product | .value |\r\n    to_entries[] | .key as $subservice | .value |\r\n    to_entries[] | .key as $env | .value |\r\n    to_entries[] | .key as $service | \r\n    &quot;aws_cost{env=\\&quot;\\($env)\\&quot;,aws_service\\&quot;\\($service)\\&quot;,product=\\&quot;\\($product)\\&quot;,backend=\\&quot;\\($backend)\\&quot;,subservice=\\&quot;\\($subservice)\\&quot;} \\(.value)&quot;\r\n\r\n`to_entries` turns an object into an array of `key`/`value` pairs. For example, `{&quot;a&quot;:1,&quot;b&quot;:2}` becomes `[{&quot;key&quot;:&quot;a&quot;,&quot;value:1},{&quot;key&quot;:&quot;b&quot;,&quot;value&quot;:2}]`. We can use this to iterate over the keys at each level, capture the key using `as` for later use, and then put the value in `.` for further iteration. Then when we get to the bottom level, it&#39;s just string formatting.\r\n\r\nEither one should be run with `jq -r` so that the output strings don&#39;t get re-encoded as JSON.",
                "title": "jq - How to iterate through nested keys with different names?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1597988985,
        "creation_date": 1597980360,
        "last_edit_date": 1597988985,
        "question_id": 63516078,
        "body_markdown": "I have data in the following format. Keys are unique across elements.  \r\n\r\n    {\r\n      &quot;backend1&quot;: {\r\n        &quot;product1&quot;: {\r\n          &quot;subservice1&quot;: {\r\n            &quot;env1&quot;: {\r\n              &quot;KMS&quot;: &quot;0.21&quot;,\r\n              &quot;DynamoDB&quot;: &quot;235.91&quot;,\r\n              &quot;ElastiCache&quot;: &quot;108.85&quot;,\r\n              &quot;Elastic Load Balancing&quot;: &quot;324.29&quot;\r\n            },\r\n            &quot;env2&quot;: {\r\n              &quot;KMS&quot;: &quot;0.21&quot;,\r\n              &quot;Elastic Load Balancing&quot;: &quot;3.78&quot;\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;backend2&quot;: {\r\n        &quot;product2&quot;: {\r\n          &quot;subservice2&quot;: {\r\n            &quot;env1&quot;: {\r\n              &quot;KMS&quot;: &quot;0.21&quot;,\r\n              &quot;ElastiCache&quot;: &quot;108.85&quot;,\r\n              &quot;Elastic Load Balancing&quot;: &quot;41.18&quot;\r\n            },\r\n            &quot;env2&quot;: {\r\n              &quot;KMS&quot;: &quot;0.21&quot;,\r\n              &quot;Elastic Load Balancing&quot;: &quot;3.78&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\nI would like to iterate through the keys and transform JSON into Prometheus metric format.\r\n\r\n    aws_cost{env=&quot;env1&quot;,aws_service=&quot;KMS&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 0.21\r\n    aws_cost{env=&quot;env1&quot;,aws_service=&quot;DynamoDB&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 235.91\r\n    aws_cost{env=&quot;env1&quot;,aws_service=&quot;ElastiCache&quot;,product=&quot;product1&quot;,backend=&quot;backend1&quot;,subservice=&quot;subservice1&quot;} 108.85\r\n    .....\r\n\r\nI found that you can get keys at different indexes by using `.[] | .[] | .[] | .[]` but I do not know how to use a nested for loop to generate the data above. I&#39;m open to other solutions.",
        "link": "https://stackoverflow.com/questions/63516078/jq-how-to-iterate-through-nested-keys-with-different-names",
        "title": "jq - How to iterate through nested keys with different names?"
    },
    {
        "tags": [
            "bash",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1674243,
                    "reputation": 11390,
                    "user_id": 1553537,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://i.sstatic.net/5Xcxt.png?s=256",
                    "display_name": "Giorgi Tsiklauri",
                    "link": "https://stackoverflow.com/users/1553537/giorgi-tsiklauri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598014851,
                "post_id": 63523379,
                "comment_id": 112328003,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598015147,
                "post_id": 63523379,
                "comment_id": 112328136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6974839,
                    "reputation": 3146,
                    "user_id": 5809597,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c767eb3b64ae4c978cf631e6b84b712?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jorge Bellon",
                    "link": "https://stackoverflow.com/users/5809597/jorge-bellon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598015304,
                "post_id": 63523379,
                "comment_id": 112328217,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3814913,
                    "reputation": 33,
                    "user_id": 3164488,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/992b62f1837780229f0125e9fcaea0fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3164488",
                    "link": "https://stackoverflow.com/users/3164488/user3164488"
                },
                "reply_to_user": {
                    "account_id": 1674243,
                    "reputation": 11390,
                    "user_id": 1553537,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://i.sstatic.net/5Xcxt.png?s=256",
                    "display_name": "Giorgi Tsiklauri",
                    "link": "https://stackoverflow.com/users/1553537/giorgi-tsiklauri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598016350,
                "post_id": 63523379,
                "comment_id": 112328690,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3814913,
                    "reputation": 33,
                    "user_id": 3164488,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/992b62f1837780229f0125e9fcaea0fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3164488",
                    "link": "https://stackoverflow.com/users/3164488/user3164488"
                },
                "reply_to_user": {
                    "account_id": 1674243,
                    "reputation": 11390,
                    "user_id": 1553537,
                    "user_type": "registered",
                    "accept_rate": 29,
                    "profile_image": "https://i.sstatic.net/5Xcxt.png?s=256",
                    "display_name": "Giorgi Tsiklauri",
                    "link": "https://stackoverflow.com/users/1553537/giorgi-tsiklauri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598016400,
                "post_id": 63523379,
                "comment_id": 112328721,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3814913,
                    "reputation": 33,
                    "user_id": 3164488,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/992b62f1837780229f0125e9fcaea0fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3164488",
                    "link": "https://stackoverflow.com/users/3164488/user3164488"
                },
                "reply_to_user": {
                    "account_id": 6974839,
                    "reputation": 3146,
                    "user_id": 5809597,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c767eb3b64ae4c978cf631e6b84b712?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jorge Bellon",
                    "link": "https://stackoverflow.com/users/5809597/jorge-bellon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598016514,
                "post_id": 63523379,
                "comment_id": 112328783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598018003,
                "post_id": 63523379,
                "comment_id": 112329483,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598036179,
                "creation_date": 1598036179,
                "answer_id": 63528621,
                "question_id": 63523379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out in a comment, the second invocation of jq in the question can be made to work, but using string interpolation is generally regarded as an anti-pattern that&#39;s best avoided.  There are numerous alternatives, e.g.:\r\n\r\n    jq --arg token &quot;$TOKEN&quot; &#39;.DatabaseName = $token&#39; connector.json\r\n\r\nPlease also note that both updates can, and perhaps should, be performed with just one invocation of jq, e.g. along the lines of:\r\n\r\n    jq --arg token &quot;$TOKEN&quot; &#39;.awsIAMCred = &quot;hello&quot; | .DatabaseName = $token&#39; connector.json\r\n    ",
                "title": "jq: error: TOKEN/0 is not defined at &lt;top-level&gt;, line 1:"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1598082340,
        "creation_date": 1598014665,
        "last_edit_date": 1598082340,
        "question_id": 63523379,
        "body_markdown": "Below is the JSON file:\r\n\r\n```json\r\n{\r\n\t&quot;awsIAMCred&quot; : &quot;replaceme&quot;,\r\n\t&quot;DatabaseName&quot; : &quot;replaceme&quot;\r\n}\r\n```\r\n\r\nBelow is the bash file:\r\n\r\n\r\n```sh\r\n#!/bin/bash\r\n\r\necho BEGIN\r\ndate &#39;+%Y-%m-%d %H:%M:%S&#39;\r\n\r\nTOKEN=mouse\r\n\r\ntouch connector.json\r\n\r\nyum -y install moreutils            \r\nyum -y install nano\r\nyum -y install nc\r\necho install of nano,nc and moreutils are done\r\nchmod 660 connector.json\r\n\r\njq &#39;.awsIAMCred = &quot;hello&quot;&#39; connector.json|sponge connector.json\r\njq &#39;.DatabaseName = $TOKEN&#39; connector.json|sponge connector.json\r\ncat connector.json\r\n```\r\n\r\nI am getting this exception:\r\n&gt; jq: error: TOKEN/0 is not defined at &lt;top-level&gt;, line 1:\r\n\r\nPlease help.",
        "link": "https://stackoverflow.com/questions/63523379/jq-error-token-0-is-not-defined-at-top-level-line-1",
        "title": "jq: error: TOKEN/0 is not defined at &lt;top-level&gt;, line 1:"
    },
    {
        "tags": [
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598023116,
                "post_id": 63525523,
                "comment_id": 112332082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598023386,
                "creation_date": 1598023386,
                "answer_id": 63525642,
                "question_id": 63525523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work -\r\n\r\n`cat test.json | jq &#39;.&quot;auth-server-url&quot;&#39;`",
                "title": "Scores in json key make jq fail"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1598023554,
                "creation_date": 1598023554,
                "answer_id": 63525682,
                "question_id": 63525523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid the use of cat, and catch [special characters](https://github.com/stedolan/jq/issues/140) use;\r\n```\r\njq &#39;.[&quot;auth-server-url&quot;]&#39; &lt; test.json\r\n```",
                "title": "Scores in json key make jq fail"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1598038900,
        "creation_date": 1598022921,
        "last_edit_date": 1598038900,
        "question_id": 63525523,
        "body_markdown": "Having this file, \r\n\r\n    $ cat test.json\r\n    {\r\n      &quot;realm&quot;: &quot;somerealm&quot;,\r\n      &quot;auth-server-url&quot;: &quot;http://someserver:8080/auth/&quot;\r\n    }\r\n\r\nHow can I get the &quot;auth-server-url&quot; value? This three queries give the same result:\r\n\r\n    $ cat test.json|jq .&quot;auth-server-url&quot;\r\n   \r\n    jq: error: auth/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[auth-server-url]  \r\n    jq: error: server/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[auth-server-url]       \r\n    jq: error: url/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[auth-server-url]              \r\n    jq: 2 compile errors\r\n\r\n    $ cat test.json|jq .auth-server-url\r\n    (similar)\r\n\r\n    $ cat test.json|jq .[&quot;auth-server-url&quot;]\r\n    (similar)\r\n\r\nPlease don&#39;t tell me to modify the JSON file, it is generated by a known app, Keycloak; I&#39;m using today&#39;s jq-1.6 linux binary; the first value goes fine, apparently the error is due to the scores. Thanks!",
        "link": "https://stackoverflow.com/questions/63525523/scores-in-json-key-make-jq-fail",
        "title": "Scores in json key make jq fail"
    },
    {
        "tags": [
            "json",
            "bash",
            "select",
            "jq",
            "processing-efficiency"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598127503,
                "post_id": 63540687,
                "comment_id": 112358740,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598128275,
                "post_id": 63540687,
                "comment_id": 112358902,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598128356,
                "post_id": 63540687,
                "comment_id": 112358924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598128663,
                "post_id": 63540687,
                "comment_id": 112359006,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598129705,
                "post_id": 63540687,
                "comment_id": 112359269,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598129019,
                "last_edit_date": 1598129019,
                "creation_date": 1598128668,
                "answer_id": 63540899,
                "question_id": 63540687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Calling `jq` once per id is always going to be slow. Don&#39;t do that -- call jq just once, and have it match against the full set.\r\n\r\nYou can accomplish that by passing the entire comma-separated list of ids into your one copy of jq, and letting jq itself do the work of splitting that string into individual items (and then putting them in a dictionary for fast access)\r\n\r\nFor example:\r\n\r\n```\r\npid=&quot;24885,73648,38758,8377,747&quot;\r\njq --arg pidListStr &quot;$pid&quot; &#39;\r\n  ($pidListStr | [split(&quot;,&quot;)[] | {(.): true}] | add) as $pidDict |\r\n  .page[] | select($pidDict[.id | tostring]) | .url\r\n&#39; &lt;&lt;&lt;&quot;$pagejson&quot;\r\n```",
                "title": "Select lots of known IDs from a big JSON document efficiently"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598129352,
                "last_edit_date": 1598129352,
                "creation_date": 1598128793,
                "answer_id": 63540916,
                "question_id": 63540687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a response to the original question, which posited:\r\n\r\n    pid=&quot;24885,73648,38758,8377,747&quot;\r\n    echo $pagejson|jq -r &#39;.page[]|select(.id==&#39;$pid&#39;)|.url&#39;\r\n\r\n(Based on subsequent edits to the question, it would appear that the intent was to iterate over the id values separately, invoking jq once per value.  That is a bad idea as well but can be dealt with in a separate response.)\r\n\r\n### Response to original question\r\n\r\nThere are several problems with the invocation of jq based on\r\ninterpolating `$pid` as was originally done.  \r\n\r\nThe major problem is that your query, when expanded, includes this `select` statement:\r\n\r\n    select(.id==24885,73648,38758,8377,747)\r\n\r\nwhereas what you evidently intend is:\r\n\r\n    select(.id==(24885,73648,38758,8377,747))\r\n\r\nIt&#39;s not difficult to see that there&#39;s a huge difference, which affects both functionality and performance.\r\n\r\nSince you don&#39;t give any hints about the expected input, it&#39;s not feasible to suggest how the query might be optimized.  To illustrate, though, suppose it&#39;s known that the .id values in the input are distinct. Then once all the ids in the query have been found, execution can stop.\r\n\r\nIn general, passing shell variables in by string interpolation is not a great idea.  Some alternatives to consider are using `--arg` or `--argjson`.\r\n\r\n\r\n",
                "title": "Select lots of known IDs from a big JSON document efficiently"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598223438,
                "last_edit_date": 1598223438,
                "creation_date": 1598158388,
                "answer_id": 63543522,
                "question_id": 63540687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution uses the same approach as the one posted by Charles Duffy (*) but is only applicable:\r\n\r\n* if each of the specified id values in $pid appears at most once as an id in the JSON objects in the .page array; or\r\n\r\n* if the goal is to extract, for each id in $pid, at most one corresponding object from the .page array.\r\n\r\nThe idea is to remove an id from the dictionary once it is found, and to stop if and when all ids have been found.\r\n\r\n```\r\n  jq --arg pidListStr &quot;$pid&quot; &#39;\r\n    ($pidListStr | [splits(&quot; *, *&quot;) | {(.): true}] | add) as $pidDict\r\n    | label $finish\r\n    | foreach .page[] as $page ($pidDict + {emit:null};\r\n        if length == 1 then break $finish\r\n        else ($page.id | tostring) as $id\r\n        | if .[$id] then delpaths([[$id]]) | .emit = $page.url \r\n          else .emit = null\r\n          end\r\n        end;\r\n        .emit // empty )\r\n&#39;\r\n```\r\n\r\n---\r\n### (*) Caveat\r\nUsing $pidDict here assumes there are no &quot;collisions&quot;; this condition would hold if all the id values in the .page objects are numeric.\r\n\r\n",
                "title": "Select lots of known IDs from a big JSON document efficiently"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598213434,
                "creation_date": 1598213434,
                "answer_id": 63551541,
                "question_id": 63540687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution, which is based on the one posted by Charles\r\nDuffy (*), can be used if each of the specified id values in $pid\r\nappears at most once as an id in the JSON objects in the .page array.\r\n\r\nThe idea is to stop if and when all the $pid ids have been found.\r\nThis can be accomplished with the following helper function:\r\n```\r\n  def first_n(stream; $n):\r\n    label $done\r\n    | foreach stream as $x (-1; .+1; if . &gt;= $n then break $done else $x end);\r\n```\r\nThe solution can then be written as follows:\r\n```\r\n  ($pidListStr | [splits(&quot; *, *&quot;) | {(.): true}] | add) as $pidDict\r\n  | ($pidDict|length) as $n\r\n  | first_n(.page[] | select($pidDict[.id | tostring]) | .url; $n)\r\n```\r\n\r\nThis solution is similar to the one using `foreach` posted elsewhere\r\non this page, but is simpler and probably slightly more efficient as\r\nthe dictionary, once constructed, is unaltered.\r\n\r\nThe solution using `foreach`, however, can also be used if the ids of the\r\nobjects in the .page array are not unique, and if the goal is to\r\nextract, for each id in $pid, at most one corresponding object from\r\nthe .page array.\r\n\r\n----\r\n\r\n### (*) Caveat\r\nUsing $pidDict here assumes there are no &quot;collisions&quot;; this condition would hold if all the id values in the .page objects are numeric.",
                "title": "Select lots of known IDs from a big JSON document efficiently"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1598223438,
        "creation_date": 1598127131,
        "last_edit_date": 1598171217,
        "question_id": 63540687,
        "body_markdown": "I am trying to get some value from json via jq in bash. With small value it work nice but with big json it work too slow, like 1 value for each 2-3 second. Example of my code: \r\n```\r\njson=$(curl -s -A &quot;some useragent&quot;  &quot;url&quot; )\r\npid=$(cat idlist.json |  jq &#39;.page_ids[]&#39;)\r\nfor id in $pid\r\ndo\r\necho $pagejson|jq -r &#39;.page[]|select(.id==&#39;$id&#39;)|.url&#39;&gt;&gt;path.url\r\ndone\r\n```\r\nThe &quot;pid&quot; is list of id that I type before running script. It may contain 700-1000 id. Example object of json\r\n```\r\n{\r\n&quot;page&quot;:[\r\n{\r\n&quot;url&quot;:&quot;some url&quot;,\r\n&quot;id&quot;:some numbers\r\n},\r\n{\r\n\r\n&quot;url&quot;:&quot;some url&quot;,\r\n&quot;id&quot;:some numbers\r\n}\r\n]\r\n}\r\n```\r\nIs there any way to speed up it? In javascript it work faster than it. Example of javascript:\r\n```\r\n//First sort object with order\r\nvar url=&quot;&quot;;\r\nvar sortedjson= ids.map(id =&gt; obj.find(page =&gt; page.id === id));\r\n//Then collect url\r\nfor ( x=0 ; x &lt; sortedjson.length;x++) {\r\nurl+=sortedjson[x].url\r\n};\r\n```\r\nShould I sort json like in javascript for better performance? I don&#39;t tried it because don&#39;t know how.\r\n\r\nEdit:\r\nReplaced &quot;pid&quot; variable with json to use less code and `for id in $(echo $pid)` with `for id in $pid`.\r\nBut it still slow down if id list more than about 50\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63540687/select-lots-of-known-ids-from-a-big-json-document-efficiently",
        "title": "Select lots of known IDs from a big JSON document efficiently"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598230926,
                "creation_date": 1598230926,
                "answer_id": 63553451,
                "question_id": 63553334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "        // say, this is your json\r\n        var json = &quot;{\\&quot;pools\\&quot;:[{\\&quot;id\\&quot;:\\&quot;403add1f-25d9-4a24-99ff-12c5559fecfa\\&quot;,\\&quot;loadbalancers\\&quot;:[{\\&quot;id\\&quot;:\\&quot;79970c9a-b0ba-4cde-a7e6-16b61641a7b8\\&quot;},{\\&quot;id\\&quot;:\\&quot;ranj-b0ba-4cde-a7e6-16b61641a7b8\\&quot;}]}],\\&quot;pools_links\\&quot;:[]}&quot;;\r\n        \r\n        var obj = JSON.parse(json),\r\n            resultArr = [];\r\n        \r\n        obj.pools.forEach(function(pool){\r\n            var id = pool.id,\r\n                balancers = [];\r\n            \r\n            pool.loadbalancers.forEach(function(loadbalancer){\r\n                balancers.push(loadbalancer.id);\r\n            });\r\n            \r\n            var result = id+&#39;#&#39;+balancers.join(&#39;,&#39;);\r\n            resultArr.push(result);\r\n        });\r\n        \r\n        var joinResultsBy = &#39;&#39;, // indicate any character to join the results by, if necessary\r\n            finalResult = resultArr.join(joinResultsBy);\r\n        \r\n        console.log(finalResult);",
                "title": "jq concat elements into 1 line"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598234029,
                "last_edit_date": 1598234029,
                "creation_date": 1598230984,
                "answer_id": 63553456,
                "question_id": 63553334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n\r\n```\r\njq -r &#39;.pools[] | .id + &quot;#&quot; + ( [.loadbalancers[].id] | join(&quot;,&quot;))&#39;\r\n```\r\n\r\nFor each item in `pools` it extracts the `id` field, and joins all the `loadbalancers[].id` fields.",
                "title": "jq concat elements into 1 line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1598234029,
        "creation_date": 1598229455,
        "question_id": 63553334,
        "body_markdown": "I got below JSON example content. \r\n\r\n    {\r\n       &quot;pools&quot;:[\r\n          {\r\n             &quot;id&quot;:&quot;403add1f-25d9-4a24-99ff-12c5559fecfa&quot;,\r\n             &quot;loadbalancers&quot;:[\r\n                {\r\n                   &quot;id&quot;:&quot;79970c9a-b0ba-4cde-a7e6-16b61641a7b8&quot;\r\n                },\r\n                {\r\n                   &quot;id&quot;:&quot;ranj-b0ba-4cde-a7e6-16b61641a7b8&quot;\r\n                }\r\n             ]\r\n          }\r\n       ],\r\n       &quot;pools_links&quot;:[\r\n          \r\n       ]\r\n    }\r\n\r\nI would like to have content as below\r\n\r\n    403add1f-25d9-4a24-99ff-12c5559fecfa#79970c9a-b0ba-4cde-a7e6-16b61641a7b8,ranj-b0ba-4cde-a7e6-16b61641a7b8\r\n\r\n\r\nI have tried to use below, however, I want to concatenate the id into 1 line instead of having 2 lines.\r\n\r\n    .pools[] | &quot;\\(.id),\\(.loadbalancers[] | .id)&quot;\r\n\r\n\r\nCan anyone help me?",
        "link": "https://stackoverflow.com/questions/63553334/jq-concat-elements-into-1-line",
        "title": "jq concat elements into 1 line"
    },
    {
        "tags": [
            "json",
            "shell",
            "variables",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598254061,
                "post_id": 63556272,
                "comment_id": 112386695,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1598255071,
                "post_id": 63556272,
                "comment_id": 112387151,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1598254177,
                "creation_date": 1598254177,
                "answer_id": 63556509,
                "question_id": 63556272,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split up the path into two parts:\r\n\r\n```\r\n$ jq --arg keyvar &quot;$var&quot; &#39;.servers | .[$keyvar].monitoredServerHealth.healthState&#39; input.json\r\n&quot;ALIVE&quot;\r\n```\r\n\r\nFrom the documentation:\r\n\r\n&gt;A filter of the form .foo.bar is equivalent to .foo|.bar.\r\n\r\nI don&#39;t know why it doesn&#39;t work combined as `.servers.[$keyvar]`; might be a parser bug or something. At least the workaround is trivial.\r\n\r\n---\r\n\r\nAnother way uses string interpolation:\r\n\r\n```\r\njq --arg keyvar &quot;$var&quot; &#39;.servers.&quot;\\($keyvar)&quot;.monitoredServerHealth.healthState&#39; input.json\r\n```",
                "title": "Pass nested json key to jq from bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1598254177,
        "creation_date": 1598253116,
        "last_edit_date": 1598253320,
        "question_id": 63556272,
        "body_markdown": "I&#39;m trying to parse some json with jq that looks like this:\r\n\r\n```\r\n{\r\n    &quot;currentServerId&quot;: 1,\r\n    &quot;isCurrentServerAvailable&quot;: true,\r\n    &quot;isClusterOwner&quot;: false,\r\n    &quot;clusterOwnerServerId&quot;: &quot;2&quot;,\r\n    &quot;numInvalidEventMessages&quot;: &quot;0&quot;,\r\n    &quot;numInvalidoperationalStateMessages&quot;: &quot;0&quot;,\r\n    &quot;servers&quot;: {\r\n        &quot;1&quot;: {\r\n            &quot;isAvailableViaServerObjective&quot;: true,\r\n            &quot;eventMessagesPendingInDb&quot;: &quot;0&quot;,\r\n            &quot;neo4jClusterRole&quot;: &quot;slave&quot;,\r\n            &quot;monitoredServerHealth&quot;: null\r\n        },\r\n        &quot;2&quot;: {\r\n            &quot;isAvailableViaServerObjective&quot;: true,\r\n            &quot;eventMessagesPendingInDb&quot;: &quot;0&quot;,\r\n            &quot;neo4jClusterRole&quot;: &quot;master&quot;,\r\n            &quot;monitoredServerHealth&quot;: {\r\n                &quot;serverId&quot;: 2,\r\n                &quot;healthState&quot;: &quot;ALIVE&quot;,\r\n                &quot;healthCount&quot;: 1,\r\n                &quot;serverIdAsString&quot;: &quot;2&quot;,\r\n                &quot;serverUid&quot;: &quot;*&quot;\r\n            }\r\n        },\r\n        &quot;3&quot;: {\r\n            &quot;isAvailableViaServerObjective&quot;: true,\r\n            &quot;eventMessagesPendingInDb&quot;: &quot;0&quot;,\r\n            &quot;neo4jClusterRole&quot;: &quot;slave&quot;,\r\n            &quot;monitoredServerHealth&quot;: null\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI can obtain the value I need with a filter like this:\r\n\r\n```\r\n # cat test.json | jq .&#39;servers.&quot;2&quot;.monitoredServerHealth.healthState&#39;\r\n&quot;ALIVE&quot;\r\n```\r\n\r\nIf I pass in a single variable as a key it works:\r\n\r\n```\r\n# echo $var \r\nservers\r\n\r\n# cat json.tst | jq --arg keyvar &quot;$var&quot; &#39;.[$keyvar]&#39;\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;isAvailableViaServerObjective&quot;: true,\r\n    &quot;eventMessagesPendingInDb&quot;: &quot;0&quot;,\r\n    &quot;neo4jClusterRole&quot;: &quot;slave&quot;,\r\n    &quot;monitoredServerHealth&quot;: null\r\n  },\r\n&lt;omitted the rest for brevity&gt;\r\n```\r\n\r\nWhen I try to do the same for a nested block (where one level of the key is from a variable), it fails. I&#39;ve tried a number of variations but they all fail.\r\n\r\nWhat is the correct syntax?\r\n\r\n```\r\n# echo $var\r\n&quot;2&quot;\r\n\r\n# cat test.json | jq --arg keyvar &quot;$var&quot; &#39;.servers.$[keyvar].monitoredServerHealth.healthState&#39;\r\njq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.servers.$[keyvar].monitoredServerHealth.healthState         \r\njq: 1 compile error\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63556272/pass-nested-json-key-to-jq-from-bash-variable",
        "title": "Pass nested json key to jq from bash variable"
    },
    {
        "tags": [
            "json",
            "jq",
            "gpsd"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10314095,
                    "reputation": 108,
                    "user_id": 8057381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3dW79.png?s=256",
                    "display_name": "TobiV",
                    "link": "https://stackoverflow.com/users/8057381/tobiv"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598254197,
                "post_id": 63556425,
                "comment_id": 112386745,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598254376,
                "creation_date": 1598254376,
                "answer_id": 63556552,
                "question_id": 63556425,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the presented input:\r\n\r\n    $ jq -r &#39;.sky[].satellites | ( [ .[] | select(.used == true) ] | length ), length&#39;\r\n    9\r\n    12\r\n\r\nOr maybe (but you could also pipe it to `paste -sd&quot; &quot;`):\r\n\r\n    $ jq -r &#39;.sky[].satellites | ( [ .[] | select(.used == true) ] | length | tostring) + &quot; &quot; + (length|tostring)&#39;\r\n    9 12",
                "title": "Using jq to count number of satellites used and in view from gpsd output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598255329,
        "creation_date": 1598253764,
        "last_edit_date": 1598255329,
        "question_id": 63556425,
        "body_markdown": "Consider this JSON:\r\n\r\n    {&quot;class&quot;:&quot;POLL&quot;,&quot;time&quot;:&quot;2020-08-24T07:01:31.690Z&quot;,&quot;active&quot;:1,&quot;tpv&quot;:[{&quot;class&quot;:&quot;TPV&quot;,&quot;tag&quot;:&quot;ID8fac&quot;,&quot;device&quot;:&quot;/dev/ttyM1&quot;,&quot;mode&quot;:3,&quot;time&quot;:&quot;2020-08-24T07:01:31.000Z&quot;,&quot;ept&quot;:0.005,&quot;lat&quot;:-37.043028622,&quot;lon&quot;:145.984996786,&quot;alt&quot;:708.492,&quot;epx&quot;:9.963,&quot;epy&quot;:14.642,&quot;epv&quot;:0.000,&quot;speed&quot;:0.000,&quot;climb&quot;:0.000,&quot;eps&quot;:29.28}],&quot;gst&quot;:[{&quot;class&quot;:&quot;GST&quot;,&quot;tag&quot;:&quot;ID8fac&quot;,&quot;device&quot;:&quot;/dev/ttyM1&quot;,&quot;time&quot;:&quot;1970-01-01T00:00:00.000Z&quot;,&quot;rms&quot;:0.000,&quot;major&quot;:0.000,&quot;minor&quot;:0.000,&quot;orient&quot;:0.000,&quot;lat&quot;:0.000,&quot;lon&quot;:0.000,&quot;alt&quot;:0.000}],&quot;sky&quot;:[{&quot;class&quot;:&quot;SKY&quot;,&quot;tag&quot;:&quot;ID8fac&quot;,&quot;device&quot;:&quot;/dev/ttyM1&quot;,&quot;xdop&quot;:0.66,&quot;ydop&quot;:0.98,&quot;vdop&quot;:0.00,&quot;tdop&quot;:1.00,&quot;hdop&quot;:0.00,&quot;gdop&quot;:1.00,&quot;pdop&quot;:0.00,&quot;satellites&quot;:[{&quot;PRN&quot;:17,&quot;el&quot;:42,&quot;az&quot;:137,&quot;ss&quot;:43,&quot;used&quot;:true},{&quot;PRN&quot;:12,&quot;el&quot;:27,&quot;az&quot;:241,&quot;ss&quot;:44,&quot;used&quot;:true},{&quot;PRN&quot;:24,&quot;el&quot;:53,&quot;az&quot;:247,&quot;ss&quot;:46,&quot;used&quot;:true},{&quot;PRN&quot;:6,&quot;el&quot;:55,&quot;az&quot;:54,&quot;ss&quot;:36,&quot;used&quot;:true},{&quot;PRN&quot;:15,&quot;el&quot;:10,&quot;az&quot;:307,&quot;ss&quot;:40,&quot;used&quot;:true},{&quot;PRN&quot;:2,&quot;el&quot;:31,&quot;az&quot;:358,&quot;ss&quot;:37,&quot;used&quot;:true},{&quot;PRN&quot;:28,&quot;el&quot;:20,&quot;az&quot;:89,&quot;ss&quot;:35,&quot;used&quot;:true},{&quot;PRN&quot;:7,&quot;el&quot;:10,&quot;az&quot;:52,&quot;ss&quot;:31,&quot;used&quot;:false},{&quot;PRN&quot;:19,&quot;el&quot;:64,&quot;az&quot;:148,&quot;ss&quot;:45,&quot;used&quot;:true},{&quot;PRN&quot;:13,&quot;el&quot;:10,&quot;az&quot;:338,&quot;ss&quot;:29,&quot;used&quot;:false},{&quot;PRN&quot;:15,&quot;el&quot;:18,&quot;az&quot;:297,&quot;ss&quot;:33,&quot;used&quot;:true},{&quot;PRN&quot;:22,&quot;el&quot;:10,&quot;az&quot;:17,&quot;ss&quot;:39,&quot;used&quot;:false}]}]}\r\n\r\nI&#39;m interested in parsing the satellites array in the above JSON (extracted below) and returning two numbers: The number of satellites, and the number of satellites used. For example: `7 12`\r\n\r\n    [\r\n      {\r\n        &quot;PRN&quot;: 17,\r\n        &quot;el&quot;: 42,\r\n        &quot;az&quot;: 137,\r\n        &quot;ss&quot;: 43,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 12,\r\n        &quot;el&quot;: 27,\r\n        &quot;az&quot;: 241,\r\n        &quot;ss&quot;: 44,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 24,\r\n        &quot;el&quot;: 53,\r\n        &quot;az&quot;: 247,\r\n        &quot;ss&quot;: 46,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 6,\r\n        &quot;el&quot;: 55,\r\n        &quot;az&quot;: 54,\r\n        &quot;ss&quot;: 36,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 15,\r\n        &quot;el&quot;: 10,\r\n        &quot;az&quot;: 307,\r\n        &quot;ss&quot;: 40,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 2,\r\n        &quot;el&quot;: 31,\r\n        &quot;az&quot;: 358,\r\n        &quot;ss&quot;: 37,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 28,\r\n        &quot;el&quot;: 20,\r\n        &quot;az&quot;: 89,\r\n        &quot;ss&quot;: 35,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 7,\r\n        &quot;el&quot;: 10,\r\n        &quot;az&quot;: 52,\r\n        &quot;ss&quot;: 31,\r\n        &quot;used&quot;: false\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 19,\r\n        &quot;el&quot;: 64,\r\n        &quot;az&quot;: 148,\r\n        &quot;ss&quot;: 45,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 13,\r\n        &quot;el&quot;: 10,\r\n        &quot;az&quot;: 338,\r\n        &quot;ss&quot;: 29,\r\n        &quot;used&quot;: false\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 15,\r\n        &quot;el&quot;: 18,\r\n        &quot;az&quot;: 297,\r\n        &quot;ss&quot;: 33,\r\n        &quot;used&quot;: true\r\n      },\r\n      {\r\n        &quot;PRN&quot;: 22,\r\n        &quot;el&quot;: 10,\r\n        &quot;az&quot;: 17,\r\n        &quot;ss&quot;: 39,\r\n        &quot;used&quot;: false\r\n      }\r\n    ]\r\n\r\n\r\nCurrently I&#39;ve only been able to figure out how to parse one value not both in one go; this is what I have:\r\n\r\n    jq -r &#39;[ .sky[] | .satellites[]| select(.used == true )| &quot;\\( .PRN )&quot; ] |length&#39;\r\n\r\nWhich outputs the number of satellites used, e.g., 7.\r\n\r\n\r\n\r\nFor the sake of completeness and on the off chance it might help someone, I&#39;m polling gpsd in bash as follows. This returns a JSON structure as seen at the start of this post:\r\n\r\n    timeout 1 grep -m1 satellites &lt; &lt;(printf &#39;%s\\n&#39; &#39;?WATCH={&quot;enable&quot;:true,&quot;json&quot;:true};?POLL;&#39; | nc 127.0.0.1 2947) \r\n",
        "link": "https://stackoverflow.com/questions/63556425/using-jq-to-count-number-of-satellites-used-and-in-view-from-gpsd-output",
        "title": "Using jq to count number of satellites used and in view from gpsd output"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598261049,
                "last_edit_date": 1598261049,
                "creation_date": 1598257007,
                "answer_id": 63557169,
                "question_id": 63556984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can select the key `categoryId` for each object in the array by applying the selector: `curl -s https://api.scalablepress.com/v2/categories | jq &#39;map(.categoryId)&#39;`\r\n\r\nThis will give you a JSON array with only the values you&#39;re interested in. Then you can use the antislurp filter `.[]` to turn the array into individual results. `jq` can then output raw strings with the `-r` switch. \r\n\r\nCombining everything, you can achieve what you&#39;re looking for with a one-liner:\r\n\r\n`curl -s https://api.scalablepress.com/v2/categories | jq -r &#39;map(.categoryId) | .[]&#39;`\r\n\r\nEven better, you can antislurp first, and then select the key you&#39;re looking for: `curl -s https://api.scalablepress.com/v2/categories | jq -r &#39;.[] | .categoryId&#39;`",
                "title": "jq - Parsing fields with hyphen - Invalid Numeric Literal"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598258210,
                "creation_date": 1598258210,
                "answer_id": 63557456,
                "question_id": 63556984,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "you can loop over categories ids right away, without doing all the &quot;echos&quot; that break the json. the two loops can be rewritten as:\r\n\r\n    #!/bin/bash\r\n    \r\n    CATURL=&quot;https://api.scalablepress.com/v2/categories&quot;\r\n    \r\n    curl -s &quot;$CATURL&quot; | jq -rc &#39;.[] | .categoryId&#39; | while read catid; do\r\n            echo &quot;$catid&quot;\r\n            curl -s &quot;$CATURL/$catid&quot; | jq -rc &#39;.products[].id&#39;\r\n    done\r\n\r\nthis will print category id followed by all products ids which from you code seems like your end result:\r\n\r\n    $ ./pullcat.sh\r\n    aprons\r\n    port-authority-port-authority-&#226;-medium-length-apron-with-pouch-pockets\r\n    port-authority-port-authority-&#226;-full-length-apron-with-pockets\r\n    port-authority-easy-care-reversible-waist-apron-with-stain-release\r\n    port-authority-easy-care-waist-apron-with-stain-release\r\n    backpacks\r\n    port-authority-&#226;-wheeled-backpack\r\n    nike-performance-backpack\r\n    port-authority-&#226;-value-backpack\r\n    port-authority-&#226;-basic-backpack\r\n    port-authority-&#226;-cyber-backpack\r\n    port-authority-&#226;-commuter-backpack\r\n    port-authority-&#226;-contrast-honeycomb-backpack\r\n    port-authority-&#226;-camo-xtreme-backpack\r\n    port-authority-&#226;-xtreme-backpack\r\n    port-authority-&#226;-xcape&#226;-computer-backpack\r\n    port-authority-&#226;-nailhead-backpack\r\n    nike-elite-backpack\r\n    port-authority-&#226;-urban-backpack\r\n    eddie-bauer-eddie-bauer-&#226;-ripstop-backpack\r\n    the-north-face-aurora-ii-backpack\r\n    the-north-face-fall-line-backpack\r\n    the-north-face-groundwork-backpack\r\n    the-north-face-connector-backpack\r\n    beanies\r\n    rabbit-skins-infant-baby-rib-cap\r\n    yupoong-adult-cuffed-knit-cap\r\n    ultra-club-adult-knit-beanie-with-cuff\r\n    ultra-club-adult-knit-beanie\r\n    ultra-club-adult-two-tone-knit-beanie\r\n    ultra-club-adult-knit-beanie-with-lid\r\n    ultra-club-adult-waffle-beanie\r\n    ultra-club-adult-knit-pom-pom-beanie-with-cuff\r\n    bayside-beanie\r\n    ...\r\n\r\nif you want just the categories ids, you can of course &quot;drop&quot; while loop:\r\n\r\n    #!/bin/bash\r\n    \r\n    CATURL=&quot;https://api.scalablepress.com/v2/categories&quot;\r\n    \r\n    curl -s &quot;$CATURL&quot; | jq -rc &#39;.[] | .categoryId&#39;\r\n\r\n---\r\n\r\n    $ ./pullcat.sh\r\n    aprons\r\n    backpacks\r\n    beanies\r\n    bracelet\r\n    coaster\r\n    cutting-board\r\n    dress-shirts\r\n    duffel-bags\r\n    earring\r\n    full-brim-hats\r\n    generic-dropoff\r\n    hats\r\n    hoodies\r\n    infant-shirts\r\n    ladies-dress-shirts\r\n    ladies-dresses\r\n    ladies-long-sleeve\r\n    ladies-pants\r\n    ladies-performance-shirts\r\n    ladies-polos\r\n    ladies-short-sleeve\r\n    ladies-tank-tops\r\n    large-bags\r\n    ...",
                "title": "jq - Parsing fields with hyphen - Invalid Numeric Literal"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1598261049,
        "creation_date": 1598256184,
        "last_edit_date": 1598259027,
        "question_id": 63556984,
        "body_markdown": "I&#39;m trying to pull a list of product categories from an API using jq and some nested for-loops. I have to pull the category ID first, then I&#39;m able to pull product details. Some of the category IDs have hypens and jq seems to be treating them like math instead of a string, and I&#39;ve tried every manner of quoting but I&#39;m still running into this error. In Powershell, I&#39;m able to pull the list just fine, but I really need this to work in bash.\r\n\r\nHere&#39;s the expected list:\r\n\r\n    aprons\r\n    backpacks\r\n    beanies\r\n    bracelet\r\n    coaster\r\n    cutting-board\r\n    dress-shirts\r\n    duffel-bags\r\n    earring\r\n    full-brim-hats\r\n    generic-dropoff\r\n    hats\r\n    etc...\r\n\r\nAnd trying to recreate the same script in Bash, here&#39;s the output:\r\n\r\n    aprons\r\n    backpacks\r\n    beanies\r\n    bracelet\r\n    coaster\r\n    parse error: Invalid numeric literal at line 1, column 6\r\n    parse error: Invalid numeric literal at line 1, column 7\r\n    parse error: Invalid numeric literal at line 1, column 5\r\n    earring\r\n    parse error: Invalid numeric literal at line 2, column 0\r\n    parse error: Invalid numeric literal at line 1, column 5\r\n    parse error: Invalid numeric literal at line 1, column 8\r\n    hats\r\n    etc...\r\n\r\nYou can see that it&#39;s running into this error with all values that contain hyphens. Here&#39;s my current script:\r\n\r\n    #!/bin/bash\r\n\r\n    CATEGORIES=$(curl -s https://api.scalablepress.com/v2/categories)\r\n    IFS=$&#39; \\t\\n&#39;\r\n\r\n\r\n    for CATEGORY in $(echo $CATEGORIES | jq -rc &#39;.[]&#39;)\r\n    do\r\n    CATEGORY_IDS=$(echo $CATEGORY | jq -rc &#39;.&quot;categoryId&quot;&#39;)\r\n    for CATEGORY_ID in $(echo $CATEGORY_IDS)\r\n    do\r\n    echo $CATEGORY_ID\r\n    PRODUCT_IDS=$(curl -s https://api.scalablepress.com/v2/categories/$CATEGORY_ID | jq -rc &#39;.products[].id&#39;)\r\n    #for PRODUCT_ID in $(echo $PRODUCT_IDS)\r\n    #do\r\n    #echo $PRODUCT_ID\r\n    #done\r\n    done\r\n    done\r\n\r\nThis is a publicly available API so you should be able to copy this script and produce the same results. All of the guides I&#39;ve seen have said to put double quotes around the field you&#39;re trying to parse if it contains hyphens, but I&#39;m having no luck trying that.",
        "link": "https://stackoverflow.com/questions/63556984/jq-parsing-fields-with-hyphen-invalid-numeric-literal",
        "title": "jq - Parsing fields with hyphen - Invalid Numeric Literal"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598274778,
                "post_id": 63561477,
                "comment_id": 112396589,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598274812,
                "post_id": 63561477,
                "comment_id": 112396613,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598275074,
                "post_id": 63561477,
                "comment_id": 112396749,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598276256,
                "post_id": 63561477,
                "comment_id": 112397402,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598276927,
                "post_id": 63561477,
                "comment_id": 112397783,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598296853,
                "last_edit_date": 1598296853,
                "creation_date": 1598275371,
                "answer_id": 63561932,
                "question_id": 63561477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `CidrIP` is not present for `udp` record. If you want to alternate between `.GroupId` and `CidrIp`, you can do an alternation like\r\n\r\n    .SecurityGroups[].IpPermissions[] |\r\n    .FromPort as $port          |\r\n    .IpProtocol as $prot        |\r\n    .IpRanges as $ip            |\r\n    .UserIdGroupPairs as $group |\r\n    [\r\n      ($port|tostring),\r\n      ($prot),\r\n      (select($ip|length) | $ip[].CidrIp) //\r\n      (select($group|length) | $group[].GroupId) //\r\n      empty\r\n    ] |\r\n    @tsv\r\n\r\nproduces an output like you wanted\r\n\r\n    161\tudp\tsg-22e04e44\r\n    22\ttcp\t0.0.0.0/0\r\n    -1\ticmp\t0.0.0.0/0\r\n\r\nYou can use the `--raw-output/-r` mode along with any of `@csv`, `@tsv` or `join(&quot; &quot;)` to represent the output in a tabular form.\r\n\r\n[&lt;sup&gt;jqplay - Online demo&lt;/sup&gt;](https://jqplay.org/s/Gk2ARJuOA1)",
                "title": "jq: How to display a value only if its key exists?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598323439,
        "creation_date": 1598273637,
        "last_edit_date": 1598323439,
        "question_id": 63561477,
        "body_markdown": "I have the following json:\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;SG for ssh-proxy server&quot;,\r\n                &quot;GroupName&quot;: &quot;ssh-proxy-SG&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;FromPort&quot;: 161,\r\n                        &quot;IpProtocol&quot;: &quot;udp&quot;,\r\n                        &quot;IpRanges&quot;: [],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;ToPort&quot;: 161,\r\n                        &quot;UserIdGroupPairs&quot;: [\r\n                            {\r\n                                &quot;GroupId&quot;: &quot;sg-22e04e44&quot;,\r\n                                &quot;UserId&quot;: &quot;XXXXXXXXXXXX&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: -1,\r\n                        &quot;IpProtocol&quot;: &quot;icmp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;ToPort&quot;: -1,\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;OwnerId&quot;: &quot;XXXXXXXXXXXX&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-4f1d8a35&quot;,\r\n                &quot;IpPermissionsEgress&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;Name&quot;,\r\n                        &quot;Value&quot;: &quot;ssh-proxy-SG&quot;\r\n                    }\r\n                ],\r\n                &quot;VpcId&quot;: &quot;vpc-d3131fbe&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nUsing `jq`, I&#39;m trying to display such a list:\r\n\r\n    161 tcp sg-22e04e44\r\n    22 tcp 0.0.0.0/0\r\n    -1 icmp 0.0.0.0/0\r\n\r\nI am able to print only the port and the protocol but not the &quot;.IpRanges[].CidrIp&quot;, like so:\r\n\r\n    ✗ aws ec2 describe-security-groups --group-id sg-4f1d8a35 --profile XXXX --region us-east-1 --output json | jq -r &#39;.SecurityGroups[].IpPermissions[] | (.FromPort|tostring) + &quot; &quot; + .IpProtocol&#39;\r\n    161 udp\r\n    22 tcp\r\n    -1 icmp\r\n\r\nThe problem is that sometimes (in this case the 161 udp rule) lacks &quot;.IpRanges[].CidrIp&quot; and it causes an error.\r\n\r\nI tried this:\r\n\r\n    ✗ aws ec2 describe-security-groups --group-id sg-4f1d8a35 --profile XXXXXXX --region us-east-1 --output json | jq -r &#39;.SecurityGroups[].IpPermissions[] | (.FromPort|tostring) + &quot; &quot; + .IpProtocol + &quot; &quot; + .IpRanges[].CidrIp&#39;\r\n    \r\n    22 tcp 0.0.0.0/0\r\n    -1 icmp 0.0.0.0/0\r\n\r\nBut as you can see, the udp line is missing.\r\n\r\nAlso tried this:\r\n\r\n    ✗ aws ec2 describe-security-groups --group-id sg-4f1d8a35 --profile XXXXXXX --region us-east-1 --output json | jq -r &#39;.SecurityGroups[].IpPermissions[] | .IpRanges[]? |= if has(.CidrIp) then (.FromPort|tostring) + &quot; &quot; + .IpProtocol + &quot; &quot; + .IpRanges[].CidrIp else (.FromPort|tostring) + &quot; &quot; + .IpProtocol + &quot; &quot; + .UserIdGroupPairs[].GroupId end&#39;\r\n    \r\n    {\r\n      &quot;FromPort&quot;: 161,\r\n      &quot;IpProtocol&quot;: &quot;udp&quot;,\r\n      &quot;IpRanges&quot;: [],\r\n      &quot;Ipv6Ranges&quot;: [],\r\n      &quot;PrefixListIds&quot;: [],\r\n      &quot;ToPort&quot;: 161,\r\n      &quot;UserIdGroupPairs&quot;: [\r\n        {\r\n          &quot;GroupId&quot;: &quot;sg-22e04e44&quot;,\r\n          &quot;UserId&quot;: &quot;XXXXXXX&quot;\r\n        }\r\n      ]\r\n    }\r\n    jq: error (at &lt;stdin&gt;:72): Cannot iterate over null (null)\r\n\r\nWhat am I doing wrong?",
        "link": "https://stackoverflow.com/questions/63561477/jq-how-to-display-a-value-only-if-its-key-exists",
        "title": "jq: How to display a value only if its key exists?"
    },
    {
        "tags": [
            "json",
            "null",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598279482,
                "post_id": 63562998,
                "comment_id": 112399209,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1598279682,
                "post_id": 63562998,
                "comment_id": 112399320,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1230255,
                    "reputation": 6121,
                    "user_id": 1702942,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/ICkw8.jpg?s=256",
                    "display_name": "Itai Ganot",
                    "link": "https://stackoverflow.com/users/1702942/itai-ganot"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598280140,
                "post_id": 63562998,
                "comment_id": 112399602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598285595,
                "last_edit_date": 1598285595,
                "creation_date": 1598280141,
                "answer_id": 63563271,
                "question_id": 63562998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add a [fallback][1] for the `.FromPort` key:\r\n```\r\n.FromPort // &quot;&quot;\r\n```\r\n\r\nSo the command becomes;\r\n```\r\n.SecurityGroups[].IpPermissions[] | [ (.FromPort // &quot;&quot; ?), .IpProtocol, .IpRanges[].CidrIp ] | @tsv\r\n```\r\nWhich yields to\r\n```\r\n\t-1\t0.0.0.0/0\r\n22\ttcp\t0.0.0.0/0\r\n```\r\n\r\n[Try it online!][2]\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/354\r\n  [2]: https://jqplay.org/s/MnbJvQV6bL",
                "title": "jq: How to substitute &quot;null&quot; from the output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1598320062,
        "creation_date": 1598279119,
        "last_edit_date": 1598320062,
        "question_id": 63562998,
        "body_markdown": "I have the following JSON:\r\n\r\n    {\r\n        &quot;SecurityGroups&quot;: [\r\n            {\r\n                &quot;Description&quot;: &quot;launch-wizard-6 created 2018-10-25T13:59:20.092+03:00&quot;,\r\n                &quot;GroupName&quot;: &quot;launch-wizard-6&quot;,\r\n                &quot;IpPermissions&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    },\r\n                    {\r\n                        &quot;FromPort&quot;: 22,\r\n                        &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;ToPort&quot;: 22,\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;OwnerId&quot;: &quot;XXXXXXXXXXXX&quot;,\r\n                &quot;GroupId&quot;: &quot;sg-054368f50a6b4fea4&quot;,\r\n                &quot;IpPermissionsEgress&quot;: [\r\n                    {\r\n                        &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                        &quot;IpRanges&quot;: [\r\n                            {\r\n                                &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;Ipv6Ranges&quot;: [\r\n                            {\r\n                                &quot;CidrIpv6&quot;: &quot;::/0&quot;\r\n                            }\r\n                        ],\r\n                        &quot;PrefixListIds&quot;: [],\r\n                        &quot;UserIdGroupPairs&quot;: []\r\n                    }\r\n                ],\r\n                &quot;VpcId&quot;: &quot;vpc-6ea82a08&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\nWhen I run the following jq command:\r\n\r\n    aws ec2 describe-security-groups --group-id ${group_id} --profile ${profile} --region ${region} --output json | jq -r &#39;.SecurityGroups[].IpPermissions[] | [ (.FromPort|tostring), .IpProtocol, .IpRanges[].CidrIp // .UserIdGroupPairs[].GroupId // &quot;&quot; ] | @tsv&#39;\r\n\r\nI get the following output:\r\n\r\n    null\t-1\t0.0.0.0/0\r\n    22\ttcp\t0.0.0.0/0\r\n\r\nI&#39;d like to remove the null from the output, how can it be done?",
        "link": "https://stackoverflow.com/questions/63562998/jq-how-to-substitute-null-from-the-output",
        "title": "jq: How to substitute &quot;null&quot; from the output?"
    },
    {
        "tags": [
            "json",
            "iteration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598332232,
                "last_edit_date": 1598332232,
                "creation_date": 1598331800,
                "answer_id": 63572341,
                "question_id": 63572261,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By applying **[]** operator to **files** twice, you&#39;re running into a combinatorial explosion. That needs to be avoided, for example:\r\n```\r\n[ .[] | select(.status == &quot;2&quot;) | {id, name} + (.files[] | select(.status == &quot;2&quot;) | {file_filename: .filename, file_status: .status}) ]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/d9i0Mj33hM)&lt;/sup&gt;",
                "title": "How to avoid generating all combinations of selected data while constructing an object?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1598341037,
        "creation_date": 1598331273,
        "last_edit_date": 1598341037,
        "question_id": 63572261,
        "body_markdown": "My original JSON is given below.\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;name&quot;: &quot;AA_1&quot;,\r\n    &quot;total&quot;: &quot;100002&quot;,\r\n    &quot;files&quot;: [\r\n      {\r\n        &quot;filename&quot;: &quot;8665b987ab48511eda9e458046fbc42e.csv&quot;,\r\n        &quot;filename_original&quot;: &quot;some.csv&quot;,\r\n        &quot;status&quot;: &quot;3&quot;,\r\n        &quot;total&quot;: &quot;100002&quot;,\r\n        &quot;time&quot;: &quot;2020-08-24 23:25:49&quot;\r\n      }\r\n    ],\r\n    &quot;status&quot;: &quot;3&quot;,\r\n    &quot;created&quot;: &quot;2020-08-24 23:25:49&quot;,\r\n    &quot;filenames&quot;: &quot;8665b987ab48511eda9e458046fbc42e.csv&quot;,\r\n    &quot;is_append&quot;: &quot;0&quot;,\r\n    &quot;is_deleted&quot;: &quot;0&quot;,\r\n    &quot;comment&quot;: null\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;,\r\n    &quot;name&quot;: &quot;AA_2&quot;,\r\n    &quot;total&quot;: &quot;43806503&quot;,\r\n    &quot;files&quot;: [\r\n      {\r\n        &quot;filename&quot;: &quot;1b4812fe634938928953dd40db1f70b2.csv&quot;,\r\n        &quot;filename_original&quot;: &quot;other.csv&quot;,\r\n        &quot;status&quot;: &quot;3&quot;,\r\n        &quot;total&quot;: &quot;21903252&quot;,\r\n        &quot;time&quot;: &quot;2020-08-24 23:33:43&quot;\r\n      },\r\n      {\r\n        &quot;filename&quot;: &quot;63ab85fef2412ce80ae8bd018497d8bf.csv&quot;,\r\n        &quot;filename_original&quot;: &quot;some.csv&quot;,\r\n        &quot;status&quot;: &quot;2&quot;,\r\n        &quot;total&quot;: 0,\r\n        &quot;time&quot;: &quot;2020-08-24 23:29:30&quot;\r\n      }\r\n    ],\r\n    &quot;status&quot;: &quot;2&quot;,\r\n    &quot;created&quot;: &quot;2020-08-24 23:35:51&quot;,\r\n    &quot;filenames&quot;: &quot;1b4812fe634938928953dd40db1f70b2.csv&amp;&amp;63ab85fef2412ce80ae8bd018497d8bf.csv&quot;,\r\n    &quot;is_append&quot;: &quot;0&quot;,\r\n    &quot;is_deleted&quot;: &quot;0&quot;,\r\n    &quot;comment&quot;: null\r\n  }\r\n]\r\n```\r\n\r\nFrom this JSON I want to create new objects by combining fields from objects which have **status: 2** and their **files** which also have the same pair, **status: 2**.\r\n\r\nSo, I am expecting a JSON array as below.\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;,\r\n    &quot;name&quot;: &quot;AA_2&quot;,\r\n    &quot;file_filename&quot;: &quot;63ab85fef2412ce80ae8bd018497d8bf.csv&quot;,\r\n    &quot;file_status&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nSo far I tried with this JQ filter:\r\n```\r\n.[]|select(.status==&quot;2&quot;)|[{id:.id,file_filename:.files[].filename,file_status:.files[].status}]\r\n```\r\nBut this produces some invalid data.\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;, # want to remove this as file.status != 2\r\n    &quot;file_filename&quot;: &quot;1b4812fe634938928953dd40db1f70b2.csv&quot;,\r\n    &quot;file_status&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;,\r\n    &quot;file_filename&quot;: &quot;1b4812fe634938928953dd40db1f70b2.csv&quot;,\r\n    &quot;file_status&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;, # Repeat\r\n    &quot;file_filename&quot;: &quot;63ab85fef2412ce80ae8bd018497d8bf.csv&quot;,\r\n    &quot;file_status&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;4&quot;,  # Repeat\r\n    &quot;file_filename&quot;: &quot;63ab85fef2412ce80ae8bd018497d8bf.csv&quot;,\r\n    &quot;file_status&quot;: &quot;2&quot;\r\n  }\r\n]\r\n```\r\nHow do I filter the new JSON using JQ and remove these duplicate objects?",
        "link": "https://stackoverflow.com/questions/63572261/how-to-avoid-generating-all-combinations-of-selected-data-while-constructing-an",
        "title": "How to avoid generating all combinations of selected data while constructing an object?"
    },
    {
        "tags": [
            "json",
            "parent-child",
            "jq",
            "reshape"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1598359765,
                "last_edit_date": 1598359765,
                "creation_date": 1598359362,
                "answer_id": 63579109,
                "question_id": 63578959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Copy all fields except **events** from the root to each *event*, and put resulting objects into an array.\r\n```\r\njq -n &#39;[ inputs | .events[] + del(.events) ]&#39;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/oXAS_oceHs)&lt;/sup&gt;",
                "title": "jq - flatten parent objects into children"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1598360086,
                "creation_date": 1598360086,
                "answer_id": 63579315,
                "question_id": 63578959,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Almost same logic as Oguz&#39;s answer, using `with_entries()` to remove events from root and adding the fields alone\r\n\r\n    jq -n &#39;[ inputs | with_entries(select(.key != &quot;events&quot;)) + (.events[]) ]&#39;\r\n\r\n&lt;sup&gt;[jqplay - Demo][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/ec2DQdrLd2",
                "title": "jq - flatten parent objects into children"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1598425742,
        "creation_date": 1598358840,
        "last_edit_date": 1598425742,
        "question_id": 63578959,
        "body_markdown": "I have the following source JSON which I need to reshape:\r\n\r\n    {\r\n      &quot;group&quot;: &quot;A&quot;,\r\n      &quot;name&quot;: &quot;abc&quot;,\r\n      &quot;events&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;54209&quot;,\r\n          &quot;message&quot;: &quot;foobar 1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;76548&quot;,\r\n          &quot;message&quot;: &quot;foobar 2&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;group&quot;: &quot;B&quot;,\r\n      &quot;name&quot;: &quot;def&quot;,\r\n      &quot;events&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;54593&quot;,\r\n          &quot;message&quot;: &quot;foobar 3&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;20359&quot;,\r\n          &quot;message&quot;: &quot;foobar 4&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nHow can I get to the following output:\r\n\r\n    [\r\n      {\r\n        &quot;group&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;id&quot;: &quot;54209&quot;,\r\n        &quot;message&quot;: &quot;foobar 1&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;A&quot;,\r\n        &quot;name&quot;: &quot;abc&quot;,\r\n        &quot;id&quot;: &quot;76548&quot;,\r\n        &quot;message&quot;: &quot;foobar 2&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;B&quot;,\r\n        &quot;name&quot;: &quot;def&quot;,\r\n        &quot;id&quot;: &quot;54593&quot;,\r\n        &quot;message&quot;: &quot;foobar 3&quot;\r\n      },\r\n      {\r\n        &quot;group&quot;: &quot;B&quot;,\r\n        &quot;name&quot;: &quot;def&quot;,\r\n        &quot;id&quot;: &quot;20359&quot;,\r\n        &quot;message&quot;: &quot;foobar 4&quot;\r\n      }\r\n    ]\r\n\r\nI basically want a single array with all the child event arrays, but with their parent objects embedded into them.\r\nI came very close with an example from this issue: https://github.com/stedolan/jq/issues/646. But I need the keys as well, not just the values.",
        "link": "https://stackoverflow.com/questions/63578959/jq-flatten-parent-objects-into-children",
        "title": "jq - flatten parent objects into children"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598366993,
                "last_edit_date": 1598366993,
                "creation_date": 1598360864,
                "answer_id": 63579537,
                "question_id": 63579320,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Select arrays and apply **.[][]** to only them.\r\n```\r\nselect(type == &quot;array&quot;) .[][]\r\n```\r\nOr, shorter:\r\n```\r\narrays[][]\r\n```",
                "title": "Expand arrays from a stream of JSON values of various types"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598366993,
        "creation_date": 1598360109,
        "last_edit_date": 1598360966,
        "question_id": 63579320,
        "body_markdown": "I am trying to parse to JSON from the variable below:\r\n\r\nWhen I call my variable like this: *echo $IDS | jq*\r\n\r\nI receive:\r\n\r\n    &quot;/redfish/v1/Chassis&quot;\r\n    &quot;/redfish/v1/$metadata#ChassisCollection.ChassisCollection&quot;\r\n    &quot;#ChassisCollection.ChassisCollection&quot;\r\n    &quot;ChassisCollection&quot;\r\n    [\r\n       {\r\n        &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/14&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/9&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/1&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/25&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/5&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/26&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/6&quot;\r\n       },\r\n       {\r\n         &quot;@odata.id&quot;: &quot;/redfish/v1/Chassis/22&quot;\r\n       }\r\n    ]\r\n    28\r\n\r\nWhen I then try to extract all the chassis ID&#39;s I cannot get them without error:\r\n\r\n*IDT=$(echo $IDS | jq &#39;.[][]&#39;)*\r\n\r\nreturns:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;/redfish/v...)\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;/redfish/v...)\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;#ChassisCo...)\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;ChassisCol...)\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over number (28)\r\n\r\neven when I use \r\n\r\n*IDT=$(echo $IDS | jq -R &#39;.[][]&#39;)*\r\n\r\nit returns \r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;\\&quot;/redfish...)\r\n\r\nI do end up with a variable $IDT with exactly what I want in it, but I need to achieve this without getting any errors along the way:\r\n\r\nResult of  *echo $IDT | jq*\r\n\r\n    &quot;/redfish/v1/Chassis/14&quot;\r\n    &quot;/redfish/v1/Chassis/9&quot;\r\n    &quot;/redfish/v1/Chassis/1&quot;\r\n    &quot;/redfish/v1/Chassis/25&quot;\r\n    &quot;/redfish/v1/Chassis/5&quot;\r\n    &quot;/redfish/v1/Chassis/26&quot;\r\n    &quot;/redfish/v1/Chassis/6&quot;\r\n    &quot;/redfish/v1/Chassis/22&quot;\r\n\r\nWho knows how to achieve my goal without getting errors along the way? All help is welcome.",
        "link": "https://stackoverflow.com/questions/63579320/expand-arrays-from-a-stream-of-json-values-of-various-types",
        "title": "Expand arrays from a stream of JSON values of various types"
    },
    {
        "tags": [
            "python",
            "bash",
            "subprocess",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598368594,
                "post_id": 63581946,
                "comment_id": 112433281,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5330688,
                    "reputation": 852,
                    "user_id": 4251301,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/e47755a3aeeb4e434c690ce835e69ce2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jislam",
                    "link": "https://stackoverflow.com/users/4251301/jislam"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598369425,
                "post_id": 63581946,
                "comment_id": 112433745,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598368817,
                "creation_date": 1598368817,
                "answer_id": 63582059,
                "question_id": 63581946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In nodes.sh, rather than invoking jq without any argument, invoke it as `jq -s .`.",
                "title": "How to call jq written in shell with python subprocess?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598368817,
        "creation_date": 1598368451,
        "question_id": 63581946,
        "body_markdown": "I have two following shell scripts. \r\n\r\n**nodes.sh:**\r\n\r\n    #!/bin/bash\r\n\r\n    NODE_IDs=$(docker node ls --format &quot;{{.ID}}&quot;)\r\n\tfor NODE_ID in ${NODE_IDs}\r\n\tdo\r\n\t\tdocker node inspect $NODE_ID | jq -r &#39;.[] | {node:.ID, ip:.Status.Addr}&#39;\r\n\tdone | jq -s\r\n\r\n*nodes.sh* gives following output (with `./nodes.sh` or `cat ./nodes.sh | bash`):\r\n\r\n    [\r\n      {\r\n        &quot;node&quot;: &quot;b2d9g6i9yp5uj5k25h1ehp26e&quot;,\r\n        &quot;ip&quot;: &quot;192.168.1.123&quot;\r\n      },\r\n      {\r\n        &quot;node&quot;: &quot;iy25xmeln0ns7onzg4jaofiwo&quot;,\r\n        &quot;ip&quot;: &quot;192.168.1.125&quot;\r\n      }\r\n    ]\r\n\r\n**node_detail.sh**:\r\n\r\n    #!/bin/bash\r\n    \r\n    docker node inspect b2d | jq &#39;.[] | {node: .ID, ip: .Status.Addr}&#39;\r\n\r\nwhere as *node_detail.sh* gives (`./node_detail.sh` or `cat ./node_detail.sh`):\r\n\r\n    {\r\n      &quot;node&quot;: &quot;b2d9g6i9yp5uj5k25h1ehp26e&quot;,\r\n      &quot;ip&quot;: &quot;192.168.1.123&quot;\r\n    }\r\n\r\n**Problem**: I would like to run both script from python `subporcess`. \r\n\r\nI can run and get output for *node_detail.sh* with following code:\r\n\r\n    &gt;&gt;&gt; import subprocess\r\n    &gt;&gt;&gt; proc = subprocess.Popen(&#39;./node_detail.sh&#39;, stdout=subprocess.PIPE, shell=True)\r\n    &gt;&gt;&gt; proc.stdout.read()\r\n    &#39;{\\n  &quot;node&quot;: &quot;b2d9g6i9yp5uj5k25h1ehp26e&quot;,\\n  &quot;ip&quot;: &quot;192.168.1.123&quot;\\n}\\n&#39;\r\n\r\nI wrote following code to get output from *nodes.sh*\r\n\r\n    &gt;&gt;&gt; import subprocess\r\n    &gt;&gt;&gt; proc = subprocess.Popen(&#39;./nodes.sh&#39;, stdout=subprocess.PIPE, shell=True)\r\n\r\nNow I am getting following error:\r\n\r\n    &gt;&gt;&gt; jq - commandline JSON processor [version 1.5-1-a5b5cbe]\r\n    Usage: jq [options] &lt;jq filter&gt; [file...]\r\n    \r\n    \tjq is a tool for processing JSON inputs, applying the\r\n    \tgiven filter to its JSON text inputs and producing the\r\n    \tfilter&#39;s results as JSON on standard output.\r\n    \tThe simplest filter is ., which is the identity filter,\r\n    \tcopying jq&#39;s input to its output unmodified (except for\r\n    \tformatting).\r\n    \tFor more advanced filters see the jq(1) manpage (&quot;man jq&quot;)\r\n    \tand/or https://stedolan.github.io/jq\r\n    \r\n    \tSome of the options include:\r\n    \t -c\t\tcompact instead of pretty-printed output;\r\n    \t -n\t\tuse `null` as the single input value;\r\n    \t -e\t\tset the exit status code based on the output;\r\n    \t -s\t\tread (slurp) all inputs into an array; apply filter to it;\r\n    \t -r\t\toutput raw strings, not JSON texts;\r\n    \t -R\t\tread raw strings, not JSON texts;\r\n    \t -C\t\tcolorize JSON;\r\n    \t -M\t\tmonochrome (don&#39;t colorize JSON);\r\n    \t -S\t\tsort keys of objects on output;\r\n    \t --tab\tuse tabs for indentation;\r\n    \t --arg a v\tset variable $a to value &lt;v&gt;;\r\n    \t --argjson a v\tset variable $a to JSON value &lt;v&gt;;\r\n    \t --slurpfile a f\tset variable $a to an array of JSON texts read from &lt;f&gt;;\r\n    \tSee the manpage for more options.\r\n    Error: writing output failed: Broken pipe\r\n    Error: writing output failed: Broken pipe\r\n\r\nWhy I am getting *Error: writing output failed: Broken pipe*?",
        "link": "https://stackoverflow.com/questions/63581946/how-to-call-jq-written-in-shell-with-python-subprocess",
        "title": "How to call jq written in shell with python subprocess?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 358955,
                    "reputation": 3031,
                    "user_id": 700074,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/41e7c894a478fd3b82a9f7adba12feed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "recursive_acronym",
                    "link": "https://stackoverflow.com/users/700074/recursive-acronym"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598447986,
                "post_id": 63596570,
                "comment_id": 112462128,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 358955,
                    "reputation": 3031,
                    "user_id": 700074,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://www.gravatar.com/avatar/41e7c894a478fd3b82a9f7adba12feed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "recursive_acronym",
                    "link": "https://stackoverflow.com/users/700074/recursive-acronym"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598458071,
                "post_id": 63596570,
                "comment_id": 112467701,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598462409,
                "post_id": 63596570,
                "comment_id": 112469750,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1598462383,
                "last_edit_date": 1598462383,
                "creation_date": 1598441875,
                "answer_id": 63596839,
                "question_id": 63596570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why take the trouble of taking a roundabout approach for such a simple filter? All you need is below. The `-c/--compact-output` flag will put the output in a single line\r\n\r\n    jq -c &#39;[.items[].id]&#39;\r\n\r\n[jqplay - demo1][1]\r\n\r\nTo demystify your filter from the pasted link, `[.items[] ] []` will put the contents of `.items` in an array and will get it back from it. Then `[.id, .name]` will create multiple arrays with 0th element being the `.id` value and `.[0]` will get only the id values without them being put in an array. The approach doesn&#39;t make sense to me.\r\n\r\n---\r\n\r\nIn addition to the OP, there was a post in the comments to get the first element from each of the arrays below\r\n\r\n    [&quot;1&quot;, &quot;2&quot;, &quot;3&quot;]\r\n    [&quot;4&quot;, &quot;5&quot;, &quot;6&quot;]\r\n    [&quot;7&quot;, &quot;8&quot;, &quot;9&quot;]\r\n\r\nwhich can be done as\r\n\r\n    jq -cn &#39;[inputs] | map(first)&#39;\r\n    \r\n[jqplay - demo2][2]\r\n\r\n\r\n  [1]: https://jqplay.org/s/YB7mMyh9-_\r\n  [2]: https://jqplay.org/s/hg3MY-PkVx",
                "title": "jq - returns plain list instead of json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1598462383,
        "creation_date": 1598440943,
        "last_edit_date": 1598442550,
        "question_id": 63596570,
        "body_markdown": "The below example returns a plain list instead of a JSON array for this sample JSON\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: 1,\r\n          &quot;name&quot;: &quot;one&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 2,\r\n          &quot;name&quot;: &quot;two&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: 3,\r\n          &quot;name&quot;: &quot;tre&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nThis is the output I want:\r\n\r\n    [1,2,3]\r\n\r\nBut I get\r\n\r\n    1\r\n    2\r\n    3\r\n\r\nwith \r\n\r\n    [.items[] ] [] | [.id, .name]  | .[0]\r\n\r\n\r\nDemo:   https://jqplay.org/s/YPG4I9BMDn\r\n",
        "link": "https://stackoverflow.com/questions/63596570/jq-returns-plain-list-instead-of-json-array",
        "title": "jq - returns plain list instead of json array"
    },
    {
        "tags": [
            "json",
            "math",
            "type-conversion",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598443618,
                "last_edit_date": 1598443618,
                "creation_date": 1598443246,
                "answer_id": 63597199,
                "question_id": 63597198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[This SO answer](https://stackoverflow.com/questions/46911763/jq-error-number-and-string-cannot-be-added) gave me the clue that there was a `tostring` function, so a more thorough search of the manual page revealed that the analogous function for numbers is `tonumber`.\r\n\r\nWell, duh. I guess I was expecting it to be named something else, like `toint`, which is why I didn&#39;t find it while string-searching through the man page.\r\n\r\nHere is the solution I ended up with:\r\n\r\n\r\n```bash\r\njq &#39;map(.width | sub(&quot;%&quot;; &quot;&quot;)? | tonumber) | add&#39; columns.json\r\n```\r\n\r\nInstead of `select(.)` to filter out the `null`s from objects with no `.width` field, I just silently ignore the error in `sub` (with `?`), which drops those records.\r\n\r\nNote that `map(.width)` is just another way of saying `[.[].width]`.",
                "title": "How to sum up string fields that contain percentages with &#39;jq&#39;?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598445537,
                "creation_date": 1598445537,
                "answer_id": 63597885,
                "question_id": 63597198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A shorter alternative:\r\n```\r\nmap(.width[:-1] | tonumber?) | add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/IqWchEeFpv)&lt;/sup&gt;",
                "title": "How to sum up string fields that contain percentages with &#39;jq&#39;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1645538217,
        "creation_date": 1598443246,
        "last_edit_date": 1645538217,
        "question_id": 63597198,
        "body_markdown": "I have a JSON file that&#39;s keeping track of column widths for a table as percentages. So the input file, `columns.json`, looks something like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Column A&quot;,\r\n    &quot;width&quot;: &quot;33%&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Column B&quot;,\r\n    &quot;width&quot;: &quot;33%&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Column C&quot;,\r\n    &quot;width&quot;: &quot;33%&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Column D&quot;,\r\n    &quot;visible&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nSome columns are not displayed and therefore don&#39;t have widths (`jq &#39;.[].width&#39;` will return `null`s for these), and then there&#39;s also the issue of the percent signs. Otherwise I might&#39;ve used `munge | munge | paste -sd+ | bc`, which is usually what I use for summing things up in the shell, but that seems stupid here because `jq` _ought_ to be able to do this by itself.\r\n\r\nSo **using only `jq`**, how can I sum up the `width` fields from this file, _e.g._, to make sure they don&#39;t exceed 100%?\r\n\r\n## Things I have tried (that didn&#39;t work)\r\n\r\nI use `select(.)` here to filter out records that don&#39;t have a `.width`, then get rid of the percent sign:\r\n\r\n```bash\r\njq &#39;[.[].width | select(.) | sub(&quot;%&quot;; &quot;&quot;)] | add&#39; columns.json\r\n```\r\n\r\n…but that just concatenates the strings and returns `&quot;333333&quot;`.\r\n\r\nI didn&#39;t see any mention of the word &quot;typecast&quot; in the `jq` man page, so I thought maybe it would do type inference, treating a string that looks like a number as a number in the right context:\r\n\r\n```bash\r\njq &#39;[.[].width | select(.) | sub(&quot;%&quot;; &quot;&quot;) | .+0] | add&#39; columns.json\r\n```\r\n\r\n…but that just yields and error message like:\r\n\r\n    jq: error (at columns.json:18): string (&quot;33&quot;) and number (0) cannot be added",
        "link": "https://stackoverflow.com/questions/63597198/how-to-sum-up-string-fields-that-contain-percentages-with-jq",
        "title": "How to sum up string fields that contain percentages with &#39;jq&#39;?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598516067,
                "post_id": 63611639,
                "comment_id": 112485863,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 452919,
                    "reputation": 3698,
                    "user_id": 849632,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/0XO3G.jpg?s=256",
                    "display_name": "Arun",
                    "link": "https://stackoverflow.com/users/849632/arun"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598516191,
                "post_id": 63611639,
                "comment_id": 112485920,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1598516336,
                "post_id": 63611639,
                "comment_id": 112486001,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598746859,
                "post_id": 63611639,
                "comment_id": 112559677,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1598518785,
                "last_edit_date": 1598518785,
                "creation_date": 1598516993,
                "answer_id": 63612109,
                "question_id": 63611639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to pass TOKEN_JSON_RESPONSE value to jq stdin. It will print to stout result and then you save this result to variable:\r\n\r\n    #!/bin/bash                                                                                                                                                                                                                                 \r\n    \r\n    TOKEN_JSON_RESPONSE=&#39;                                                                                                                                                                                                                       \r\n    {                                                                                                                                                                                                                                           \r\n       &quot;access_token&quot;:&quot;eyJxxxxxxxx&quot;,                                                                                                                                                                                                            \r\n       &quot;token_type&quot;:&quot;bearer&quot;,                                                                                                                                                                                                                   \r\n       &quot;expires_in&quot;:3600                                                                                                                                                                                                                        \r\n    }&#39;\r\n    \r\n    echo &#39;The token response is &#39; $TOKEN_JSON_RESPONSE\r\n    \r\n    ACCESS_TOKEN=$(echo $TOKEN_JSON_RESPONSE | jq -j &#39;.access_token&#39;)\r\n    \r\n    echo &#39;The access token is &#39;$ACCESS_TOKEN\r\n\r\nExecution:\r\n\r\n    The token response is  { &quot;access_token&quot;:&quot;eyJxxxxxxxx&quot;, &quot;token_type&quot;:&quot;bearer&quot;, &quot;expires_in&quot;:3600 }\r\n    The access token is eyJxxxxxxxx\r\n\r\n#Update1\r\n\r\nAs suggested in comments below it may be written without echo:\r\n\r\n    jq -jn &quot;$TOKEN_JSON_RESPONSE|.access_token&quot;",
                "title": "Parse access-token using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1598518785,
        "creation_date": 1598515302,
        "last_edit_date": 1598516132,
        "question_id": 63611639,
        "body_markdown": "Below is the bash-script that i use to parse the json-response from my OAuth provider. My intention is to extract only the `access-token` from the json response\r\n\r\n```sh\r\nCLIENT_ID=MASKED\r\nCLIENT_SECRET=MASKED\r\nRESOURCE=MASKED\r\n\r\nTOKEN_JSON_RESPONSE=$(\r\n    curl https://corp.company.com/adfs/oauth2/token/ -H &#39;Accept: application/json&#39; -H &#39;Content-Type: application/x-www-form-urlencoded&#39; -d &#39;client_id=&#39;$CLIENT_ID&#39;&amp;client_secret=&#39;$CLIENT_SECRET&#39;&amp;grant_type=client_credentials&amp;resource=&#39;$RESOURCE\r\n)\r\n\r\necho &#39;The token response is &#39; $TOKEN_JSON_RESPONSE\r\n\r\necho &#39; @@@@@@@@@@@@@@@@@  &#39;\r\n\r\nACCESS_TOKEN=$TOKEN_JSON_RESPONSE | jq &#39;.access_token&#39;\r\n\r\necho &#39;The access token is &#39;$ACCESS_TOKEN\r\n```\r\n\r\nI am getting the JSON response properly and below is that\r\n\r\n```json\r\n{\r\n   &quot;access_token&quot;:&quot;eyJxxxxxxxx&quot;,\r\n   &quot;token_type&quot;:&quot;bearer&quot;,\r\n   &quot;expires_in&quot;:3600\r\n}\r\n```\r\n\r\nAll that i need is to just to extract the value in the `access_token` .. Currently in the above script, i get an empty string after using jq-parser\r\n\r\n**Update:**\r\n\r\nwhen i directly print this way, it works `echo $TOKEN_JSON_RESPONSE|jq &#39;.access_token’`\r\n\r\nwhereas when i put the same in a variable it doesn&#39;t work\r\n\r\n`ACCESS_TOKEN=$TOKEN_JSON_RESPONSE|jq &#39;.access_token’`\r\n`echo $ACCESS_TOKEN`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63611639/parse-access-token-using-jq",
        "title": "Parse access-token using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598527748,
                "post_id": 63613080,
                "comment_id": 112491369,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598666958,
                "creation_date": 1598666958,
                "answer_id": 63642777,
                "question_id": 63613080,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you haven&#39;t provided more detail I am going to assume that you simply want to append a hard-coded object to an existing array. (If that&#39;s not what you mean you&#39;ll need to be more precise in your question.)\r\n\r\nYou can add items to the end of a list with the `+` operator. So in your case:\r\n\r\n```\r\njq &#39;.+[{&quot;gate&quot;:[{&quot;pro1&quot;: &quot;2&quot;}], &quot;home&quot;:[{&quot;mem1&quot;: &quot;2&quot;}],&quot;holder&quot;: &quot;1&quot;}]&#39; input.json\r\n```\r\n```\r\n[\r\n  {\r\n    &quot;gate&quot;: [\r\n      {\r\n        &quot;pro1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;home&quot;: [\r\n      {\r\n        &quot;mem1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;holder&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;gate&quot;: [\r\n      {\r\n        &quot;pro1&quot;: &quot;2&quot;\r\n      }\r\n    ],\r\n    &quot;home&quot;: [\r\n      {\r\n        &quot;mem1&quot;: &quot;2&quot;\r\n      }\r\n    ],\r\n    &quot;holder&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe `.` takes the existing input, which is an array. The `+[ {...} ]` concatenates it with another array of one object. If you want to put the new item(s) at the start instead of the end, swap it round: `[ {...} ]+.`",
                "title": "How can i insert object which got arrays into arrays using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1598666958,
        "creation_date": 1598520602,
        "last_edit_date": 1598521357,
        "question_id": 63613080,
        "body_markdown": "I may not discribed it properly, I tried many times and looked up the manaual on [jq Manaual][1] , and i got no idea how to insert object which contains array into a json file by jq command, anyway,  here is the origin test.json:\r\n```\r\n[\r\n  {\r\n    &quot;gate&quot;: [\r\n      {\r\n        &quot;pro1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;home&quot;: [\r\n      {\r\n        &quot;mem1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;holder&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```\r\nAnd i wish to be like this after insert:\r\n```\r\n[\r\n  {\r\n    &quot;gate&quot;: [\r\n      {\r\n        &quot;pro1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;home&quot;: [\r\n      {\r\n        &quot;mem1&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;holder&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;gate&quot;: [\r\n      {\r\n        &quot;pro1&quot;: &quot;2&quot;\r\n      }\r\n    ],\r\n    &quot;home&quot;: [\r\n      {\r\n        &quot;mem1&quot;: &quot;2&quot;\r\n      }\r\n    ],\r\n    &quot;holder&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```\r\n\r\nCould it possibly done by jq? \r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/\r\n",
        "link": "https://stackoverflow.com/questions/63613080/how-can-i-insert-object-which-got-arrays-into-arrays-using-jq",
        "title": "How can i insert object which got arrays into arrays using jq?"
    },
    {
        "tags": [
            "json",
            "relational-database",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598535883,
                "post_id": 63616669,
                "comment_id": 112495608,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598536148,
                "post_id": 63616669,
                "comment_id": 112495777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598536526,
                "post_id": 63616669,
                "comment_id": 112496012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598536691,
                "post_id": 63616669,
                "comment_id": 112496125,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2716477,
                    "reputation": 2569,
                    "user_id": 2343739,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/hetYc.jpg?s=256",
                    "display_name": "Collin Barrett",
                    "link": "https://stackoverflow.com/users/2343739/collin-barrett"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598536907,
                "post_id": 63616669,
                "comment_id": 112496252,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598537200,
                "post_id": 63616669,
                "comment_id": 112496415,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598539643,
                "post_id": 63616669,
                "comment_id": 112497797,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1598536478,
                "creation_date": 1598536478,
                "answer_id": 63617564,
                "question_id": 63616669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a simple script with hardcoded number of mirrors and primariness. Hope it will do the trick.\r\n\r\n    jq &#39;\r\n        map(\r\n            { foreinKeyId } +\r\n            (\r\n                { primariness: 1, url },\r\n                (.urlMirror1 // empty | { primariness: 2, url: . }),\r\n                (.urlMirror2 // empty | { primariness: 3, url: . })\r\n            )\r\n        )\r\n    &#39; input.json\r\n",
                "title": "Flatten / normalize json array of objects with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1598625359,
                "last_edit_date": 1598625359,
                "creation_date": 1598539449,
                "answer_id": 63618532,
                "question_id": 63616669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given that OP has limited the query from generic down to a more specific criteria, the answer provided by @luciole75w is the best (most probably), refer to that one.\r\n\r\nNow, for @oguzismail, this is a generic `jtc` approach (which will handle an arbitrary number of `&quot;urlMirror&quot;s`) made of 3 JSON transformation steps (**updated solution**):\r\n```\r\n&lt;file.json jtc -w&#39;&lt;foreignKeyId&gt;l:&lt;f&gt;v[-1]&lt;urlM&gt;L:&lt;u&gt;v[^0]&#39; \\\r\n               -i&#39;{&quot;url&quot;:{{u}},&quot;foreignKeyId&quot;:{f}}&#39; /\\\r\n               -w&#39;[foreignKeyId]:&lt;f&gt;q:&lt;p:0&gt;v[^0][foreignKeyId]:&lt;f&gt;s:[-1]&lt;p&gt;I1&#39; \\\r\n               -i&#39;{&quot;primeriness&quot;:{{p}}}&#39; /\\\r\n               -pw&#39;&lt;urlM&gt;L:&#39; -tc\r\n[\r\n   { &quot;foreignKeyId&quot;: 1, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://1-url.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://2-url.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://3-url.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;primeriness&quot;: 2, &quot;url&quot;: &quot;https://2-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 2, &quot;url&quot;: &quot;https://3-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 3, &quot;url&quot;: &quot;https://3-url-mirror-2.com&quot; }\r\n]\r\nbash $ \r\n```\r\n\r\n### Explanation and visualization:\r\n\\- all the 3 steps can be observed in a &quot;slow-mo&quot;:  \r\n1\\. for each found `&quot;foreignKeyId&quot;` and each `&quot;urlMirror&quot;` found within the same record extend (insert into) the array with `{&quot;url&quot;:... , &quot;foreignKeyId&quot;: ...}`:\r\n```\r\n&lt;file.json jtc -w&#39;&lt;foreignKeyId&gt;l:&lt;f&gt;v[-1]&lt;urlM&gt;L:&lt;u&gt;v[^0]&#39; \\\r\n               -i&#39;{&quot;url&quot;:{{u}},&quot;foreignKeyId&quot;:{f}}&#39; -tc\r\n[\r\n   { &quot;foreignKeyId&quot;: 1, &quot;url&quot;: &quot;https://1-url.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;url&quot;: &quot;https://2-url.com&quot;, &quot;urlMirror1&quot;: &quot;https://2-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;url&quot;: &quot;https://3-url.com&quot;, &quot;urlMirror1&quot;: &quot;https://3-url-mirror-1.com&quot;, &quot;urlMirror2&quot;: &quot;https://3-url-mirror-2.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;url&quot;: &quot;https://2-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;url&quot;: &quot;https://3-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;url&quot;: &quot;https://3-url-mirror-2.com&quot; }\r\n]\r\nbash $ \r\n```\r\n\r\n2\\. now insert `&quot;primariness&quot;: N` records based on the index of the occurrence of the `foreignKeyId`:\r\n```\r\n&lt;file.json jtc -w&#39;&lt;foreignKeyId&gt;l:&lt;f&gt;v[-1]&lt;urlM&gt;L:&lt;u&gt;v[^0]&#39; \\\r\n               -i&#39;{&quot;url&quot;:{{u}},&quot;foreignKeyId&quot;:{f}}&#39; /\\\r\n               -w&#39;[foreignKeyId]:&lt;f&gt;q:&lt;p:0&gt;v[^0][foreignKeyId]:&lt;f&gt;s:[-1]&lt;p&gt;I1&#39; \\\r\n               -i&#39;{&quot;primeriness&quot;:{{p}}}&#39; -tc\r\n[\r\n   { &quot;foreignKeyId&quot;: 1, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://1-url.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://2-url.com&quot;, &quot;urlMirror1&quot;: &quot;https://2-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 1, &quot;url&quot;: &quot;https://3-url.com&quot;, &quot;urlMirror1&quot;: &quot;https://3-url-mirror-1.com&quot;, &quot;urlMirror2&quot;: &quot;https://3-url-mirror-2.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 2, &quot;primeriness&quot;: 2, &quot;url&quot;: &quot;https://2-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 2, &quot;url&quot;: &quot;https://3-url-mirror-1.com&quot; },\r\n   { &quot;foreignKeyId&quot;: 3, &quot;primeriness&quot;: 3, &quot;url&quot;: &quot;https://3-url-mirror-2.com&quot; }\r\n]\r\nbash $ \r\n```\r\n\r\n3\\. and final step (`-pw&#39;&lt;urlM&gt;L:&#39;`) - rid of all redundant `&quot;urlMirror&quot;`s records.\r\n\r\n_Optionally_: if there&#39;s a requirement to sort all the records within the top array as per the OP&#39;s example, then this additional step will do: `-jw&#39;[foreignKeyId]:&lt;&gt;g:[-1]&#39;` \r\n\r\nPS. it so happens that I&#39;m also a developer of the `jtc` unix tool\r\n\r\n",
                "title": "Flatten / normalize json array of objects with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1598599830,
                "last_edit_date": 1598599830,
                "creation_date": 1598582108,
                "answer_id": 63626671,
                "question_id": 63616669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a general solution, that is, it will handle arbitrarily many urlMirrors.\r\n\r\nFor the sake of clarity, let&#39;s begin by defining a helper function that emits a stream of {foreignKeyId, primariness, url} objects for a single input object:\r\n```\r\ndef primarinesses:\r\n  {foreinKeyId} +\r\n    ({primariness:1, url},\r\n     (to_entries[]\r\n      | (.key | capture( &quot;^urlMirror(?&lt;n&gt;[0-9]+)&quot;)) as $n\r\n      | {primariness: ($n.n | tonumber + 1), url : .value } )) ;\r\n```\r\n\r\nThe solution is then simply:\r\n\r\n    [.[] | primarinesses]\r\n\r\nwhich can also be written with less punctuation as:\r\n\r\n    map(primarinesses)\r\n\r\n\r\n",
                "title": "Flatten / normalize json array of objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1598625359,
        "creation_date": 1598533564,
        "last_edit_date": 1598614260,
        "question_id": 63616669,
        "body_markdown": "I have a large json array of objects. Each object contains a `foreignKeyId`, a `url`, (optionally) a `urlMirror1`, and (optionally) a `urlMirror2`.\r\n\r\nHere&#39;s a sample:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foreignKeyId&quot;: 1,\r\n    &quot;url&quot;: &quot;https://1-url.com&quot;\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 2,\r\n    &quot;url&quot;: &quot;https://2-url.com&quot;,\r\n    &quot;urlMirror1&quot;: &quot;https://2-url-mirror-1.com&quot;,\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 3,\r\n    &quot;url&quot;: &quot;https://3-url.com&quot;,\r\n    &quot;urlMirror1&quot;: &quot;https://3-url-mirror-1.com&quot;,\r\n    &quot;urlMirror2&quot;: &quot;https://3-url-mirror-2.com&quot;\r\n  }\r\n}\r\n```\r\n\r\nI want to normalize this json to something like below:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;foreignKeyId&quot;: 1,\r\n    &quot;primariness&quot;: 1,\r\n    &quot;url&quot;: &quot;https://1-url.com&quot;\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 2,\r\n    &quot;primariness&quot;: 1,\r\n    &quot;url&quot;: &quot;https://2-url.com&quot;,\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 2,\r\n    &quot;primariness&quot;: 2,\r\n    &quot;url&quot;: &quot;https://2-url-mirror-1.com&quot;,\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 3,\r\n    &quot;primariness&quot;: 1,\r\n    &quot;url&quot;: &quot;https://3-url.com&quot;\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 3,\r\n    &quot;primariness&quot;: 2,\r\n    &quot;url&quot;: &quot;https://3-url-mirror-1.com&quot;,\r\n  },\r\n  {\r\n    &quot;foreignKeyId&quot;: 3,\r\n    &quot;primariness&quot;: 3,\r\n    &quot;url&quot;: &quot;https://3-url-mirror-2.com&quot;\r\n  }\r\n}\r\n```\r\n\r\nIs there a way to do something like this using `jq`? If not, any other suggestions to accomplish this quickly without writing too much custom code? This only needs to be run one time, so any kind of hacky one-off solution could work (bash script, etc.).\r\n\r\nThanks!\r\n\r\n**Update:**\r\n`primariness` should be derived from the key names (`url` =&gt; `1`, `urlMirror1` =&gt; `2`, `urlMirror2` =&gt; `3`. Order of the keys inside any given object is insignificant. There is a fixed number of mirrors (e.g., there is never a `urlMirror3`).",
        "link": "https://stackoverflow.com/questions/63616669/flatten-normalize-json-array-of-objects-with-jq",
        "title": "Flatten / normalize json array of objects with jq"
    },
    {
        "tags": [
            "javascript",
            "node.js",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598551505,
                "post_id": 63621648,
                "comment_id": 112503718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598552126,
                "post_id": 63621648,
                "comment_id": 112503982,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598551217,
                "creation_date": 1598551217,
                "answer_id": 63621771,
                "question_id": 63621648,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use [`Object.fromEntries`][1] like this:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    const tags = [ \r\n        { Key: &#39;Name&#39;, Value: &#39;xxx&#39; },\r\n        { Key: &#39;role&#39;, Value: &#39;yyy&#39; } \r\n    ];\r\n\r\n\r\n    const obj = Object.fromEntries(tags.map(({ Key, Value }) =&gt; [Key, Value]));\r\n\r\n    console.log(obj);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n\r\n  [1]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/fromEntries",
                "title": "transform ec2 tags with jq and node.js"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1633090927,
        "creation_date": 1598550671,
        "last_edit_date": 1633090927,
        "question_id": 63621648,
        "body_markdown": "I need to transform this ec2 tags (array)  \r\n\r\n    [ \r\n        { Key: &#39;Name&#39;, Value: &#39;xxx&#39; },\r\n        { Key: &#39;role&#39;, Value: &#39;yyy&#39; } \r\n    ]\r\n\r\nto \r\n\r\n    { \r\n     name : &#39;xxx&#39;,\r\n     role : &#39;yyy&#39;\r\n    }\r\n\r\nusing jq and node.js. Could you help please\r\nregards\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63621648/transform-ec2-tags-with-jq-and-node-js",
        "title": "transform ec2 tags with jq and node.js"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598600759,
                "post_id": 63627472,
                "comment_id": 112517516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16405220,
                    "reputation": 33,
                    "user_id": 11849945,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-hrK4j10Zj0E/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfvG9A4oh68gPXtTWnigAh1a-oeJA/s256-rj/photo.jpg",
                    "display_name": "Joe Jiang",
                    "link": "https://stackoverflow.com/users/11849945/joe-jiang"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598845774,
                "post_id": 63627472,
                "comment_id": 112579224,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16405220,
                    "reputation": 33,
                    "user_id": 11849945,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-hrK4j10Zj0E/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfvG9A4oh68gPXtTWnigAh1a-oeJA/s256-rj/photo.jpg",
                    "display_name": "Joe Jiang",
                    "link": "https://stackoverflow.com/users/11849945/joe-jiang"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598845828,
                "post_id": 63627472,
                "comment_id": 112579236,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598846447,
                "last_edit_date": 1598846447,
                "creation_date": 1598601252,
                "answer_id": 63629670,
                "question_id": 63627472,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input shown in the Q has been modified in the obvious way to make it valid JSON, the following filter will produce the output as shown below, that is, a stream of valid JSON values that is similar to the allegedly expected output included in the Q.  If a single array is desired, one possibility would be to wrap the program in square brackets. \r\n### program.jq\r\n```\r\n.elements[]\r\n| {id, values: [ .fieldValues[].value] }\r\n```\r\n### Output\r\n```\r\n{\r\n  &quot;id&quot;: &quot;2185&quot;,\r\n  &quot;values&quot;: [\r\n    &quot;9/6/2017 12:00:00 AM&quot;,\r\n    &quot;ABC&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;2186&quot;,\r\n  &quot;values&quot;: [\r\n    &quot;8/31/2017 12:00:00 AM&quot;,\r\n    &quot;DEF&quot;\r\n  ]\r\n}\r\n```\r\n\r\n## Producing CSV\r\nOne of many possibilities:\r\n```\r\n.elements[]\r\n| [.id] + [.fieldValues[].value]\r\n| @csv\r\n```\r\n\r\nWith the -r command-line option, this produces the following CSV:\r\n```\r\n&quot;2185&quot;,&quot;9/6/2017 12:00:00 AM&quot;,&quot;ABC&quot;\r\n&quot;2186&quot;,&quot;8/31/2017 12:00:00 AM&quot;,&quot;DEF&quot;\r\n```\r\n\r\n\r\n",
                "title": "Format nested JSON input using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598846447,
        "creation_date": 1598588861,
        "question_id": 63627472,
        "body_markdown": "I am trying to convert the sample input below into the output below using jq:\r\n\r\n**Input JSON**\r\n```{\r\n  &quot;elements&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;CustomObjectData&quot;,\r\n      &quot;id&quot;: &quot;2185&quot;,\r\n      &quot;fieldValues&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;FieldValue&quot;,\r\n          &quot;id&quot;: &quot;169&quot;,\r\n          &quot;value&quot;: &quot;9/6/2017 12:00:00 AM&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;FieldValue&quot;,\r\n          &quot;id&quot;: &quot;190&quot;,\r\n          &quot;value&quot;: &quot;ABC&quot;\r\n        } \r\n        ]\r\n        },\r\n {\r\n      &quot;type&quot;: &quot;CustomObjectData&quot;,\r\n      &quot;id&quot;: &quot;2186&quot;,\r\n      &quot;contactId&quot;: &quot;13&quot;,\r\n      &quot;fieldValues&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;FieldValue&quot;,\r\n          &quot;id&quot;: &quot;169&quot;,\r\n          &quot;value&quot;: &quot;8/31/2017 12:00:00 AM&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;FieldValue&quot;,\r\n          &quot;id&quot;: &quot;190&quot;,\r\n          &quot;value&quot;: &quot;DEF&quot;\r\n        }\r\n        ]\r\n        }\r\n]\r\n```\r\n\r\n**Desired Output (group by id)**\r\n\r\nEssentially trying to extract &quot;value&quot; field from each &quot;fieldValues&quot; object and group them by &quot;id&quot;\r\n```\r\n{\r\n&quot;id:&quot;2185&quot;,\r\n&quot;value&quot;: &quot;9/6/2017 12:00:00 AM&quot;,\r\n &quot;value&quot;: &quot;ABC&quot;\r\n},\r\n{\r\n&quot;id:&quot;2186&quot;,\r\n&quot;value&quot;: &quot;8/31/2017 12:00:00 AM&quot;,\r\n &quot;value&quot;: &quot;DEF&quot;\r\n}\r\n```\r\n\r\nWhat jq syntax should i use to achieve this? Thanks very much!!",
        "link": "https://stackoverflow.com/questions/63627472/format-nested-json-input-using-jq",
        "title": "Format nested JSON input using JQ?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1598623972,
                "last_edit_date": 1598623972,
                "creation_date": 1598620317,
                "answer_id": 63634468,
                "question_id": 63633913,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To perform the selection, you could use\r\n\r\n    select( test( &quot;^/v6/&quot; ) )\r\n\r\nSo the command becomes;\r\n```bash\r\njq &#39;.. .pattern? // empty | select(test(&quot;^/v6/&quot;))&#39; /tmp/all.json\r\n```\r\nOr similarly with `startswith`.\r\n\r\n",
                "title": "jq Recursive search values by key, starting with"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1598623972,
        "creation_date": 1598618165,
        "question_id": 63633913,
        "body_markdown": "**TL;DR**\r\n\r\nWhat is [tag:jq]&#39;s equivalent to `grep &#39;&quot;\\/v6&#39;` in the following command;\r\n```\r\njq &#39;.. .pattern? // empty&#39; /tmp/all.json | grep &#39;&quot;\\/v6&#39;\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\nConsider the following json;\r\n```json\r\n{\r\n  &quot;payload&quot;: {\r\n    &quot;groups&quot;: [\r\n      {\r\n        &quot;pattern&quot;: &quot;/v6/&quot;,\r\n        &quot;groups&quot;: [\r\n          {\r\n            &quot;pattern&quot;: &quot;something/&quot;,\r\n            &quot;groups&quot;: [\r\n              {\r\n                &quot;pattern&quot;: &quot;somethingElse/&quot;,\r\n                &quot;groups&quot;: [\r\n                  {\r\n                    &quot;pattern&quot;: &quot;{specialPattern:[0-9]+}/&quot;,\r\n                    &quot;groups&quot;: [],\r\n                    &quot;routes&quot;: [\r\n                      {\r\n                        &quot;type&quot;: &quot;variable&quot;,\r\n                        &quot;pattern&quot;: &quot;/v6/notImportant/{specialPattern:[0-9]+}/&quot;,\r\n                        &quot;methods&quot;: {\r\n```\r\n&lt;sup&gt;The json file is quite large, with a lot of irrelevant data&lt;/sup&gt;\r\n\r\nI&#39;m trying to capture all the `.pattern` in the json file, [based on this question](https://stackoverflow.com/questions/38459429/recursive-search-values-by-key) I&#39;ve created the following jq command:\r\n```\r\njq &#39;.. .pattern? // empty&#39; /tmp/all.json\r\n```\r\nThis works as expected, creating a output similar to this;\r\n```\r\n&quot;/v6/&quot;\r\n&quot;something/&quot;\r\n&quot;somethingElse/&quot;\r\n&quot;{specialPattern:[0-9]+}/&quot;\r\n&quot;/v6/notImportant/{specialPattern:[0-9]+}/&quot;\r\n```\r\n&lt;hr&gt;\r\n\r\n**Question:** How would I *only* select each `.pattern` that starts with `/v6/` ?\r\nI&#39;ve used [tag:grep] like so\r\n```\r\njq &#39;.. .pattern? // empty&#39; /tmp/all.json | grep &#39;&quot;\\/v6&#39;\r\n```\r\nHowever, there must be a `jq`-only solution to this.\r\n\r\n&lt;hr&gt;\r\n\r\nGoogle taught me about jq&#39;s [`contains`](https://stedolan.github.io/jq/manual/#example49) that seems to be the answer on some-sort-of related question;\r\n* &lt;https://stackoverflow.com/questions/26701538/how-to-filter-an-array-of-objects-based-on-values-in-an-inner-array-with-jq&gt;\r\n* [filter on &quot;string contains&quot;](https://github.com/stedolan/jq/issues/33)\r\n* [Print array element if it contains](https://github.com/stedolan/jq/issues/861)\r\n\r\nUnfortunately I can&#39;t manage to make it work with my situation, since using `select` seems unnecessary.",
        "link": "https://stackoverflow.com/questions/63633913/jq-recursive-search-values-by-key-starting-with",
        "title": "jq Recursive search values by key, starting with"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1651202,
                    "reputation": 1844,
                    "user_id": 1670134,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/L4ejd.jpg?s=256",
                    "display_name": "sirandy",
                    "link": "https://stackoverflow.com/users/1670134/sirandy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598624758,
                "post_id": 63635568,
                "comment_id": 112528587,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19395082,
                    "reputation": 15,
                    "user_id": 14182961,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-9JSjEL0kbqU/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuckY-7zSn3ZcGbXOaovBM9mKTB3fLA/s256-rj/photo.jpg",
                    "display_name": "dobre",
                    "link": "https://stackoverflow.com/users/14182961/dobre"
                },
                "reply_to_user": {
                    "account_id": 1651202,
                    "reputation": 1844,
                    "user_id": 1670134,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://i.sstatic.net/L4ejd.jpg?s=256",
                    "display_name": "sirandy",
                    "link": "https://stackoverflow.com/users/1670134/sirandy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598625640,
                "post_id": 63635568,
                "comment_id": 112529019,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1598645561,
                "last_edit_date": 1598645561,
                "creation_date": 1598625902,
                "answer_id": 63636029,
                "question_id": 63635568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` function to convert the objects within `.components` into key/value pairs and provide an expression that selects the first object matching the condition and retrieve its key\n\r\n\n    .components | \n    to_entries  | \n    map(select(.value.status == &quot;DOWN&quot;))[0].key",
                "title": "With jq how to get the name of the parent element that contains &quot;DOWN&quot;?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598651484,
                "last_edit_date": 1598651484,
                "creation_date": 1598628360,
                "answer_id": 63636716,
                "question_id": 63635568,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` to get the key/values of your components , then select the first one with down status:\r\n```\r\nfirst(.components | to_entries | .[] | select( .value.status == &quot;DOWN&quot;) | .key)\r\n```\r\n[Run it on jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/f-hCdZ4_vI",
                "title": "With jq how to get the name of the parent element that contains &quot;DOWN&quot;?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1599194254,
        "creation_date": 1598624136,
        "last_edit_date": 1599194254,
        "question_id": 63635568,
        "body_markdown": "  ```json\r\n  {\r\n    \t&quot;status&quot;: &quot;DOWN&quot;,\r\n    \t&quot;components&quot;: {\r\n    \t\t&quot;ping&quot;: {\r\n    \t\t\t&quot;status&quot;: &quot;UP&quot;,\r\n    \t\t\t&quot;details&quot;: {\r\n    \t\t\t\t&quot;version&quot;: &quot;1.0.0&quot;,\r\n    \t\t\t\t&quot;description&quot;: &quot;dobre application&quot;,\r\n    \t\t\t\t&quot;name&quot;: &quot;SO-3113&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;bridge.lock&quot;: {\r\n    \t\t\t&quot;status&quot;: &quot;UP&quot;,\r\n    \t\t\t&quot;details&quot;: {\r\n    \t\t\t\t&quot;description&quot;: &quot;test1&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;Configuration converted&quot;: {\r\n    \t\t\t&quot;status&quot;: &quot;DOWN&quot;,\r\n    \t\t\t&quot;details&quot;: {\r\n    \t\t\t\t&quot;description&quot;: &quot;test2&quot;\r\n    \t\t\t}\r\n    \t\t},\r\n    \t\t&quot;app started&quot;: {\r\n    \t\t\t&quot;status&quot;: &quot;DOWN&quot;,\r\n    \t\t\t&quot;details&quot;: {\r\n    \t\t\t\t&quot;description&quot;: &quot;test3&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n```\r\nI need to get the name of first component with DOWN status (&quot;Configuration converted&quot; in above json). So far i managed to get only `.details.description` of it:\r\n\r\n```bash\r\njq -c &#39;.components| .[] | select( .status | contains(&quot;DOWN&quot;)) .details.description&#39; | head -1\r\n```\r\n\r\nHow can I get the name (key) of component? (&quot;Configuration converted&quot;)",
        "link": "https://stackoverflow.com/questions/63635568/with-jq-how-to-get-the-name-of-the-parent-element-that-contains-down",
        "title": "With jq how to get the name of the parent element that contains &quot;DOWN&quot;?"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1092869,
                    "reputation": 21464,
                    "user_id": 1087119,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://i.sstatic.net/CMEVE.png?s=256",
                    "display_name": "Christian Fritz",
                    "link": "https://stackoverflow.com/users/1087119/christian-fritz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598625226,
                "post_id": 63635682,
                "comment_id": 112528818,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1598625178,
                "creation_date": 1598625178,
                "answer_id": 63635833,
                "question_id": 63635682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Delete all lines which ends with `&quot;&quot;`:\r\n\r\n    sed -r &#39;/&quot;&quot;$/d&#39; test.json",
                "title": "jq: Remove keys with empty string values"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1598626962,
                "last_edit_date": 1598626962,
                "creation_date": 1598625415,
                "answer_id": 63635908,
                "question_id": 63635682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do below, to select values that are not _empty_ using `with_entries(expr)`, with the _expr_ being the condition that excludes the empty fields.\r\n\r\nAlso use the `.value` field again to remove the string that matches the regex containing the port string.\r\n\r\n    jq &#39;.data |= map(with_entries(select(.value != &quot;&quot;) | .value |= sub(&quot;:[0-9][0-9]$&quot;; &quot;&quot;)))&#39;\r\n\r\n[jqplay - Online demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/IPIqtH9fDR",
                "title": "jq: Remove keys with empty string values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1598647222,
        "creation_date": 1598624574,
        "last_edit_date": 1598647222,
        "question_id": 63635682,
        "body_markdown": "I have the following JSON:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 1&quot;,\r\n      &quot;{#ID}&quot;: &quot;1&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.2:80&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 2&quot;,\r\n      &quot;{#ID}&quot;: &quot;2&quot;,\r\n      &quot;{#IP}&quot;: &quot;&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 3&quot;,\r\n      &quot;{#ID}&quot;: &quot;3&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.3:80&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 4&quot;,\r\n      &quot;{#ID}&quot;: &quot;4&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.4:80&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 5&quot;,\r\n      &quot;{#ID}&quot;: &quot;5&quot;,\r\n      &quot;{#IP}&quot;: &quot;&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n``` \r\n\r\nBut I want to return:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 1&quot;,\r\n      &quot;{#ID}&quot;: &quot;1&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.2&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 2&quot;,\r\n      &quot;{#ID}&quot;: &quot;2&quot;,\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 3&quot;,\r\n      &quot;{#ID}&quot;: &quot;3&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.3&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 4&quot;,\r\n      &quot;{#ID}&quot;: &quot;4&quot;,\r\n      &quot;{#IP}&quot;: &quot;192.168.1.4&quot;\r\n    },\r\n    {\r\n      &quot;{#NAME}&quot;: &quot;Test 5&quot;,\r\n      &quot;{#ID}&quot;: &quot;5&quot;,\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nI&#39;m very new to using JQ and not sure how I can go about doing this. I read through this [issue page on GitHub][1] but none of the example seem to work for me.\r\n\r\nI also need to remove the port number and colon. Is that possible?\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/104",
        "link": "https://stackoverflow.com/questions/63635682/jq-remove-keys-with-empty-string-values",
        "title": "jq: Remove keys with empty string values"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1598665168,
                "creation_date": 1598665168,
                "answer_id": 63642648,
                "question_id": 63641481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "While I won&#39;t go so far as to say this _cannot_ be done, not only am I not aware of any straightforward way of doing so, I think it would be extremely challenging to do at all for the following reasons:\r\n\r\n1. It&#39;s hard to reliable identify that a command is outputting JSON. Many things might look like JSON but not be intended to be JSON. A command might output something that looks like JSON in large part but that isn&#39;t entirely JSON.\r\n\r\n2. It&#39;s impossible to know if a long-running command is outputting valid JSON until it has finished. This gives a dilemma of what to do in the interim - wait for it to finish, potentially indefinitely (especially if it&#39;s waiting for your input!) or find some way to roll-back the output if it turns out we guessed wrong.\r\n\r\n3. It&#39;s hard to predict up-front if a command is going to return JSON. As in your example, you can&#39;t tell what the remote server is going to return from a curl command.\r\n\r\n4. It&#39;s unclear what&#39;s the &quot;right&quot; thing to do for non-trivial commands, such as invoking shell functions or pipelines or applying redirections, or for programs such as text editors that use advanced control codes for redrawing the screen.\r\n\r\nFor these reasons, I think if this is possible it would require quite an advanced shell that captures the output of all commands the user executes, analyses and formats that output continuously, and has the capability to roll-back and reformat (or unformat) the output if it realises the output is incompatible with its method of display. I think that would be pretty interesting to see but I&#39;m not aware of such a shell.",
                "title": "How to always have json output show up nicely formatted using jq without appending the jq command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598670003,
                "last_edit_date": 1598670003,
                "creation_date": 1598668774,
                "answer_id": 63642894,
                "question_id": 63641481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could start with a simple script, e.g.\r\n```bash\r\n$ cat curljq\r\n#!/bin/bash\r\ncurl &quot;$@&quot; | jq .\r\n```\r\n```bash\r\n$ chmod +x curljq\r\n$ ./curljq -Ss -H &quot;Accept: application/json&quot; https://reqbin.com/echo/get/json\r\n{\r\n  &quot;success&quot;: &quot;true&quot;\r\n}\r\n```",
                "title": "How to always have json output show up nicely formatted using jq without appending the jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1598670003,
        "creation_date": 1598652774,
        "question_id": 63641481,
        "body_markdown": "I just installed jq on Ubuntu 18.04 and It is really nicely formatted when making curl calls. I am wondering if there is a way to always have my terminal(s) output JSON data nicely formatted without having to append the ```| jq .``` command to the end of it? I am familiar with setting up aliases in my ```.zshrc``` file but there is no single command I would use this for so not sure how to make this happen.\r\n\r\nDummy command I ran \r\n\r\n    curl -X GET localhost:3000/products | jq .\r\n\r\nI want the jq command to always be in effect when returning json to from the CLI.\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/63641481/how-to-always-have-json-output-show-up-nicely-formatted-using-jq-without-appendi",
        "title": "How to always have json output show up nicely formatted using jq without appending the jq command"
    },
    {
        "tags": [
            "jq",
            "xargs"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1598661733,
                "last_edit_date": 1598661733,
                "creation_date": 1598661114,
                "answer_id": 63642370,
                "question_id": 63642265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have various options. To add a separator as you describe, simply add it into your shell command: `; printf &#39;---\\n&#39;`\r\n\r\n```\r\ncat /tmp/ip_addresses |  xargs -I {} sh -c &quot;aws ec2 describe-instances --filter Name=private-ip-address,Values={} | jq &#39;.Reservations[].Instances[].SecurityGroups[]&#39;; printf &#39;---\\n&#39;&quot;\r\n```\r\n\r\nOr you could output a more structured object from the jq query: `.Reservations[].Instances[]|{InstanceId,SecurityGroups}`\r\n\r\n```\r\ncat /tmp/ip_addresses |  xargs -I {} sh -c &quot;aws ec2 describe-instances --filter Name=private-ip-address,Values={} | jq &#39;.Reservations[].Instances[]|{InstanceId,SecurityGroups}&#39;&quot;\r\n```\r\n\r\nI don&#39;t have access to AWS to check but that should get you one object for each instance with only two fields - the InstanceId and the array of SecurityGroups.\r\n\r\nLastly if you want to output one object per security group but still label them with InstanceId you can do: `.Reservations[].Instances[]|{InstanceId,SecurityGroup:.SecurityGroups[]}`\r\n\r\n```\r\ncat /tmp/ip_addresses | xargs -I {} sh -c &quot;aws ec2 describe-instances --filter Name=private-ip-address,Values={} | jq &#39;.Reservations[].Instances[]|{InstanceId,SecurityGroup:.SecurityGroups[]}&#39;&quot;\r\n```",
                "title": "print out a separator in between different outputs for a piped xargs command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598661733,
        "creation_date": 1598660152,
        "question_id": 63642265,
        "body_markdown": "I am checking properties of each output (in this case, `SecurityGroups` field of `aws ec2 describe-instances` command) from multiple outputs generated by piping into `xargs`, like so:\r\n\r\n    cat /tmp/ip_addresses |  xargs -I {} sh -c &quot;aws ec2 describe-instances --filter Name=private-ip-address,Values={} | jq &#39;.Reservations[].Instances[].SecurityGroups[]&#39;&quot;\r\n\r\nAn example output from one `aws ec2 describe-instance` call can be something like this:\r\n\r\n    {\r\n      &quot;ImageId&quot;: &quot;ami-0d093cc932863f7a9&quot;,\r\n      &quot;InstanceId&quot;: &quot;i-0b0bcbf0b766504ea&quot;,\r\n      ...\r\n      &quot;IamInstanceProfile&quot;: {\r\n        &quot;Arn&quot;: &quot;arn:aws:iam::blahblah&quot;,\r\n        &quot;Id&quot;: &quot;AIPAJ4P46HO5Z322JQHWA&quot;\r\n      },\r\n      ...,\r\n      &quot;SecurityGroups&quot;: [\r\n        {\r\n          &quot;GroupName&quot;: &quot;usw2-staging-zookeeper-serv&quot;,\r\n          &quot;GroupId&quot;: &quot;sg-da9361a1&quot;\r\n        }\r\n      ],\r\n      ...\r\n    }\r\n\r\nSome instances have more than 1 security group, and the outputs are not clearly separate by anything. So for 25 instances I got 28 security group objects. This makes it hard for me to distinguish which security group(s) is for which instance. Is it possible to print out a separator between each `xargs` output like a horizontal line so that I can easily tell which output(s) map to which instance?",
        "link": "https://stackoverflow.com/questions/63642265/print-out-a-separator-in-between-different-outputs-for-a-piped-xargs-command",
        "title": "print out a separator in between different outputs for a piped xargs command"
    },
    {
        "tags": [
            "arrays",
            "bash",
            "for-loop",
            "error-handling",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598687076,
                "post_id": 63644576,
                "comment_id": 112544864,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598687172,
                "post_id": 63644576,
                "comment_id": 112544889,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1598687211,
                "post_id": 63644576,
                "comment_id": 112544894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598688124,
                "post_id": 63644576,
                "comment_id": 112545075,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598688545,
                "post_id": 63644576,
                "comment_id": 112545159,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598688585,
                "post_id": 63644576,
                "comment_id": 112545167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598688681,
                "post_id": 63644576,
                "comment_id": 112545192,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598688797,
                "post_id": 63644576,
                "comment_id": 112545216,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598689045,
                "post_id": 63644576,
                "comment_id": 112545267,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598689779,
                "creation_date": 1598689779,
                "answer_id": 63644965,
                "question_id": 63644576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using files such as jq_filter_start.txt and jq_filter_end.txt to hold fragments of programs is almost certainly a bad idea (in general) for a wide variety of reasons, not least that it leads to the sort of errors displayed in the question. With that caveat in mind, let&#39;s consider one way to fix &quot;Case 2&quot;.\r\n\r\nSince the fix I have in mind is easier than explaining the problems you&#39;ve run into, I&#39;ll focus on the former.  \r\n\r\nThe fix can be accomplished by taking these three steps:\r\n\r\n1. omit the leading `&#39;` in jq_filter_start.txt; \r\n\r\n2. omit the trailing `&#39;` in jq_filter_end.txt;\r\n\r\n3. change the invocation of jq to:\r\n```\r\njq -r --arg search_param &quot;$i&quot; &quot;$jq_filter_start \\$search_param $jq_filter_end&quot; &quot;$dc1&quot;\r\n```\r\n\r\nThe point is that the jq program, when presented on the command line, has to be presented as a single &quot;string&quot;.\r\n\r\nBut rather than dwelling further on these best-avoided paths, it might make sense to refocus attention on the actual problem that&#39;s prompting these explorations.",
                "title": "bash - call of jq generates syntax errors and INVALID_CHARACTER messages"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598949844,
                "last_edit_date": 1598949844,
                "creation_date": 1598735488,
                "answer_id": 63651822,
                "question_id": 63644576,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Whether or not you use the -f command-line option is really a tangential matter here.\r\n\r\nYou could, for example, avoid fiddling with program fragments by performing the iteration within jq, e.g.:\r\n\r\n    jq -r &#39;(&quot;CronJobName&quot;, &quot;CronJobResult&quot;) as $search_param\r\n      | [.[] | select( .Body.values)]\r\n      | [.[] | select (all(.Body.values[]; .name != $search_param ) )]\r\n      | .[].Header.Tenant&#39; &quot;$dc1&quot;\r\n\r\nor if you want the search parameter values to be provided externally:\r\n    \r\n    jq -r --argjson search_params &#39;[&quot;CronJobName&quot;, &quot;CronJobResult&quot;]&#39; jq &#39;\r\n      $search_params[] as $search_param\r\n      | [.[] | select ( .Body.values)]\r\n      | [.[] | select (all(.Body.values[]; .name != $search_param ) )]\r\n      | .[].Header.Tenant&#39; &quot;$dc1&quot;\r\n\r\nPlease also note that if you wish to parameterize some jq code such as `.foo.bar`, you can either use a form such as .[$FOOSTRING][$BARSTRING] or getpath($ARRAY) so you can pass in the parameters programmatically.\r\n\r\nYou may also want to take advantage of jq&#39;s support for user-defined functions.\r\n   \r\n",
                "title": "bash - call of jq generates syntax errors and INVALID_CHARACTER messages"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1598949844,
        "creation_date": 1598686408,
        "last_edit_date": 1598689119,
        "question_id": 63644576,
        "body_markdown": "I am trying to understand why my script is choking when jq is called. \r\n\r\nHere is the code. I called jq in three different ways and only the first option below works.\r\n\r\n```\r\n#define vars\r\njq_filter_filename_start=&quot;jq_filter_start.txt&quot;\r\njq_filter_filename_end=&quot;jq_filter_end.txt&quot;\r\ncheck_config_list=&quot;CronJobName CronJobResult&quot;\r\ndc1=&quot;test.json&quot;\r\njq_filter_start=$(&lt;&quot;$jq_filter_filename_start&quot;)\r\njq_filter_end=$(&lt;&quot;$jq_filter_filename_end&quot;)\r\n\r\n# now Filter resulting json for missing properties\r\n    \r\n#case 1 - works without using bash vars\r\nfor i in $check_config_list; do\r\n    jq -r --arg search_param &quot;$i&quot; &#39;[.[] | select ( .Body.values)] | [.[] | select (all(.Body.values[]; .name != $search_param ) )] | .[].Header.Tenant&#39; &quot;$dc1&quot;\r\n    done\r\n\r\n#case 2 - does not work when using vars and calling jq directly\r\nfor i in $check_config_list; do\r\n    jq -r --arg search_param &quot;$i&quot; &quot;$jq_filter_start&quot; $search_param &quot;$jq_filter_end&quot; &quot;$dc1&quot;\r\n    done\r\n\r\n#case 3 - does not work when putting everything in an array\r\nfor i in $check_config_list; do\r\n    jqcommand=(jq -r &quot;$jq_filter_start&quot; \\&quot;&quot;$i&quot;\\&quot; &quot;$jq_filter_end&quot; &quot;$dc1&quot;)\r\n    ${jqcommand[@]}\r\n    done\r\n```\r\n\r\nHere is the content of the ``jq_filter_start.txt`` and ``jq_filter_end.txt`` files - as you can guess - it is beginning and the end of jq filter:\r\n```\r\n&#39;[.[] | select ( .Body.values)] | [.[] | select (all(.Body.values[]; .name !=\r\n```\r\n```\r\n) )] | .[].Header.Tenant&#39;\r\n```\r\n\r\nCould you please explain why I am getting the following output for both case 2 and case 3? \r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&#39;[.[] | select ( .Body.values)] | [.[] | select (all(.Body.values[]; .name !=\r\njq: 1 compile error\r\n```\r\n\r\nI want to break down jq&#39;s filters and dynamically store them either at vars or at files and join them when necessary, as outlined above. \r\n\r\nMy jq filters starting to getting quite long and complex, one such example\r\n```\r\n[.[] | select ( .Body.extensions ) ] | [.[] | select ( (.Header.Tenant | test(&quot;^(?![a-z]{3}-[a-z][a-z1-9]{2}-p[1-9]$)[a-zA-Z0-9.,-]+$&quot;)) and (.Header.ProductType | test(&quot;Product&quot;)))] | .[].Header.Tenant\r\n```\r\nIn the above example, I need to have an option to use vars in place of ``.Body.extensions`` and inside the ``test()`` conditions. \r\n\r\nThat&#39;s why I tried to use bash vars but seems I am missing something...\r\n\r\nP.S. Example JSON below. The purpose of this script is to go thru the ``CronJobName CronJobResult`` and other parameters defined in the ``check_config_list`` to identify all these Tenants which are missing one or more such parameters.\r\n\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;mytenant&quot;\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [                \r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-0c0c-07a3a4decaa6&quot;,\r\n                    &quot;name&quot;: &quot;Currency&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-0c0c-9390805c3b09&quot;,\r\n                    &quot;name&quot;: &quot;CronJobName&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/63644576/bash-call-of-jq-generates-syntax-errors-and-invalid-character-messages",
        "title": "bash - call of jq generates syntax errors and INVALID_CHARACTER messages"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598721019,
                "post_id": 63649672,
                "comment_id": 112553742,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2405989,
                    "reputation": 14070,
                    "user_id": 2102457,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/4e8y0.jpg?s=256",
                    "display_name": "mattst",
                    "link": "https://stackoverflow.com/users/2102457/mattst"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598721099,
                "post_id": 63649672,
                "comment_id": 112553755,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598772000,
                "last_edit_date": 1598772000,
                "creation_date": 1598722535,
                "answer_id": 63649945,
                "question_id": 63649672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use the `split` command and write a little shell script around it:\r\n\r\n    #!/bin/bash\r\n    input_file=ids.txt\r\n    temp_dir=splits\r\n    api_limit=10000\r\n    \r\n    # Make sure that there are no leftovers from previous runs\r\n    rm -rf &quot;${temp_dir}&quot;\r\n    # Create temporary folder for splitting the file\r\n    mkdir &quot;${temp_dir}&quot;\r\n    # Split the input file based on the api limit\r\n    split --lines &quot;${api_limit}&quot; &quot;${input_file}&quot; &quot;${temp_dir}/&quot;\r\n    \r\n    # Iterate through splits and make an api call per split\r\n    for split in &quot;${temp_dir}&quot;/* ; do\r\n        jq -Rsn &#39;\r\n            {&quot;id&quot;:\r\n              [inputs\r\n                | . / &quot;\\n&quot;\r\n                | (.[] | select(length &gt; 0) | . / &quot;;&quot;) as $input\r\n                | $input[0]]\r\n            }&#39; &quot;${split}&quot; &gt; api_payload.json\r\n    \r\n        # now do something ...\r\n        # curl -dapi_payload.json http://...\r\n    \r\n        rm -f api_payload.json\r\n    done\r\n    \r\n    # Clean up\r\n    rm -rf &quot;${temp_dir}&quot;\r\n",
                "title": "Bash: Loop Read N lines at time from CSV"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598801992,
                "last_edit_date": 1598801992,
                "creation_date": 1598752199,
                "answer_id": 63653268,
                "question_id": 63649672,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a simple and efficient solution that at its core just uses jq.  It takes advantage of the -c command-line option.  I&#39;ve used `xargs printf ...` for illustration - mainly to show how easy it is to set up a shell pipeline.\r\n```\r\n&lt; data.txt jq -Rnc &#39;\r\n  def batch($n; stream):\r\n    def b: [limit($n; stream)]\r\n    | select(length &gt; 0)\r\n    | (., b);\r\n    b;\r\n\r\n  {id: batch(10000; inputs | select(length&gt;0) | (. / &quot;;&quot;)[0])}\r\n&#39; | xargs printf &quot;%s\\n&quot;\r\n```\r\n\r\n### Parameterizing batch size\r\n\r\nIt might make sense to set things up so that the batch size is specified outside the jq program.  This could be done in numerous ways, e.g. by invoking jq along the lines of:\r\n\r\n    jq --argjson n 10000 ....\r\n\r\nand of course using `$n` instead of 10000 in the jq program.\r\n \r\n### Why “def b:”?\r\nFor efficiency.  jq’s TCO (tail recursion optimization) only works for arity-0 filters.\r\n\r\n### Note on -s\r\n\r\nIn the Q as originally posted, the command-line options -sn are used in conjunction with `inputs`.  Using -s with `inputs` defeats the whole purpose of `inputs`, which is to make it possible to process input in a stream-oriented way (i.e. one line of input or one JSON entity at a time).\r\n\r\n",
                "title": "Bash: Loop Read N lines at time from CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1598801992,
        "creation_date": 1598720666,
        "question_id": 63649672,
        "body_markdown": "I have a csv file of 100000 ids\r\n\r\n    wef7efwe1fwe8\r\n    wef7efwe1fwe3\r\n    ewefwefwfwgrwergrgr\r\n\r\nthat are being transformed into a json object using jq\r\n\r\n    output=$(jq -Rsn &#39;\r\n    {&quot;id&quot;:\r\n      [inputs\r\n        | . / &quot;\\n&quot;\r\n        | (.[] | select(length &gt; 0) | . / &quot;;&quot;) as $input\r\n        | $input[0]]}\r\n    &#39; &lt;$FILE)\r\n\r\n\r\noutput\r\n\r\n    {\r\n      &quot;id&quot;: [\r\n             &quot;wef7efwe1fwe8&quot;,\r\n             &quot;wef7efwe1fwe3&quot;,\r\n             ....\r\n       ]\r\n    }\r\n\r\ncurrently, I need to manually split the file into smaller 10000 line files... because the API call has a limit.\r\n\r\nI would like a way to automatically loop through the large file... and only use 10000 lines as a time as $FILE... up until the end of the list.",
        "link": "https://stackoverflow.com/questions/63649672/bash-loop-read-n-lines-at-time-from-csv",
        "title": "Bash: Loop Read N lines at time from CSV"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598756193,
                "last_edit_date": 1598756193,
                "creation_date": 1598753465,
                "answer_id": 63653352,
                "question_id": 63653321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this particular case, the &quot;output&quot; as originally shown is a valid jq program, so to convert it to JSON, you could simply provide it to the jq processor as a program, e.g.:\r\n```\r\njq -n &#39;{ currentBlock: 4479441, highestBlock: 7063981, knownStates: 15306625, pulledStates: 15306625, startingBlock: 0 }&#39;\r\n```\r\n## Output\r\n```\r\n{\r\n  &quot;currentBlock&quot;: 4479441,\r\n  &quot;highestBlock&quot;: 7063981,\r\n  &quot;knownStates&quot;: 15306625,\r\n  &quot;pulledStates&quot;: 15306625,\r\n  &quot;startingBlock&quot;: 0\r\n}\r\n```\r\n\r\n### Using the -f option\r\nIf the quasi-JSON is in a file, say data.txt, then you could simply run:\r\n\r\n    jq -n -f data.txt\r\n\r\n### Caveats\r\nThis approach will only work if the text happens to be valid as a jq program.  In particular, it won&#39;t work if any of the keys is an unquoted jq keyword, or does not match the regex:\r\n\r\n    ^[A-Za-z_][A-Za-z0-9_]*$",
                "title": "command output give object string how to convert it to json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598756493,
                "last_edit_date": 1598756493,
                "creation_date": 1598753982,
                "answer_id": 63653387,
                "question_id": 63653321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A generic solution would be to use a tool such as [tag:hjson]:\r\n\r\n```\r\n$ echo &#39;{ currentBlock: 4479441, highestBlock: 7063981, knownStates: 15306625, pulledStates: 15306625, startingBlock: 0 }&#39; |\r\n    hjson -j\r\n{\r\n  &quot;currentBlock&quot;: 4479441,\r\n  &quot;highestBlock&quot;: 7063981,\r\n  &quot;knownStates&quot;: 15306625,\r\n  &quot;pulledStates&quot;: 15306625,\r\n  &quot;startingBlock&quot;: 0\r\n}\r\n```",
                "title": "command output give object string how to convert it to json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598756413,
                "last_edit_date": 1598756413,
                "creation_date": 1598755940,
                "answer_id": 63653532,
                "question_id": 63653321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the issue here is that the quasi-JSON contains literal &quot;\\n&quot; strings, then you could perhaps remove them using `sed &#39;s/\\\\n//g&#39;`:\r\n\r\n    $ output=&#39;{\\n currentBlock: 4769045,\\n highestBlock: 7063981,\\n knownStates: 15306625,\\n pulledStates: 15306625,\\n startingBlock: 0\\n}&#39;\r\n\r\n    $ jq -n -f &lt;(sed &#39;s/\\\\n//g&#39; &lt;&lt;&lt; &quot;$output&quot;)\r\n\r\nAnother possibility might be to use `printf`, e.g.\r\n\r\n    $ printf &quot;$output&quot; &quot;&quot; | hjson -j\r\n\r\nBoth yield valid JSON.\r\n\r\n",
                "title": "command output give object string how to convert it to json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1598758554,
        "creation_date": 1598753024,
        "last_edit_date": 1598758554,
        "question_id": 63653321,
        "body_markdown": "a command gives the following output which is arranged in an object, how to convert it to json using jq?\r\n \r\n\r\n```\r\n{\\n  currentBlock: 4769045,\\n  highestBlock: 7063981,\\n  knownStates: 15306625,\\n  pulledStates: 15306625,\\n  startingBlock: 0\\n}\r\n```\r\nN.B the output isn&#39;t json; it contains `\\n` strings. \r\n\r\ni used the following to convert it \r\n\r\n    echo &quot;$output&quot; | jq -R -s -c &#39;split(&quot;\\n&quot;)&#39; \r\n\r\nbut the output wasn&#39;t as i expect it \r\n\r\n[&quot;{&quot;,&quot;  currentBlock: 4787477,&quot;,&quot;  highestBlock: 7063981,&quot;,&quot;  knownStates: 15306625,&quot;,&quot;  pulledStates: 15306625,&quot;,&quot;  startingBlock: 0&quot;,&quot;}&quot;,&quot;&quot;]\r\n",
        "link": "https://stackoverflow.com/questions/63653321/command-output-give-object-string-how-to-convert-it-to-json-using-jq",
        "title": "command output give object string how to convert it to json using jq"
    },
    {
        "tags": [
            "arrays",
            "sorting",
            "search",
            "replace",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598758898,
                "last_edit_date": 1598758898,
                "creation_date": 1598758368,
                "answer_id": 63653697,
                "question_id": 63653577,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`@csv` is guaranteed to produce CSV, but if you want strings to be presented unconditionally without the surrounding quotation marks, you could consider using `join(&quot;, &quot;)` instead of `@csv`. Since you indicated you&#39;re open to some other value-separator, you might also wish to consider `@tsv`.\r\n\r\nThe redundancy in the jq program can also be reduced, so you might end up with:\r\n\r\n```\r\n.[] \r\n| (.Header     | [.Tenant, .Stage, .ProductType]) + \r\n  (.Body.error | [.message, .code ])\r\n| @tsv\r\n```",
                "title": "Jq - print in one line values from different keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598758898,
        "creation_date": 1598756627,
        "question_id": 63653577,
        "body_markdown": "Sample Json file:\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;Test-d1&quot;,\r\n            &quot;Stage&quot;: &quot;dev&quot;,\r\n            &quot;ProductType&quot;: &quot;b2b&quot;,\r\n            &quot;Rcode&quot;: 401\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;error&quot;: {\r\n                &quot;code&quot;: 401,\r\n                &quot;message&quot;: &quot;Unsupported authorization scheme&quot;\r\n            }\r\n        }\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;2734d7ac0f0e&quot;,\r\n            &quot;Stage&quot;: &quot;unknown&quot;,\r\n            &quot;ProductType&quot;: &quot;unknown&quot;,\r\n            &quot;Rcode&quot;: 404\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;error&quot;: {\r\n                &quot;code&quot;: 404,\r\n                &quot;message&quot;: &quot;Not found&quot;\r\n            }\r\n        }\r\n    }\r\n]\r\n```\r\nDesired output:\r\n\r\n```\r\nTest-d1, dev, b2b, Unsupported authorization scheme, 401\r\n2734d7ac0f0e, unknown, unknown, Not found, 404\r\n```\r\nSo skip the keys, interested only with certain values and form a single line, separate them by commas or semicolumn or some other separator.\r\n\r\nThe simplest procedure I could imagine with jq was to put values into an array and use @csv\r\n```\r\njq  -r .[] | [ .Header.Tenant, .Header.Stage, .Header.ProductType, .Body.error.message, .Body.error.code ] | @csv\r\n```\r\n\r\nAbove *almost* does what I wanted, but encloses every value with double-quotes. I can deal with double-quotes using some other tools but I&#39;m sure it should be possible within jq itself.\r\n\r\nWhat are alternative approaches using jq?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63653577/jq-print-in-one-line-values-from-different-keys",
        "title": "Jq - print in one line values from different keys"
    },
    {
        "tags": [
            "string",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1703806,
                    "reputation": 1524,
                    "user_id": 1563297,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ba6aac14f927054dd9892356c4589543?s=256&d=identicon&r=PG",
                    "display_name": "Sergio Santiago",
                    "link": "https://stackoverflow.com/users/1563297/sergio-santiago"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1598825830,
                "post_id": 63662634,
                "comment_id": 112575931,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598829918,
                "last_edit_date": 1598829918,
                "creation_date": 1598828267,
                "answer_id": 63662900,
                "question_id": 63662634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Download the JSON from Rapid7 OpenData\r\n\r\n    $ wget https://opendata.rapid7.com/sonar.https/2020-07-26-1595771130-https_get_50880.json.gz\r\n\r\n### Extract &#39;ip&#39; and &#39;port&#39; fields\r\n\r\n    $ zcat 2020-07-26-1595771130-https_get_50880.json.gz | jq &#39;.ip,.port&#39; | head\r\n    &quot;73.71.198.224&quot;\r\n    50880\r\n    &quot;3.228.14.207&quot;\r\n    50880\r\n    &quot;175.139.245.229&quot;\r\n    50880\r\n    &quot;162.208.16.163&quot;\r\n    50880\r\n    &quot;58.58.213.88&quot;\r\n    50880\r\n\r\n### Extract fields in the form &#39;ip:port&#39;\r\n\r\n    zcat 2020-07-26-1595771130-https_get_50880.json.gz | jq -r &#39;&quot;\\(.ip):\\(.port)&quot;&#39; | head\r\n    73.71.198.224:50880\r\n    3.228.14.207:50880\r\n    175.139.245.229:50880\r\n    162.208.16.163:50880\r\n    58.58.213.88:50880\r\n    18.130.113.90:50880\r\n    54.216.22.17:50880\r\n    15.236.60.123:50880\r\n    77.54.234.109:50880\r\n    71.37.173.187:50880\r\n\r\nThanks to [@peak][1] for the improvement!\r\n\r\n\r\n  [1]: https://stackoverflow.com/users/997358/peak",
                "title": "Extracting some strings with jq from Rapid7 OpenData website"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1598829918,
        "creation_date": 1598825504,
        "question_id": 63662634,
        "body_markdown": "I was wondering if someone had an idea how to extract with &#39;jq&#39; the following strings; &#39;ip, port&#39; from the input files available on Rapid7 opendata website:\r\n\r\n[Rapid7 OpenData website][1]\r\n\r\n\r\n  [1]: https://opendata.rapid7.com/sonar.https/\r\n\r\nAny help would be very appreciated,\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63662634/extracting-some-strings-with-jq-from-rapid7-opendata-website",
        "title": "Extracting some strings with jq from Rapid7 OpenData website"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1598859219,
                "post_id": 63666491,
                "comment_id": 112582919,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598860048,
                "post_id": 63666491,
                "comment_id": 112583263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598861686,
                "post_id": 63666491,
                "comment_id": 112583940,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598865507,
                "post_id": 63666491,
                "comment_id": 112585650,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598866477,
                "post_id": 63666491,
                "comment_id": 112586124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5723949,
                    "reputation": 73,
                    "user_id": 4521546,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b3c675334f9ac9ef9966e722120f6895?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nanoticket",
                    "link": "https://stackoverflow.com/users/4521546/nanoticket"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1598872516,
                "post_id": 63666491,
                "comment_id": 112588691,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598882452,
                "creation_date": 1598882452,
                "answer_id": 63672257,
                "question_id": 63666491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "     map({ username,\r\n           value: first(.attributes[]\r\n                        | select(.name == &quot;attr1&quot;)\r\n                        | .value) })",
                "title": "Making an array of objects from json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598882452,
        "creation_date": 1598858696,
        "last_edit_date": 1598864833,
        "question_id": 63666491,
        "body_markdown": "```\r\n[\r\n  {\r\n    &quot;username&quot;: &quot;new&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;attr1&quot;,\r\n        &quot;value&quot;: &quot;value1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;attr2&quot;,\r\n        &quot;value&quot;: &quot;value2&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;username&quot;: &quot;new2&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;attr2&quot;,\r\n        &quot;value&quot;: &quot;value3&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;attr1&quot;,\r\n        &quot;value&quot;: &quot;value4&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nI have a json as above. From this json, I would like to get the following:\r\n```\r\n[\r\n  {\r\n    &quot;username&quot;: &quot;new&quot;,\r\n    &quot;value&quot;: &quot;value1&quot;\r\n  },\r\n  {\r\n    &quot;username&quot;: &quot;new2&quot;,\r\n    &quot;value&quot;: &quot;value4&quot;\r\n  }\r\n]\r\n```\r\nThe value I want to have in this object is the value for attribute named attr1. How I can achieve this with jq?\r\n\r\nEdit: Fixed errors in the qn. I have tried \r\n```\r\necho $USERS | jq [&#39;.[] | {username:username, value: jq &#39;.attributes[]  | select(.name == &quot;attr1&quot;) | .value&#39;}&#39;];\r\n```\r\nwhere $USERS contains the json data",
        "link": "https://stackoverflow.com/questions/63666491/making-an-array-of-objects-from-json-using-jq",
        "title": "Making an array of objects from json using jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "datetime-format"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598896980,
                "last_edit_date": 1598896980,
                "creation_date": 1598896514,
                "answer_id": 63675833,
                "question_id": 63671299,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `todateiso8601` to convert the epoch time to an iso date string.\r\n\r\n```\r\n$ &lt;&lt;&lt; &#39;1595602422.013&#39; jq &#39;todateiso8601&#39;\r\n&quot;2020-07-24T14:53:42Z&quot;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/lV7QRakEAI)\r\n\r\n```\r\n$ ... | jq -r &#39;.tasks[] | .taskArn, (.createdAt | todateiso8601), .taskDefinitionArn&#39;\r\narn:aws:ecs:eu-west-1:871479025269:task/ABC/1a9a276e0a044d3d337ff954cfa6b1f36bc66\r\n2020-07-24T14:53:42Z\r\narn:aws:ecs:eu-west-1:87147922025269:task-definition/new:1\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/silDOj_whG)\r\n",
                "title": "jq command to convert epoch time"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598907056,
        "creation_date": 1598878761,
        "last_edit_date": 1598907056,
        "question_id": 63671299,
        "body_markdown": "I run the following AWS command using the `jq`, but it returns the time in epoch. \r\n\r\n```\r\n# aws ecs describe-tasks \\\r\n    --tasks arn:aws:ecs:eu-west-1:87147902d5269:task/ABC/1a9a276e0a0443d3d37ff954cfa6b1f36bc66 \\\r\n    --cluster arn:aws:ecs:eu-west-1:87147902d5269:cluster/CDE \\\r\n    | jq -r &#39;.tasks[]|.taskArn,.createdAt,.taskDefinitionArn&#39;\r\n```\r\n\r\n```\r\narn:aws:ecs:eu-west-1:871479025269:task/ABC/1a9a276e0a044d3d337ff954cfa6b1f36bc66\r\n1595602422.013\r\narn:aws:ecs:eu-west-1:87147922025269:task-definition/new:1\r\n```\r\n\r\nHow can I convert the epoch time into a date within the same command?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63671299/jq-command-to-convert-epoch-time",
        "title": "jq command to convert epoch time"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598883388,
                "creation_date": 1598883388,
                "answer_id": 63672528,
                "question_id": 63672380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close.\r\n\r\n    jq &#39;.saved_objects=(\r\n            .saved_objects[] |\r\n                select (.id != &quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot;\r\n                        and .id != &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;))\r\n        &#39; file.json",
                "title": "Remove key from json based on condition with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598907774,
                "last_edit_date": 1598907774,
                "creation_date": 1598905796,
                "answer_id": 63677772,
                "question_id": 63672380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the blacklist is quite long or should be passed as a parameter, the following approach is worth noting:\r\n\r\n```\r\n[&quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot;, &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;] as $blacklist\r\n| .saved_objects |= map(select(.id | IN($blacklist[]) | not))\r\n\r\n```\r\nOr even more succinctly:\r\n```\r\n[&quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot;, &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;] as $blacklist\r\n| del(.saved_objects[] | select(.id | IN($blacklist[])))\r\n```\r\nNote also the use of `|=` in the first approach above. ",
                "title": "Remove key from json based on condition with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598909360,
                "creation_date": 1598909360,
                "answer_id": 63678425,
                "question_id": 63672380,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "i&#39;m also tempted to publish a solution based on the different approach (`jtc`), only for awareness of the alternative:\r\n\r\n1\\. the ad-hoc solution would be to purge parents of each found element:\r\n```\r\nbash $ &lt;file.json jtc -pw&#39;&lt;f3ea5f20-e773-11ea-8cae-c1046c8b1215&gt;[-1]&#39; -w&#39;&lt;5c071f30-e797-11ea-8cae-c1046c8b1215&gt;[-1]&#39;\r\n{\r\n   &quot;page&quot;: 1,\r\n   &quot;per_page&quot;: 20,\r\n   &quot;saved_objects&quot;: [\r\n      {\r\n         &quot;id&quot;: &quot;644a15c0-e79d-11ea-8cae-c1046c8b1215&quot;,\r\n         &quot;type&quot;: &quot;dashboard&quot;\r\n      }\r\n   ],\r\n   &quot;total&quot;: 3\r\n}\r\nbash $ \r\n```\r\n\r\n2\\. possibly a more convenient approach, where the ids passed as a JSON array:\r\n```\r\nbash $ ids=&#39;[&quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;,&quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot;]&#39;\r\nbash $ &lt;file.json jtc -pw&#39;[id]:&lt;I&gt;P:[-1]&#39; -u&quot;$ids&quot; -u&#39;&lt;I&gt;s&#39;\r\n{\r\n   &quot;page&quot;: 1,\r\n   &quot;per_page&quot;: 20,\r\n   &quot;saved_objects&quot;: [\r\n      {\r\n         &quot;id&quot;: &quot;644a15c0-e79d-11ea-8cae-c1046c8b1215&quot;,\r\n         &quot;type&quot;: &quot;dashboard&quot;\r\n      }\r\n   ],\r\n   &quot;total&quot;: 3\r\n}\r\nbash $ \r\n```\r\n\r\nIf it&#39;s required to make update right into the source file (a.k.a _in-place update_), then use option `-f`, like this: `jtc -pw&#39;[id]:&lt;I&gt;P:[-1]&#39; -u$ids -u&#39;&lt;I&gt;s&#39; -f file.json`\r\n\r\n\r\nPS. It so happens that I am also a developer of the `jtc` unix tool\r\n",
                "title": "Remove key from json based on condition with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1598909360,
        "creation_date": 1598882912,
        "last_edit_date": 1598884536,
        "question_id": 63672380,
        "body_markdown": "I know there is lot of similar solutions, but no one match my case. I&#39;ve got this json:\r\n```\r\n{\r\n  &quot;page&quot;: 1,\r\n  &quot;per_page&quot;: 20,\r\n  &quot;total&quot;: 3,\r\n  &quot;saved_objects&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;dashboard&quot;,\r\n      &quot;id&quot;: &quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;dashboard&quot;,\r\n      &quot;id&quot;: &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;dashboard&quot;,\r\n      &quot;id&quot;: &quot;644a15c0-e79d-11ea-8cae-c1046c8b1215&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nand if id == &quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot; or id == &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot; I want to remove this keys, so output should be:\r\n```\r\n{\r\n  &quot;page&quot;: 1,\r\n  &quot;per_page&quot;: 20,\r\n  &quot;total&quot;: 3,\r\n  &quot;saved_objects&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;dashboard&quot;,\r\n      &quot;id&quot;: &quot;644a15c0-e79d-11ea-8cae-c1046c8b1215&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI tried:\r\n```\r\njq &#39;select(.saved_objects[].id != &quot;f3ea5f20-e773-11ea-8cae-c1046c8b1215&quot; and .saved_objects[].id != &quot;5c071f30-e797-11ea-8cae-c1046c8b1215&quot;)&#39;\r\n```\r\nand a lot of variations, but nothing worked. What am I doing wrong?\r\n\r\nThank you for help.",
        "link": "https://stackoverflow.com/questions/63672380/remove-key-from-json-based-on-condition-with-jq",
        "title": "Remove key from json based on condition with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1598915206,
                "creation_date": 1598915206,
                "answer_id": 63679301,
                "question_id": 63678557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "More succinct can be achieved by:\r\n\r\n    .changes |= map(select(.status != &quot;untracked&quot;))",
                "title": "jq: How to select within a nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1598957635,
        "creation_date": 1598910082,
        "last_edit_date": 1598957635,
        "question_id": 63678557,
        "body_markdown": "I am trying to select a sub-set of an object&#39;s children in `jq` while keeping the outer object.\r\n\r\n\r\nTake the example input:\r\n```\r\n{\r\n  &quot;head&quot;: &quot;master&quot;,\r\n  &quot;hash&quot;: &quot;ba2054c38ec68b73926acb24cd0bad61177a03d4&quot;,\r\n  &quot;upstream&quot;: &quot;origin/master&quot;,\r\n  &quot;ahead&quot;: 1,\r\n  &quot;behind&quot;: 0,\r\n  &quot;changes&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;exe/each-package&quot;,\r\n      &quot;status&quot;: &quot;updated_in_index&quot;,\r\n      &quot;work_tree_status&quot;: &quot;modified&quot;,\r\n      &quot;index_status&quot;: &quot;unmodified&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;exe/find-package&quot;,\r\n      &quot;status&quot;: &quot;not_updated&quot;,\r\n      &quot;work_tree_status&quot;: &quot;unmodified&quot;,\r\n      &quot;index_status&quot;: &quot;modified&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lib/tools/tool_support.rb&quot;,\r\n      &quot;status&quot;: &quot;not_updated&quot;,\r\n      &quot;work_tree_status&quot;: &quot;unmodified&quot;,\r\n      &quot;index_status&quot;: &quot;modified&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;curses.txt&quot;,\r\n      &quot;status&quot;: &quot;untracked&quot;,\r\n      &quot;work_tree_status&quot;: &quot;untracked&quot;,\r\n      &quot;index_status&quot;: &quot;untracked&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;exe/fat-stat&quot;,\r\n      &quot;status&quot;: &quot;untracked&quot;,\r\n      &quot;work_tree_status&quot;: &quot;untracked&quot;,\r\n      &quot;index_status&quot;: &quot;untracked&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;exe/prefix-each-with&quot;,\r\n      &quot;status&quot;: &quot;untracked&quot;,\r\n      &quot;work_tree_status&quot;: &quot;untracked&quot;,\r\n      &quot;index_status&quot;: &quot;untracked&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;notes.txt&quot;,\r\n      &quot;status&quot;: &quot;untracked&quot;,\r\n      &quot;work_tree_status&quot;: &quot;untracked&quot;,\r\n      &quot;index_status&quot;: &quot;untracked&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd the expected output where I have removed a subset of the `changes` member:\r\n\r\n```\r\n{\r\n  &quot;head&quot;: &quot;master&quot;,\r\n  &quot;hash&quot;: &quot;ba2054c38ec68b73926acb24cd0bad61177a03d4&quot;,\r\n  &quot;upstream&quot;: &quot;origin/master&quot;,\r\n  &quot;ahead&quot;: 1,\r\n  &quot;behind&quot;: 0,\r\n  &quot;changes&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;exe/each-package&quot;,\r\n      &quot;status&quot;: &quot;updated_in_index&quot;,\r\n      &quot;work_tree_status&quot;: &quot;modified&quot;,\r\n      &quot;index_status&quot;: &quot;unmodified&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;exe/find-package&quot;,\r\n      &quot;status&quot;: &quot;not_updated&quot;,\r\n      &quot;work_tree_status&quot;: &quot;unmodified&quot;,\r\n      &quot;index_status&quot;: &quot;modified&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;lib/tools/tool_support.rb&quot;,\r\n      &quot;status&quot;: &quot;not_updated&quot;,\r\n      &quot;work_tree_status&quot;: &quot;unmodified&quot;,\r\n      &quot;index_status&quot;: &quot;modified&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI was able to do it like the following. But I suspect there is a more succinct way to filter the innards of a nested array, perhaps removing the duplication.\r\n```\r\njq &#39;. + {changes: [.changes[] | select(.status != &quot;untracked&quot;)]}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/63678557/jq-how-to-select-within-a-nested-array",
        "title": "jq: How to select within a nested array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1598942165,
                "creation_date": 1598942165,
                "answer_id": 63682560,
                "question_id": 63682351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your string is a JSON-encoded object, but then that string is re-encoded using JSON again.\r\n\r\nSo you&#39;ll first need to find a way to decode the JSON, and output the result of that back into a new file.\r\n\r\nTo do this with jq:\r\n\r\n    jq -r input1.json &gt; input2.json\r\n\r\nNow your `input2.json` is a regular json file that you can normally execute jq commands on.",
                "title": "How to extract JSON object from JSON array using JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1598943383,
                "last_edit_date": 1598943383,
                "creation_date": 1598943075,
                "answer_id": 63682712,
                "question_id": 63682351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.[] | select(.state==&quot;Active&quot;) | .domain&#39; my.json\r\n\r\n\r\noutput: \r\n\r\n    domain.com\r\n    domain2.com\r\n    domain3.com",
                "title": "How to extract JSON object from JSON array using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1598956865,
                "last_edit_date": 1598956865,
                "creation_date": 1598950220,
                "answer_id": 63684349,
                "question_id": 63682351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @Inian pointed out, the key here is to use `fromjson`.  Putting it all together:\r\n\r\n    jq -r &#39;fromjson[] | select(.state==&quot;Active&quot;) | .domain&#39;",
                "title": "How to extract JSON object from JSON array using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1598956865,
        "creation_date": 1598940958,
        "question_id": 63682351,
        "body_markdown": "I have this kind of JSON:\r\n\r\n    &quot;[{\\&quot;domain\\&quot;: \\&quot;domain.com\\&quot;, \\&quot;adminEmail\\&quot;: \\&quot;test@example.com\\&quot;, \\&quot;ipAddress\\&quot;: \\&quot;1.1.1.1\\&quot;, \\&quot;admin\\&quot;: \\&quot;admin\\&quot;, \\&quot;package\\&quot;: \\&quot;Default\\&quot;, \\&quot;state\\&quot;: \\&quot;Active\\&quot;},{\\&quot;domain\\&quot;: \\&quot;domain2.com\\&quot;, \\&quot;adminEmail\\&quot;: \\&quot;test@example.com\\&quot;, \\&quot;ipAddress\\&quot;: \\&quot;8.8.8.8\\&quot;, \\&quot;admin\\&quot;: \\&quot;admin2\\&quot;, \\&quot;package\\&quot;: \\&quot;Default\\&quot;, \\&quot;state\\&quot;: \\&quot;Active\\&quot;},{\\&quot;domain\\&quot;: \\&quot;domain3.com\\&quot;, \\&quot;adminEmail\\&quot;: \\&quot;test@domain3.com\\&quot;, \\&quot;ipAddress\\&quot;: \\&quot;8.8.4.4\\&quot;, \\&quot;admin\\&quot;: \\&quot;admin3\\&quot;, \\&quot;package\\&quot;: \\&quot;Default\\&quot;, \\&quot;state\\&quot;: \\&quot;Active\\&quot;}]&quot;\r\n\r\nI want to extract a domain list that has the state &quot;Active&quot;.\r\n\r\nExample: \r\n\r\n    jq &#39;some command&#39; my.json\r\n\r\nWill print:\r\n\r\n    domain.com\r\n    domain2.com\r\n    domain3.com\r\n\r\nEvery command that I tried I get the same error:\r\n\r\n    jq: error (at test.json:1): Cannot iterate over string (&quot;[{\\&quot;domain...)\r\n\r\n\r\nThe JSON seems to be valid for me. One thing that I observed is python3 json.tool module can not print this JSON formatted. I do not know why.\r\n\r\nI am trying to avoid to create a script to read this JSON. I want some tool that can read from command line pipe and print the domains.",
        "link": "https://stackoverflow.com/questions/63682351/how-to-extract-json-object-from-json-array-using-jq",
        "title": "How to extract JSON object from JSON array using JQ"
    },
    {
        "tags": [
            "random",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599025551,
                "post_id": 63689970,
                "comment_id": 112641457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599026196,
                "post_id": 63689970,
                "comment_id": 112641665,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1599038133,
                "last_edit_date": 1599038133,
                "creation_date": 1599012101,
                "answer_id": 63697674,
                "question_id": 63689970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I cannot supply random value from bash, as it would be not random, but always the same.\r\n\r\nThat is a bit harsh.  The wikipedia article [&quot;List of random number generators&quot;][1] has two sections that give relevant listings: \r\n\r\n* Random number generators that use external entropy\r\n* Random number servers\r\n\r\nIf your requirements are not too stringent, you might find that several of these are sufficient for your purposes.  On a Linux or OSX system you might like to start with [/dev/random][2], e.g. in conjunction with [tag:od] or GNU shuf (sometimes available as gshuf):\r\n\r\n    shuf -i 0-1000 -n 1 --random-source=/dev/random\r\n\r\n(You will probably want to use -r (&quot;with replacement&quot;) if the value following -n is greater than 1.)\r\n\r\nIf you don&#39;t mind a web-based server, https://www.random.org/ has a bunch of services, e.g. you could start with this template:\r\n```\r\njq -n --argjson r $(curl -Ss &quot;https://www.random.org/integers/?num=1&amp;min=0&amp;max=100000&amp;col=1&amp;base=10&amp;format=plain&amp;rnd=new&quot;) &#39;\r\n  {random: $r}&#39;\r\n```\r\nRunning this just now produced:\r\n```\r\n{\r\n  &quot;random&quot;: 41051\r\n}\r\n```\r\n\r\nAnd running the exact same program a second time produced:\r\n```\r\n{\r\n  &quot;random&quot;: 7358\r\n}\r\n```\r\n## Example: .range=PLACEHOLDER\r\n\r\nSuppose the file data.json contains a stream of JSON objects:\r\n```\r\n{}\r\n{}\r\n{}\r\n```\r\n\r\nThen a run of the following bash commands produced the output as shown below:\r\n\r\n```\r\nn=$(stream | jq -n &#39;reduce inputs as $x (0; .+1)&#39;)\r\ngshuf -i 0-100 -r -n $n --random-source=/dev/random | \r\n  jq -cnR --slurpfile stream data.json &#39;$stream[] | .random=input&#39;\r\n```\r\nOutput:\r\n```\r\n{&quot;random&quot;:&quot;17&quot;}\r\n{&quot;random&quot;:&quot;69&quot;}\r\n{&quot;random&quot;:&quot;81&quot;}\r\n```\r\n\r\n\r\n  [1]: https://en.wikipedia.org/wiki/List_of_random_number_generators\r\n  [2]: https://en.wikipedia.org/wiki//dev/random",
                "title": "random/sequential numbers in JQ (or workaround)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1599035932,
                "last_edit_date": 1599035932,
                "creation_date": 1599015311,
                "answer_id": 63698029,
                "question_id": 63689970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Generating a fixed number of (sufficiently) random numbers to serve as input to jq is dealt with elsewhere on this page.  This response deals with the case when the jq program must have access to an unbounded (&quot;infinite&quot;) sequence of such numbers.\r\n\r\nConsider then this generator of an unbounded sequence of strings of &quot;random&quot; hexadecimal digits of length 8:\r\n\r\n    od -t x -An /dev/random | tr -d &quot; &quot; | fold -w 8 \r\n\r\n(On many systems, this produces a cryptographically secure stream.)\r\n\r\nThere are several ways to feed this into jq.  One is simply to use `input`, e.g.\r\n\r\n```\r\nod -t x -An /dev/random | tr -d &quot; &quot; | fold -w 8 |\r\n jq -nRc &#39;[range(0;5) | input]&#39;\r\n```\r\nproduced:\r\n```\r\n[&quot;54a4bdb9&quot;,&quot;13b6ed75&quot;,&quot;86bbe494&quot;,&quot;79b192f5&quot;,&quot;43f801c8&quot;]\r\n```\r\n\r\nIf the task of the jq program is to produce an unbounded stream of such quintuplets, consider this variation:\r\n```\r\nod -t x -An /dev/random | tr -d &quot; &quot; | fold -w 8 |\r\n  jq -nRc &#39;repeat( [limit(5;inputs)] )&#39;\r\n```\r\n\r\n## Example: .random = PLACEHOLDER\r\n\r\nUsing the same data.json as shown elsewhere on this page, a run of the following bash commands produced the output shown below:\r\n\r\n```\r\nod -t x -An /dev/random | tr -d &quot; &quot; | fold -w 8 |\r\n  jq -nRc --slurpfile stream data.json &#39;$stream[] | .random=input&#39;\r\n```\r\nOutput:\r\n```\r\n{&quot;random&quot;:&quot;79c434e6&quot;}\r\n{&quot;random&quot;:&quot;28797cf9&quot;}\r\n{&quot;random&quot;:&quot;90a8813d&quot;}\r\n```",
                "title": "random/sequential numbers in JQ (or workaround)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599079948,
                "last_edit_date": 1599079948,
                "creation_date": 1599038020,
                "answer_id": 63702390,
                "question_id": 63689970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this answer, we focus on the `.random = PLACEHOLDER` example given in the Q, and assume that the input stream of objects is infinite, or too long or too large to &quot;slurp&quot; (e.g. using --slurpfile).  \r\n\r\nIn order to avoid calling jq more than once (or twice if the input stream is NOT presented in JSONLines format), we will have to generate the random numbers on demand, i.e. in a loop.\r\n\r\nAssuming that `stream` generates the (possibly infinite) stream of JSON objects of interest in JSONLines format (as posited by the Q), we can write: \r\n\r\n```\r\nstream | while read -r obj ; do\r\n    echo &quot;$obj&quot;\r\n    gshuf -i 0-100 -n 1 --random-source=/dev/random\r\ndone | jq -nc &#39;repeat(input |  (.random = input))?&#39;\r\n```\r\n(To test this, one could replace `stream` by `jq -n &#39;repeat({})&#39;`, which generates an unbounded stream of empty JSON objects.)\r\n\r\nThe trick here is to use `?` to avoid raising an &quot;end of stream&quot; error in case the `stream` stream is finite.\r\n\r\nIf `stream` does not produce the JSON objects in JSONLines format, then one could replace `stream` by `stream | jq --unbuffered -c .`, which of course means that the solution requires invoking jq twice.",
                "title": "random/sequential numbers in JQ (or workaround)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1625134350,
                "last_edit_date": 1625134350,
                "creation_date": 1625133440,
                "answer_id": 68208107,
                "question_id": 63689970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` can generate pseudo-random numbers if _one_ initial random number is provided (`--argjson initialRandomNumber`).\r\n\r\nI used a slightly modified version of the function `nextRandomNumber` from Rosettacode [jq: random numbers](http://rosettacode.org/wiki/Random_numbers#jq) to generate pseudo-random numbers as shown in the following code.\r\n\r\nThe function takes a parameter `$state` and delivers a `newState` in the response for a subsequent call of `nextRandomNumber`.\r\n\r\nIf a number in the range [0 .. 32767] is not sufficient, you can have a look at [jq : Generate UUID in field][1] where I added a small collection of random functions for `jq` to generate UUID, random string, random numbers and arrays of these.\r\n\r\nPassing `$RANDOM$RANDOM` instead of `$RANDOM` is intended to increase the range for the initial pseudo-random value.\r\n\r\n```bash \r\n#!/bin/bash\r\n\r\njq -n &#39;{id: (range(10) + 1)}&#39; |   # create stream of json\r\njq -n --argjson initialRandomNumber &quot;$RANDOM$RANDOM&quot; &#39;\r\n  # 15-bit integers generated using the same formula as rand() from the Microsoft C Runtime.\r\n  # The random numbers are in [0 -- 32767] inclusive.\r\n  #\r\n  # Input: \r\n  #   first call:      $state = a random number provided to jq by parameter\r\n  #   subsequent call: $state = &quot;newState&quot; from last response\r\n  #\r\n  # Output: \r\n  #   object with pseudo-random number and &quot;newState&quot; for a subsequent call.\r\n  def nextRandomNumber($state):\r\n    ( (214013 * $state) + 2531011) % 2147483648 # mod 2^31\r\n    | { newState: ., randomNumber: (. / 65536 | floor) };\r\n\r\n  foreach inputs as $input (nextRandomNumber($initialRandomNumber); \r\n                            nextRandomNumber(.newState); \r\n                            $input + {randomNumber})\r\n&#39;\r\n``` \r\n\r\n## output\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;randomNumber&quot;: 24271\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;randomNumber&quot;: 5840\r\n}\r\n{\r\n  &quot;id&quot;: 3,\r\n  &quot;randomNumber&quot;: 3059\r\n}\r\n\r\n(...)\r\n\r\n{\r\n  &quot;id&quot;: 10,\r\n  &quot;randomNumber&quot;: 24864\r\n}\r\n``` \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/61842926/jq-generate-uuid-in-field/68192205#68192205",
                "title": "random/sequential numbers in JQ (or workaround)"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1625134350,
        "creation_date": 1598971425,
        "last_edit_date": 1599029635,
        "question_id": 63689970,
        "body_markdown": "IIUC jq does not support random numbers at the moment. I have script producing lines, where each line is JSON. I need to pipe it to jq to transform the data, and output pipe yet further. The problem is, that I need as a part of jq transformation to set some field to some random/sequential value. And since the jq is invoked just once and processes streamed data, I cannot supply random value from bash, as it would be not random, but always the same.\r\n\r\nIs there a workaround/solution for this?\r\n\r\nComment: maybe I could use some constant in place of random value, and then replace externally, but if I pipe jq output even to: `while read R;do ...;done` then the data are available only after whole input is processed, which is not possible, every line has to be processed asap. Maybe this is just a incorrect bash usage? If so, do you know how to fix that? EDIT: ok, so that is solved by --unbuffered parameter. So this is one workaroudnd. If you know better, please share.\r\n\r\n**example of invocation of my nasty workaround:**\r\n\r\n    cat | jq --unbuffered -c &#39;.random=&quot;PLACEHOLDER&quot;&#39; | while read R; do echo $R | sed &quot;s/PLACEHOLDER/$RANDOM/&quot;;done | sed &quot;s/^/anotherScriptMock/&quot;\r\n\r\nand start entering valid jsons like `{}`",
        "link": "https://stackoverflow.com/questions/63689970/random-sequential-numbers-in-jq-or-workaround",
        "title": "random/sequential numbers in JQ (or workaround)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599766603,
                "last_edit_date": 1599766603,
                "creation_date": 1599014189,
                "answer_id": 63697885,
                "question_id": 63693030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please note: this is a response to the original question.\r\n\r\nYou could use `first/1`, e.g.:\r\n```python\r\nfirst(.[] | (.team // empty)) as $default\r\n| map( .team |= (. // $default) )\r\n```",
                "title": "Cascade json property value to all descendants that are null using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599064271,
                "last_edit_date": 1599064271,
                "creation_date": 1599051620,
                "answer_id": 63706063,
                "question_id": 63693030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems that I needed to send a reference to the original collection to prevent `select` from filtering the items.  This is what I cam up with:\r\n\r\n    def func($collection; $parent): \r\n        if $parent == null or $parent == &quot;&quot; then \r\n            null \r\n        else $collection \r\n            | .[] \r\n            | select(.name==$parent)\r\n            | .team // func($collection; .parent)\r\n        end;  \r\n            \r\n    . as $collection\r\n        | map(.team = (.team // func($collection; .parent))) \r\n\r\n\r\n",
                "title": "Cascade json property value to all descendants that are null using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599766578,
                "last_edit_date": 1599766578,
                "creation_date": 1599053631,
                "answer_id": 63706704,
                "question_id": 63693030,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution using a recursive function to &quot;fill-in&quot; the dictionary constructed by `INDEX(.[]; .name)`:\r\n```python\r\n# $ix to handle the case of no parent having a team\r\ndef team($name; $ix):\r\n  if $name == null or $ix == 0 then null\r\n  else .[$name].team // team(.[$name].parent; $ix-1)\r\n  end;\r\n  \r\nINDEX(.[]; .name) \r\n| reduce keys_unsorted[] as $k (.; .[$k].team = team($k; length))\r\n| [.[]]\r\n```",
                "title": "Cascade json property value to all descendants that are null using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1599766603,
        "creation_date": 1598983033,
        "last_edit_date": 1599050299,
        "question_id": 63693030,
        "body_markdown": "I have been banging my head on this for far too long.  This is what I have:\r\n\r\nSource:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Item A&quot;,\r\n        &quot;parent&quot;: &quot;&quot;,\r\n        &quot;team&quot;: &quot;Team 1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Item B&quot;,\r\n        &quot;parent&quot;: &quot;Item A&quot;,\r\n        &quot;team&quot;: &quot;Team 2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Item C&quot;,\r\n        &quot;parent&quot;: &quot;Item A&quot;,\r\n        &quot;team&quot;: null\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Item D&quot;,\r\n        &quot;parent&quot;: &quot;Item C&quot;,\r\n        &quot;team&quot;: null\r\n      }\r\n    ]\r\n\r\nJQ Command:\r\n\r\n    def func($p): select(.name==$p) | (.team // func(.parent)); map(.team = (.team // func(.parent)))\r\n\r\nResult:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Item A&quot;,\r\n        &quot;parent&quot;: &quot;&quot;,\r\n        &quot;team&quot;: &quot;Team 1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Item B&quot;,\r\n        &quot;parent&quot;: &quot;Item A&quot;,\r\n        &quot;team&quot;: &quot;Team 2&quot;\r\n      }\r\n    ]\r\n\r\nWhat I want is for both items with a null team to inherit their team value from the their parent.  If their parent&#39;s team is null look at their parents parent and so on.  In the above example team would be &quot;Team 1&quot; for both Item C and Item D.  If Item C has a parent of Item B then Items C and D should have a parent of &quot;Team 2&quot;.\r\n\r\nThis is a simplified example and may contain several items with null teams that need to inherit from a parent.\r\n",
        "link": "https://stackoverflow.com/questions/63693030/cascade-json-property-value-to-all-descendants-that-are-null-using-jq",
        "title": "Cascade json property value to all descendants that are null using JQ"
    },
    {
        "tags": [
            "xml",
            "jq",
            "xq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599043876,
                "last_edit_date": 1599043876,
                "creation_date": 1599042493,
                "answer_id": 63703629,
                "question_id": 63703049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Appreciate trying to using `xq` bundled along with `yq` for XML parsing. The reason for your error is that `.tags` is encoded as an an array of objects in couple of instances. You need to be able to distinguish between them in your filter while extracting. Also filter out objects that don&#39;t have the `.tag` property at all\r\n\r\nOne simple way to solve it would be to use an explicit `if` statement to do the comparison\r\n\r\n    xq &#39;\r\n    .osm.node[] | \r\n    select(.tag != null) | \r\n    if (.tag|type == &quot;array&quot;) then \r\n      select(any(.tag[]; .[&quot;@k&quot;] == &quot;power&quot;)) \r\n    else \r\n      select(any(.tag; .[&quot;@k&quot;] == &quot;power&quot;)) \r\n    end\r\n    &#39; power.xml\r\n\r\nor make the conditional branch as a function\r\n\r\n    xq &#39;\r\n    def nodeSel($p): if ($p|type == &quot;array&quot;) then select(any($p[]; .[&quot;@k&quot;] == &quot;power&quot;)) else select(any($p; .[&quot;@k&quot;] == &quot;power&quot;)) end;\r\n    .osm.node[] | \r\n    select(.tag != null) |\r\n    nodeSel(.tag)\r\n    &#39; power.xml",
                "title": "Extract elements containing tags with certain values using jq/xq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599043876,
        "creation_date": 1599040425,
        "last_edit_date": 1599043210,
        "question_id": 63703049,
        "body_markdown": "I&#39;m trying to extract coordinates of nodes with the `&lt;tag k=&quot;power&quot;&gt;` tags. \r\n\r\nI&#39;ve tried several methods.\r\n\r\nThis one only returns two values (403564136 and 403564138) and an error: `jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;@k&quot;`. It is probably failing to process the entity where &lt;node&gt; contains multiple elements as opposed to one element, resulting in the xml-&gt;json conversion generating two different types of data - arrays and objects. Not sure what would be the best way to fix it though:\r\n\r\n    xq &#39;.osm.node[] | select(any(.tag; .[&quot;@k&quot;] == &quot;power&quot;))&#39; power.xml\r\n\r\nI would be able to solve the problem by just searching for plain text, but it yields 0 results:\r\n\r\n    xq &#39;.osm.node[] | select( index(&quot;power&quot;) )&#39; power.xml\r\n\r\nor \r\n\r\n    xq &#39;.osm.node[] | select( any(. == &quot;power&quot;) )&#39; power.xml\r\n\r\nI&#39;m probably missing something, but I can&#39;t figure out what I&#39;m doing wrong.\r\n\r\n`power.xml`:\r\n\r\n    &lt;?xml version=&quot;1.0&quot; encoding=&quot;UTF-8&quot;?&gt;\r\n    &lt;osm version=&quot;0.6&quot; generator=&quot;CGImap 0.8.3 (3907222 thorn-02.openstreetmap.org)&quot; copyright=&quot;OpenStreetMap and contributors&quot; attribution=&quot;http://www.openstreetmap.org/copyright&quot; license=&quot;http://opendatacommons.org/licenses/odbl/1-0/&quot;&gt;\r\n        &lt;node id=&quot;403564136&quot; visible=&quot;true&quot; version=&quot;4&quot; changeset=&quot;27918722&quot; timestamp=&quot;2015-01-04T19:50:21Z&quot; user=&quot;k__&quot; uid=&quot;156900&quot; lat=&quot;58.3795467&quot; lon=&quot;26.6902636&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;403564138&quot; visible=&quot;true&quot; version=&quot;2&quot; changeset=&quot;14825596&quot; timestamp=&quot;2013-01-28T18:28:16Z&quot; user=&quot;k__&quot; uid=&quot;156900&quot; lat=&quot;58.3798399&quot; lon=&quot;26.6882638&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;403564140&quot; visible=&quot;true&quot; version=&quot;3&quot; changeset=&quot;21131355&quot; timestamp=&quot;2014-03-16T08:53:37Z&quot; user=&quot;k__&quot; uid=&quot;156900&quot; lat=&quot;58.3811404&quot; lon=&quot;26.6822486&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n            &lt;tag k=&quot;source&quot; v=&quot;Maa amet WMS 2009; survey&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;403564141&quot; visible=&quot;true&quot; version=&quot;3&quot; changeset=&quot;14825596&quot; timestamp=&quot;2013-01-28T18:28:17Z&quot; user=&quot;k__&quot; uid=&quot;156900&quot; lat=&quot;58.3805103&quot; lon=&quot;26.6790130&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;403564142&quot; visible=&quot;true&quot; version=&quot;2&quot; changeset=&quot;1399220&quot; timestamp=&quot;2009-06-01T22:33:48Z&quot; user=&quot;green525&quot; uid=&quot;64433&quot; lat=&quot;58.3801485&quot; lon=&quot;26.6771179&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n            &lt;tag k=&quot;ref&quot; v=&quot;4&quot;/&gt;\r\n            &lt;tag k=&quot;source&quot; v=&quot;Maa amet WMS 2009; extrapolation&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;409079906&quot; visible=&quot;true&quot; version=&quot;3&quot; changeset=&quot;47530271&quot; timestamp=&quot;2017-04-07T07:39:53Z&quot; user=&quot;juhanjuku&quot; uid=&quot;152305&quot; lat=&quot;58.0699088&quot; lon=&quot;27.0763265&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;pole&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;409079908&quot; visible=&quot;true&quot; version=&quot;3&quot; changeset=&quot;32801064&quot; timestamp=&quot;2015-07-22T12:40:52Z&quot; user=&quot;evaldmaa&quot; uid=&quot;1706132&quot; lat=&quot;58.0697186&quot; lon=&quot;27.0755833&quot;&gt;\r\n            &lt;tag k=&quot;power&quot; v=&quot;tower&quot;/&gt;\r\n        &lt;/node&gt;\r\n        &lt;node id=&quot;579469806&quot; visible=&quot;true&quot; version=&quot;1&quot; changeset=&quot;3279698&quot; timestamp=&quot;2009-12-03T11:17:02Z&quot; user=&quot;maaamet-import&quot; uid=&quot;204356&quot; lat=&quot;58.1991523&quot; lon=&quot;26.8752022&quot;/&gt;\r\n        &lt;node id=&quot;319174533&quot; visible=&quot;true&quot; version=&quot;3&quot; changeset=&quot;10614880&quot; timestamp=&quot;2012-02-07T18:36:07Z&quot; user=&quot;k__&quot; uid=&quot;156900&quot; lat=&quot;58.2019064&quot; lon=&quot;26.8798802&quot;&gt;\r\n            &lt;tag k=&quot;railway&quot; v=&quot;level_crossing&quot;/&gt;\r\n        &lt;/node&gt;\r\n    &lt;/osm&gt;\r\n",
        "link": "https://stackoverflow.com/questions/63703049/extract-elements-containing-tags-with-certain-values-using-jq-xq",
        "title": "Extract elements containing tags with certain values using jq/xq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599158131,
                "last_edit_date": 1599158131,
                "creation_date": 1599049692,
                "answer_id": 63705532,
                "question_id": 63705330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of\r\n\r\n    .values[].data as $p\r\n\r\nyou would have to write:\r\n\r\n    .values[].data | . as $p\r\n\r\n## Semantics of `BAR as $BAR`\r\n\r\n`as` behaves like a shunt; that is, \r\n\r\n    FOO | BAR as $BAR | ...\r\n\r\nis the same as:\r\n\r\n    FOO | . as $FOO | (BAR as $BAR | $FOO | ...)\r\n \r\nassuming that `...` does not reference a variable named `$FOO`.\r\n",
                "title": "Saving value in &quot;jq&quot; variable causes &quot;Cannot iterate over null&quot; problem"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599158131,
        "creation_date": 1599048971,
        "last_edit_date": 1599123978,
        "question_id": 63705330,
        "body_markdown": "Such command works successfully:\r\n\r\n    jq &#39;.values[].data | .items[]&#39; my.json\r\n    &quot;url1&quot;\r\n    &quot;url2&quot;\r\n    ...\r\nAnd simple attempt to save variable leads to fail:\r\n\r\n    jq &#39;.values[].data as $p | .items[]&#39; my.json\r\n    jq: error (at my.json:0): Cannot iterate over null (null)\r\nIt looks like I follow the syntax. What am I doing wrong?",
        "link": "https://stackoverflow.com/questions/63705330/saving-value-in-jq-variable-causes-cannot-iterate-over-null-problem",
        "title": "Saving value in &quot;jq&quot; variable causes &quot;Cannot iterate over null&quot; problem"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599169388,
                "creation_date": 1599169388,
                "answer_id": 63732041,
                "question_id": 63731489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `transpose` makes for a compact solution:\r\n```\r\n[.[] | .data]\r\n| transpose[]\r\n| [.[0].timeStamp, (.[]|.maximum)]\r\n| @csv\r\n```\r\n\r\nWith the given input, the output, however, would be:\r\n```\r\n&quot;2020-09-01T00:30:00+00:00&quot;,100,69\r\n&quot;2020-09-02T00:30:00+00:00&quot;,100,72\r\n&quot;2020-09-03T00:30:00+00:00&quot;,97,71\r\n\r\n```\r\n\r\n",
                "title": "JQ join two arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599174045,
        "creation_date": 1599166356,
        "last_edit_date": 1599174045,
        "question_id": 63731489,
        "body_markdown": "I&#39;m trying to parse some json output from an API. I&#39;ve got two arrays like this:\r\n\r\n```[\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 100.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-01T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      },\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 100.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-02T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      },\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 97.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-03T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      }\r\n    ],\r\n    &quot;metadatavalues&quot;: []\r\n  },\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 69.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-01T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      },\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 72.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-02T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      },\r\n      {\r\n        &quot;average&quot;: null,\r\n        &quot;count&quot;: null,\r\n        &quot;maximum&quot;: 71.0,\r\n        &quot;minimum&quot;: null,\r\n        &quot;timeStamp&quot;: &quot;2020-09-03T00:30:00+00:00&quot;,\r\n        &quot;total&quot;: null\r\n      }\r\n    ],\r\n    &quot;metadatavalues&quot;: []\r\n  }\r\n]\r\n```\r\n\r\n\r\nI&#39;d like to take timestamp from the &quot;data&quot; in the first array, and join it with the maximum value from the first and the second array, like this:\r\n```\r\n&quot;2020-09-01T00:30:00+00:00&quot;, 100, 69\r\n&quot;2020-09-02T00:30:00+00:00&quot;, 93, 72\r\n&quot;2020-09-03T00:30:00+00:00&quot;, 97, 71\r\n```\r\n\r\nWhat I&#39;ve got now is ``` jq -c [.[0].data[].timeStamp, .[0].data[].maximum, .[1].data[].maximum] ``` that returns everything in one array\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63731489/jq-join-two-arrays",
        "title": "JQ join two arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599202685,
                "post_id": 63734373,
                "comment_id": 112706447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1599202711,
                "post_id": 63734373,
                "comment_id": 112706455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1599205110,
                "post_id": 63734373,
                "comment_id": 112707420,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4823886,
                    "reputation": 85,
                    "user_id": 3893836,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/7822a9d7d6bfb2eb22e8d7716fd20c6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3893836",
                    "link": "https://stackoverflow.com/users/3893836/user3893836"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599274503,
                "post_id": 63734373,
                "comment_id": 112731748,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599239832,
                "creation_date": 1599239832,
                "answer_id": 63745475,
                "question_id": 63734373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the minor syntactic errors have been fixed in the shown sample, the following produces the result you&#39;re expecting:\r\n\r\n```\r\n.items[].status.images[].names[]\r\n| select(test(&quot;/n2_agent_centos:&quot;))\r\n```\r\nIt looks like you were missing `.status`.",
                "title": "jq key name pattern match"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1599274704,
        "creation_date": 1599189848,
        "last_edit_date": 1599274704,
        "question_id": 63734373,
        "body_markdown": "I have the following JSON output.\r\n\r\n    {\r\n       &quot;kind&quot;:&quot;NodeList&quot;,\r\n       &quot;apiVersion&quot;:&quot;v1&quot;,\r\n       &quot;metadata&quot;:{\r\n          &quot;selfLink&quot;:&quot;/api/v1/nodes&quot;,\r\n          &quot;resourceVersion&quot;:&quot;6666628&quot;\r\n       },\r\n       &quot;items&quot;:[\r\n          {\r\n             &quot;status&quot;:{\r\n                &quot;images&quot;:[\r\n                   {\r\n                      &quot;names&quot;:[\r\n                         &quot;d50d-hlx-app13:3601/n2_agent_centos@sha256:319fea95daa46243c48ad9df4c95aa6b9d3d7a2c5343f465d1a8631ee1df9f50&quot;,\r\n                         &quot;d50d-hlx-app13:3601/n2_agent_centos:11.0.2.1&quot;\r\n                      ],\r\n                      &quot;sizeBytes&quot;:3223825508\r\n                   },\r\n                   {\r\n                      &quot;names&quot;:[\r\n                         &quot;d50d-hlx-app13:3601/ad_agent_centos@sha256:ebd885ce640a84903ed7a32ae4cd6dff526a074579831634ec9dfbe40b0962ea&quot;,\r\n                         &quot;d50d-hlx-app13:3601/ad_agent_centos:11.0.2.0&quot;\r\n                      ],\r\n                      &quot;sizeBytes&quot;:1072047699\r\n                   },\r\n                   {\r\n                      &quot;names&quot;:[\r\n                         &quot;gcr.io/google-containers/kube-apiserver:v1.15.3&quot;\r\n                      ],\r\n                      &quot;sizeBytes&quot;:206843838\r\n                   },\r\n                   {\r\n                      &quot;names&quot;:[\r\n                         &quot;httpd@sha256:3cbdff4bc16681541885ccf1524a532afa28d2a6578ab7c2d5154a7abc182379&quot;,\r\n                         &quot;httpd:latest&quot;\r\n                      ],\r\n                      &quot;sizeBytes&quot;:165547282\r\n                   },\r\n                   {\r\n                      &quot;names&quot;:[\r\n                         &quot;gcr.io/google-containers/pause:3.1&quot;,\r\n                         &quot;gcr.io/google_containers/pause-amd64:3.1&quot;\r\n                      ],\r\n                      &quot;sizeBytes&quot;:742472\r\n                   }\r\n                ]\r\n             }\r\n          }\r\n       ]\r\n    }\r\n\r\nI would like to have an output of key and value of items-&gt;images-&gt;names if one of its keys is &quot;n2_agent_centos&quot;.\r\n\r\n    d50d-hlx-app13:3601/n2_agent_centos:11.0.2.1\r\n\r\nI have tried many ways, all failed. Could someone help me? Thanks a lot in advance.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63734373/jq-key-name-pattern-match",
        "title": "jq key name pattern match"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1599215086,
                "post_id": 63739082,
                "comment_id": 112711805,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1599239199,
                "last_edit_date": 1599239199,
                "creation_date": 1599216174,
                "answer_id": 63739593,
                "question_id": 63739082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apparently it is one of the issues in `jq-1.5`. Un-terminated objects/arrays, without a corresponding close character, are being treated as valid objects and are accepted by the parser. Can reproduce in `jq-1.5`, but fixed in `jq-1.6`\r\n\r\nOn `jq-1.6`\r\n\r\n    jq -e . &lt;&lt;&lt; &#39;{&quot;fruit&quot;:{&quot;name&quot;:&quot;app&#39;\r\n    parse error: Unfinished string at EOF at line 2, column 0\r\n    echo $?\r\n    4\r\n\r\nminimal reproducible example below, which again is handled well in 1.6 but doesn&#39;t throw an error in 1.5\r\n\r\n    jq -e . &lt;&lt;&lt; &#39;{&#39;\r\n    parse error: Unfinished JSON term at EOF at line 2, column 0\r\n    jq -e . &lt;&lt;&lt; &#39;[&#39;\r\n    parse error: Unfinished JSON term at EOF at line 2, column 0\r\n\r\n---\r\n\r\nSuggest upgrading to `jq-1.6` to make this work!",
                "title": "jq accepts invalid json input when it should throw an error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1599239199,
        "creation_date": 1599214150,
        "last_edit_date": 1599216354,
        "question_id": 63739082,
        "body_markdown": "I am having problem to validate json string.\r\ni am using below code\r\n\r\n    if jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt;&quot;$json_string&quot;; then\r\n            echo &quot;Parsed JSON successfully and got something other than false/null&quot;\r\n        else\r\n            echo &quot;Failed to parse JSON, or got false/null&quot;\r\n        fi\r\nThis does not work for `json_string={&quot;fruit&quot;:{&quot;name&quot;:&quot;app`. this still shows **Parsed JSON successfully and got something other than false/null** where as the json string is incomplete.",
        "link": "https://stackoverflow.com/questions/63739082/jq-accepts-invalid-json-input-when-it-should-throw-an-error",
        "title": "jq accepts invalid json input when it should throw an error"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1599217914,
                "creation_date": 1599217914,
                "answer_id": 63740046,
                "question_id": 63739892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do:\r\n\r\n```\r\njq &#39;.link[].attributes|=sort_by(.name)&#39;\r\n```\r\n\r\nThe `|=` takes all the paths matched by `.link[].attributes`, i.e. each &quot;attributes&quot; array, and applies the filter `sort_by(.name)` to each of them, leaving everything else unchanged.",
                "title": "jq sort by value of key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1599244069,
        "creation_date": 1599217295,
        "last_edit_date": 1599244069,
        "question_id": 63739892,
        "body_markdown": "Given the following JSON (oversimplified for the sake of the example), I need to order the keys by their value. In this case, the order should be id &gt; name &gt; type.\r\n\r\n```\r\n{\r\n    &quot;link&quot;: [{\r\n            &quot;attributes&quot;: [{\r\n                    &quot;value&quot;: &quot;ConfigurationElement&quot;,\r\n                    &quot;name&quot;: &quot;type&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;NAME1&quot;,\r\n                    &quot;name&quot;: &quot;name&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;0026a8b4-ced6-410e-9213-e3fcb28b3aab&quot;,\r\n                    &quot;name&quot;: &quot;id&quot;\r\n                }\r\n            ],\r\n            &quot;href&quot;: &quot;href1&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n        }, {\r\n            &quot;attributes&quot;: [{\r\n                    &quot;value&quot;: &quot;0026a8b4-ced6-410e-9213-k23g15h2u1l5&quot;,\r\n                    &quot;name&quot;: &quot;id&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;ConfigurationElement&quot;,\r\n                    &quot;name&quot;: &quot;type&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;NAME2&quot;,\r\n                    &quot;name&quot;: &quot;name&quot;\r\n                }\r\n            ],\r\n            &quot;href&quot;: &quot;href2&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n        }\r\n    ],\r\n    &quot;total&quot;: 2\r\n}\r\n```\r\n\r\n\r\n\r\nEXPECTED RESULT:\r\n```\r\n{\r\n    &quot;link&quot;: [{\r\n            &quot;attributes&quot;: [{\r\n                    &quot;value&quot;: &quot;0026a8b4-ced6-410e-9213-e3fcb28b3aab&quot;,\r\n                    &quot;name&quot;: &quot;id&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;NAME1&quot;,\r\n                    &quot;name&quot;: &quot;name&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;ConfigurationElement&quot;,\r\n                    &quot;name&quot;: &quot;type&quot;\r\n                }\r\n            ],\r\n            &quot;href&quot;: &quot;href1&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n        }, {\r\n            &quot;attributes&quot;: [{\r\n                    &quot;value&quot;: &quot;0026a8b4-ced6-410e-9213-k23g15h2u1l5&quot;,\r\n                    &quot;name&quot;: &quot;id&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;NAME2&quot;,\r\n                    &quot;name&quot;: &quot;name&quot;\r\n                }, {\r\n                    &quot;value&quot;: &quot;ConfigurationElement&quot;,\r\n                    &quot;name&quot;: &quot;type&quot;\r\n                }\r\n            ],\r\n            &quot;href&quot;: &quot;href2&quot;,\r\n            &quot;rel&quot;: &quot;down&quot;\r\n        }\r\n    ],\r\n    &quot;total&quot;: 2\r\n}\r\n```\r\n\r\nI would be very grateful if anyone could help me out. I tried jq with -S and -s with sort_by(), but this example is way too complex for me to figure it out with my current experience with jq. Thank you a lot!",
        "link": "https://stackoverflow.com/questions/63739892/jq-sort-by-value-of-key",
        "title": "jq sort by value of key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1599281345,
                "last_edit_date": 1599281345,
                "creation_date": 1599230595,
                "answer_id": 63743340,
                "question_id": 63741888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One portable to work with on both versions would be,\r\n\r\n    .vars.instances |= map(select(index(&quot;one&quot;)|not))\r\n\r\nor if you want to still use `del()`, feed the index of the string `&quot;one&quot;` to the function as below, where `index(&quot;one&quot;)` gets the index `0` which then gets passed to delete as `del(.[0])` meaning to delete the element at zeroth index.\r\n\r\n    .vars.instances |= del(.[index(&quot;one&quot;)])",
                "title": "jq: delete element from array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1599278989,
                "creation_date": 1599278989,
                "answer_id": 63750361,
                "question_id": 63741888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The implementation of `del/1` has proven to be quite difficult and indeed it changed between jq 1.5 and jq 1.6, so if portability across different versions of jq is important, then usage of `del/1` should either be restricted to the least complicated cases (e.g., no pipelines) or undertaken with great care. ",
                "title": "jq: delete element from array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1709670577,
        "creation_date": 1599225054,
        "last_edit_date": 1709670577,
        "question_id": 63741888,
        "body_markdown": "I have this JSON file and want to delete an element from an array:\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n    &quot;address&quot;: &quot;localhost&quot;,\r\n    &quot;name&quot;: &quot;local&quot;,\r\n    &quot;vars&quot;: {\r\n        &quot;instances&quot;: [\r\n            &quot;one&quot;,\r\n            &quot;two&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\n\r\nI am using this command: \r\n\r\n&lt;!-- language: shell --&gt;\r\n    jq &#39;del(.vars.instances[] | select(index(&quot;one&quot;)))&#39; data.json\r\n\r\nThe output is:\r\n\r\n&lt;!-- language: json --&gt;\r\n    {\r\n    &quot;address&quot;: &quot;localhost&quot;,\r\n    &quot;name&quot;: &quot;local&quot;,\r\n    &quot;vars&quot;: {\r\n        &quot;instances&quot;: [\r\n            &quot;two&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n\r\n\r\nSo it works as expected, but only with jq v1.6. With jq v1.5 I get this error:\r\n\r\n&lt;!-- language: none --&gt;\r\n    jq: error (at data.json:20): Invalid path expression near attempt to access element 0 of [0]\r\n\r\nSo what am I doing wrong? Is this a bug or a feature of v1.5? Is there any workaround to get the same result in v1.5?\r\n\r\nThanks in advance\r\n\r\nVince",
        "link": "https://stackoverflow.com/questions/63741888/jq-delete-element-from-array",
        "title": "jq: delete element from array"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599308970,
                "post_id": 63753704,
                "comment_id": 112738446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599309062,
                "post_id": 63753704,
                "comment_id": 112738472,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1599313281,
                "post_id": 63753704,
                "comment_id": 112739521,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599314115,
                "last_edit_date": 1599314115,
                "creation_date": 1599309404,
                "answer_id": 63754022,
                "question_id": 63753704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first step is to realize you can turn the set of fields into an array like this using a technique like this:\r\n\r\n```\r\njq &#39;(.accountId + &quot;,&quot; + .addDate)&#39;\r\n```\r\n\r\nNow you can update your bash loop:\r\n\r\n```bash\r\nfor k in $(echo $ZONE_LIST  | jq -r &#39;.response | .data[]&#39; | jq &#39;(.content + &quot;,&quot; + .id)&#39;); do\r\n    echo $k\r\ndone\r\n```\r\n\r\nThere is probably a way to combine the two `jq` commands but I don&#39;t have your original `json` data for testing.\r\n\r\n**UPDATE** - inside the loop you can parse the comma-delimited string into separate fields. This are more efficient ways to handle this task but I prefer simplicity. \r\n\r\n```\r\n    ID=$(echo $k | cut -d&#39;,&#39; -f1)\r\n    PRIORITY=$(echo $k | cut -d&#39;,&#39; -f2)\r\n    echo &quot;ID($ID)  PRIORITY($PRIORITY)&quot;\r\n```",
                "title": "Loop json Output in shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599310450,
                "creation_date": 1599310450,
                "answer_id": 63754148,
                "question_id": 63753704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\nwhile IFS=$&#39;\\37&#39; read -r -d &#39;&#39; id content; do\r\n  echo &quot;$id&quot; &quot;$content&quot;\r\ndone &lt; &lt;(\r\n  jq -j &#39;.response | .data[] | .id + &quot;\\u001f&quot; + .content + &quot;\\u0000&quot;&#39; \\\r\n  &lt;&lt;&lt;&quot;$ZONE_LIST&quot;\r\n)\r\n```\r\n\r\n- `jq -j`: Forces a raw output from `jq`.\r\n- `.id + &quot;\\u001f&quot; + .content + &quot;\\u0000&quot;`: Assemble fields delimited by ASCII FS (Hexadecimal `1f` or Octal `37`), and end record by a `null` character.\r\n\r\nIt then becomes easy and reliable to iterate over `null` delimited records by having `read -d &#39;&#39;` (`null` delimiter).\r\n\r\nFields `id` `content` are separated by ASCII FS, so just set the **I**nternal **F**ield **S**eparator `IFS` environment variable to the corresponding octal `IFS=$&#39;37&#39;` before reading.",
                "title": "Loop json Output in shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1599310707,
                "creation_date": 1599310707,
                "answer_id": 63754179,
                "question_id": 63753704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this.\r\n```\r\nfor k in $(echo $ZONE_LIST  | jq -rc &#39;.response | .data[]&#39;); do\r\n    echo $k|jq &#39;.content + &quot; - &quot; + .id&#39; -r\r\ndone\r\n```",
                "title": "Loop json Output in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1599314115,
        "creation_date": 1599307563,
        "last_edit_date": 1599310693,
        "question_id": 63753704,
        "body_markdown": "I have this output variable\r\n\r\n    OUTPUT=$(echo $ZONE_LIST  | jq -r &#39;.response | .data[]&#39;)\r\n\r\nThe Output:\r\n\r\n    {\r\n      &quot;accountId&quot;: &quot;xyz&quot;,\r\n      &quot;addDate&quot;: &quot;2020-09-05T10:57:11Z&quot;,\r\n      &quot;content&quot;: &quot;\\&quot;MyContent\\&quot;&quot;,\r\n      &quot;id&quot;: &quot;MyID&quot;,\r\n      &quot;priority&quot;: null\r\n    }\r\n    {\r\n      &quot;accountId&quot;: &quot;xyz&quot;,\r\n      &quot;addDate&quot;: &quot;2020-09-05T06:58:52Z&quot;,\r\n      &quot;content&quot;: &quot;\\&quot;MyContent\\&quot;&quot;,\r\n      &quot;id&quot;: &quot;MyID&quot;,\r\n      &quot;priority&quot;: null\r\n    }\r\n\r\nHow can I create a loop for this two values?\r\n\r\n    MyLoop\r\n      echo &quot;$content - $id&quot;\r\n    done\r\n\r\nI tried this, but then I get a loop through every single value\r\n\r\n    for k in $(echo $ZONE_LIST  | jq -r &#39;.response | .data[]&#39;); do\r\n        echo $k\r\n    done\r\n\r\nEDIT 1:\r\n\r\n    My complete JSON:\r\n    \r\n    {\r\n        &quot;errors&quot;: [],\r\n        &quot;metadata&quot;: {\r\n            &quot;transactionId&quot;: &quot;&quot;,\r\n        },\r\n        &quot;response&quot;: {\r\n            &quot;data&quot;: [\r\n                {\r\n                    &quot;accountId&quot;: &quot;xyz&quot;,\r\n                    &quot;addDate&quot;: &quot;2020-09-05T10:57:11Z&quot;,\r\n                    &quot;content&quot;: &quot;\\&quot;abcd\\&quot;&quot;,\r\n                    &quot;id&quot;: &quot;myID1&quot;,\r\n                    &quot;lastChangeDate&quot;: &quot;2020-09-05T10:57:11Z&quot;,\r\n                },\r\n                {\r\n                    &quot;accountId&quot;: &quot;xyz&quot;,\r\n                    &quot;addDate&quot;: &quot;2020-09-05T06:58:52Z&quot;,\r\n                    &quot;content&quot;: &quot;\\&quot;abc\\&quot;&quot;,\r\n                    &quot;id&quot;: &quot;myID2&quot;,\r\n                    &quot;lastChangeDate&quot;: &quot;2020-09-05T07:08:15Z&quot;,\r\n                }\r\n            ],\r\n            &quot;limit&quot;: 10,\r\n            &quot;page&quot;: 1,\r\n            &quot;totalEntries&quot;: 2,\r\n        },\r\n        &quot;status&quot;: &quot;success&quot;,\r\n        &quot;warnings&quot;: []\r\n    }\r\n\r\nNow I need a loop for data, because I need it for a curl\r\n\r\nThe curl NOW:\r\n\r\n    curl -s -v -X POST --data &#39;{\r\n        &quot;deleteEntries&quot;: [\r\n            Data_from_json\r\n        ]\r\n    }&#39; https://URL_to_Update 2&gt;/dev/null)\r\n\r\nNow I want to create a new variable from my JSON data. My CURL should look like this at the end:\r\n\r\n    curl -s -v -X POST --data &#39;{\r\n        &quot;deleteEntries&quot;: [\r\n            {\r\n                &quot;readID&quot;: &quot;myID1&quot;,\r\n                &quot;date&quot;: &quot;2020-09-05T10:57:11Z&quot;, &lt;--Value from addDate\r\n                &quot;content&quot;: &quot;abcd&quot;\r\n            },\r\n    \t\t{\r\n                &quot;readID&quot;: &quot;myID2&quot;,\r\n                &quot;date&quot;: &quot;2020-09-05T06:58:52Z&quot;, &lt;--Value from addDate\r\n                &quot;content&quot;: &quot;abc&quot;\r\n            }\r\n        ]\r\n    }&#39; https://URL_to_Update 2&gt;/dev/null)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63753704/loop-json-output-in-shell-script",
        "title": "Loop json Output in shell script"
    },
    {
        "tags": [
            "json",
            "bash",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599358109,
                "post_id": 63757814,
                "comment_id": 112749431,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1599449071,
                "last_edit_date": 1599449071,
                "creation_date": 1599339856,
                "answer_id": 63758498,
                "question_id": 63757814,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d avoid your `for` loop in favor of piping to `while`, like this:\r\n```\r\n./sacli ClusterQuery | jq -rc &#39;\r\n    keys_unsorted[] as $k | $k, .[$k].sacli_ip&#39; |\r\n  while read -r node_id ; do\r\n    read -r ip\t \r\n    ping -c 1 -W 1 &quot;$ip&quot;\r\n    ping_result=$?\r\n    if [[ $ping_result -eq 1 ]]; then #ping has failed\r\n      echo ./remove &quot;$node_id&quot;\r\n    fi\r\n  done\r\n```\r\n\r\nThis assumes the keys and sacli_ip values don&#39;t have embedded newlines.\r\n\r\nYou can of course easily add the appropriate `select` filter(s) inside the jq program.\r\n\r\nThe `-c` is there for safety.",
                "title": "Iterate over jq loop: assign key if value.subvalue matches condition"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599449071,
        "creation_date": 1599334407,
        "last_edit_date": 1599358081,
        "question_id": 63757814,
        "body_markdown": "I&#39;m trying to perform some work on keys whose value matches a certain condition. First, the json I&#39;m working with looks similar to this when I execute a CLI tool in linux:\r\n```\r\n$ ./sacli ClusterQuery\r\n\r\n  &quot;i-aaaaaaabbbbbbbbbb&quot;: {\r\n    &quot;sacli_ip&quot;: &quot;10.0.52.37&quot;,\r\n    &quot;sacli_listen_ip&quot;: &quot;10.0.52.37&quot;,\r\n    &quot;sacli_port&quot;: &quot;945&quot;\r\n  },\r\n  &quot;i-ccccccccddddddddd&quot;: {\r\n    &quot;sacli_ip&quot;: &quot;10.0.48.68&quot;,\r\n    &quot;sacli_listen_ip&quot;: &quot;10.0.48.68&quot;,\r\n    &quot;sacli_port&quot;: &quot;945&quot;\r\n  }\r\n```\r\n\r\nI would ideally like to loop through these entries, do a check and then perform operations based on the check. So conceptually:\r\n\r\n```\r\nfor i in $(./sacli ClusterQuery | jq -r &#39;&lt;some syntax to get each key, value&gt;&#39;); do\r\n  node_id=key\r\n  ip=value.sacli_ip\r\n\r\n  ping -c 1 -W 1 $ip\r\n  ping_result=$?\r\n\r\n  if [[ $ping_result -eq 1 ]]; then #ping has failed\r\n     ./remove $node_id\r\n  fi\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/63757814/iterate-over-jq-loop-assign-key-if-value-subvalue-matches-condition",
        "title": "Iterate over jq loop: assign key if value.subvalue matches condition"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599380137,
                "creation_date": 1599380137,
                "answer_id": 63762102,
                "question_id": 63762028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `echo $uuid` outputs this:\r\n\r\n    &quot;069a79f444e94726a5befca90e38aaf5&quot;\r\n\r\nBut it really should be:\r\n\r\n    069a79f444e94726a5befca90e38aaf5\r\n\r\nfor the curl command to work. So, tweak your `jq` line to strip off quotation marks.",
                "title": "Shell script, curl with variable as part of url"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1599380608,
                "creation_date": 1599380608,
                "answer_id": 63762161,
                "question_id": 63762028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "AS you can see by executing `echo $uuid` you got `&quot;069a79f444e94726a5befca90e38aaf5&quot;` \r\ninstead of `069a79f444e94726a5befca90e38aaf5` there should be no quotes.  \r\n\r\n`jq` has option to remove them it&#39;s `-r` with that everything works as expected(I think).\r\n\r\nSo change it to:\r\n\r\n    #!/bin/bash\r\n    # settings\r\n    username=&quot;Notch&quot;\r\n\r\n    # script \r\n    uuid_json=$(curl https://api.mojang.com/users/profiles/minecraft/$username)\r\n    echo $uuid_json\r\n    uuid=$(jq -r &#39;.id&#39; &lt;&lt;&lt; &quot;$uuid_json&quot;)                                                                                                                                                                           echo $uuid\r\n\r\n    profile_json=$(curl https://sessionserver.mojang.com/session/minecraft/profile/$uuid)\r\n    echo $profile_json ",
                "title": "Shell script, curl with variable as part of url"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1599380608,
        "creation_date": 1599379682,
        "question_id": 63762028,
        "body_markdown": "I am writing a small bash script that gets the profile of a Minecraft user from their username. However, when I run the following script, the ```profile_json``` variable comes out blank while the ```uuid_json``` and ```uuid``` variables have the content they should.\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\n# settings\r\nusername=&quot;Notch&quot;\r\n\r\n\r\n# script\r\nuuid_json=$(curl https://api.mojang.com/users/profiles/minecraft/$username)\r\necho $uuid_json\r\nuuid=$(jq &#39;.id&#39; &lt;&lt;&lt; &quot;$uuid_json&quot;)\r\necho $uuid\r\n\r\nprofile_json=$(curl https://sessionserver.mojang.com/session/minecraft/profile/$uuid)\r\necho $profile_json\r\n```\r\n\r\nMoreover, the output from running the script in a terminal shows the ```Current Speed``` of ```profile_json=$(curl https://sessionserver.mojang.com/session/minecraft/profile/$uuid)``` as ```0```. Any ideas as to why this would be?\r\n\r\n```\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100    56  100    56    0     0    160      0 --:--:-- --:--:-- --:--:--   160\r\n{&quot;name&quot;:&quot;Notch&quot;,&quot;id&quot;:&quot;069a79f444e94726a5befca90e38aaf5&quot;}\r\n&quot;069a79f444e94726a5befca90e38aaf5&quot;\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0\r\n\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/63762028/shell-script-curl-with-variable-as-part-of-url",
        "title": "Shell script, curl with variable as part of url"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1599427609,
                "creation_date": 1599427609,
                "answer_id": 63769053,
                "question_id": 63768922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `-s` to create one array from both the files, than use `.[0]` and `.[1]` to get each file&#39;s structure.\r\n\r\n    jq -s &#39;.[0].records + .[1].records&#39; file1 file2\r\n\r\nTo include the toplevel key, wrap the expression to an object:\r\n\r\n    jq -s &#39;{records: (.[0].records + .[1].records)}&#39; file1 file2",
                "title": "How do I merge 2 json files?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1599436104,
                "creation_date": 1599436104,
                "answer_id": 63769853,
                "question_id": 63768922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can avoid creating an initial array with `inputs`.\r\n\r\n**(A) If you just want the objects**\r\n\r\n    jq -n &#39;inputs | .records[]&#39;\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;itemID&quot;: 128,\r\n      &quot;name&quot;: &quot;foo barn&quot;\r\n    }\r\n    {\r\n      &quot;itemID&quot;: 64,\r\n      &quot;name&quot;: &quot;fee fom&quot;\r\n    }\r\n    {\r\n      &quot;itemID&quot;: 32,\r\n      &quot;name&quot;: &quot;pim pom&quot;\r\n    }\r\n    {\r\n      &quot;itemID&quot;: 256,\r\n      &quot;name&quot;: &quot;ping pong&quot;\r\n    }\r\n\r\n**(B) If you want the objects in an array**\r\n\r\n    jq -n &#39;reduce inputs as $in ([]; . += ($in.records))&#39;\r\n\r\nResult:\r\n\r\n    [\r\n      {\r\n        &quot;itemID&quot;: 128,\r\n        &quot;name&quot;: &quot;foo barn&quot;\r\n      },\r\n      {\r\n        &quot;itemID&quot;: 64,\r\n        &quot;name&quot;: &quot;fee fom&quot;\r\n      },\r\n      {\r\n        &quot;itemID&quot;: 32,\r\n        &quot;name&quot;: &quot;pim pom&quot;\r\n      },\r\n      {\r\n        &quot;itemID&quot;: 256,\r\n        &quot;name&quot;: &quot;ping pong&quot;\r\n      }\r\n    ]\r\n\r\n**(C) If you want the objects in an array named &quot;records&quot;**\r\n\r\n    jq -n &#39;reduce inputs as $in ({}; .[&quot;records&quot;] += ($in.records))&#39;\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;records&quot;: [\r\n        {\r\n          &quot;itemID&quot;: 128,\r\n          &quot;name&quot;: &quot;foo barn&quot;\r\n        },\r\n        {\r\n          &quot;itemID&quot;: 64,\r\n          &quot;name&quot;: &quot;fee fom&quot;\r\n        },\r\n        {\r\n          &quot;itemID&quot;: 32,\r\n          &quot;name&quot;: &quot;pim pom&quot;\r\n        },\r\n        {\r\n          &quot;itemID&quot;: 256,\r\n          &quot;name&quot;: &quot;ping pong&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "How do I merge 2 json files?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1599436104,
        "creation_date": 1599426584,
        "last_edit_date": 1599428057,
        "question_id": 63768922,
        "body_markdown": "file1:\r\n```\r\n{\r\n    &quot;status&quot;: {\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;recordsTotal&quot;: 6,\r\n        &quot;recordsInResponse&quot;: 2\r\n    },\r\n    &quot;records&quot;: [\r\n        {\r\n            &quot;itemID&quot;: 128,\r\n            &quot;name&quot;: &quot;foo barn&quot;\r\n        },\r\n        {\r\n            &quot;itemID&quot;: 64,\r\n            &quot;name&quot;: &quot;fee fom&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nfile2:\r\n```\r\n{\r\n    &quot;status&quot;: {\r\n        &quot;errorCode&quot;: 0,\r\n        &quot;recordsTotal&quot;: 6,\r\n        &quot;recordsInResponse&quot;: 2\r\n    },\r\n    &quot;records&quot;: [\r\n        {\r\n            &quot;itemID&quot;: 32,\r\n            &quot;name&quot;: &quot;pim pom&quot;\r\n        },\r\n        {\r\n            &quot;itemID&quot;: 256,\r\n            &quot;name&quot;: &quot;ping pong&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nwanted:\r\n```\r\n&quot;records&quot;: [ // records array is not needed, having just items iterated is fine as well.\r\n    {\r\n        &quot;itemID&quot;: 128,\r\n        &quot;name&quot;: &quot;foo barn&quot;\r\n    },\r\n    {\r\n        &quot;itemID&quot;: 64,\r\n        &quot;name&quot;: &quot;fee fom&quot;\r\n    },\r\n    {\r\n        &quot;itemID&quot;: 32,\r\n        &quot;name&quot;: &quot;pim pom&quot;\r\n    },\r\n    {\r\n        &quot;itemID&quot;: 256,\r\n        &quot;name&quot;: &quot;ping pong&quot;\r\n    }\r\n]\r\n```\r\n\r\nFrom what I have tried, I have dismissed filtering the records, focused on only combining the files.\r\nI&#39;m not very knowlegable with `jq`. I got the nearest results with:\r\n - `jq -s &#39;.[0] += .[1]&#39;`\r\n - `jq -s &#39;.[0] |= . + .[1]&#39;`\r\n\r\nHow do I merge 2 json files, probably with `jq`?",
        "link": "https://stackoverflow.com/questions/63768922/how-do-i-merge-2-json-files",
        "title": "How do I merge 2 json files?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599447385,
                "last_edit_date": 1599447385,
                "creation_date": 1599446400,
                "answer_id": 63770697,
                "question_id": 63770596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Does this help you solve your issue:\r\n```\r\njq -r &#39;.items[].metadata.labels| to_entries|map(&quot;\\(.key)=\\(.value)&quot;) |join(&quot;;&quot;)&#39;\r\n// Output:\r\n// beta.kubernetes.io/arch=amd64;beta.kubernetes.io/os=linux;node-role.kubernetes.io/master=\r\n```\r\n",
                "title": "jq construct key and value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599447385,
        "creation_date": 1599445288,
        "question_id": 63770596,
        "body_markdown": "I have JSON file as below:\r\n\r\n    {\r\n       &quot;metadata&quot;:{\r\n          &quot;selfLink&quot;:&quot;/api/v1/nodes&quot;,\r\n          &quot;resourceVersion&quot;:&quot;6666628&quot;\r\n       },\r\n       &quot;items&quot;:[\r\n          {\r\n             &quot;metadata&quot;:{\r\n                &quot;name&quot;:&quot;d50d-sa-app23&quot;,\r\n                &quot;selfLink&quot;:&quot;/api/v1/nodes/d50d-sa-app23&quot;,\r\n                &quot;uid&quot;:&quot;86a0e0b7-e9da-4489-86bd-0b6a7aafe102&quot;,\r\n                &quot;resourceVersion&quot;:&quot;6666622&quot;,\r\n                &quot;creationTimestamp&quot;:&quot;2020-07-07T12:34:08Z&quot;,\r\n                &quot;labels&quot;:{\r\n                   &quot;beta.kubernetes.io/arch&quot;:&quot;amd64&quot;,\r\n                   &quot;beta.kubernetes.io/os&quot;:&quot;linux&quot;,\r\n                   &quot;node-role.kubernetes.io/master&quot;:&quot;&quot;\r\n                }\r\n    \t      }\r\n    \t  }\r\n    \t]\r\n    }\r\n\r\nThe desired output is below. **Please note that the name and number of label are not fixed.**\r\n\r\n    beta.kubernetes.io/arch=amd64;beta.kubernetes.io/os=linux;node-role.kubernetes.io/master=\r\n\r\n\r\nI know how to get keys and values pair separately. like below, but I don&#39;t know to pair key &amp; value together.\r\n\r\n    .items[] | ((.metadata.labels | keys | join(&quot;,&quot;)) + &quot;=&quot; + (.metadata.labels | join(&quot;;&quot;)))\r\n\r\nCan anyone help?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63770596/jq-construct-key-and-value-pair",
        "title": "jq construct key and value pair"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599458411,
                "post_id": 63771419,
                "comment_id": 112770057,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4823886,
                    "reputation": 85,
                    "user_id": 3893836,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/7822a9d7d6bfb2eb22e8d7716fd20c6f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3893836",
                    "link": "https://stackoverflow.com/users/3893836/user3893836"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599458540,
                "post_id": 63771419,
                "comment_id": 112770082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599468228,
                "last_edit_date": 1599468228,
                "creation_date": 1599462145,
                "answer_id": 63772776,
                "question_id": 63771419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following your lead, let&#39;s start with:\r\n```\r\n.items[] .spec.ports[] | to_entries | map(&quot;port01\\(.key)=\\(.value)&quot;) | join(&quot;;&quot;)\r\n```\r\nThis has two problems with respect to the first set of requirements:\r\n\r\na) it produces three separate strings;\r\nb) &quot;port01&quot; is hardwired into the prefix.\r\n\r\nThe first issue can be resolved by wrapping the relevant subexpression in square brackets, and then using join(&quot;;&quot;) again.\r\n\r\nTo resolve the second issue, it helps to have a helper function for inserting leading zeros. The following would suffice:\r\n```\r\ndef leadingZeros($n): tostring | &quot;0&quot;*($n - length) + .;\r\n```\r\nThis can now be used to solve the problem according to the first set of requirements:\r\n\r\n```\r\n.items[].spec\r\n| [.ports\r\n   | range(0;length) as $ix\r\n   | .[$ix]\r\n   | to_entries\r\n   | map(&quot;port\\($ix+1|leadingZeros(2))\\(.key)=\\(.value)&quot;)\r\n   | join(&quot;;&quot;) ]\r\n| join(&quot;;&quot;)\r\n```\r\n## Global index\r\nIf the requirements were modified to require the port indices to be global, we could go with the following variant:\r\n```\r\ndef addIndex(stream): foreach stream as $x (0; .+1; [., $x]);\r\n\r\naddIndex(.items[].spec.ports[])\r\n  | (.[0]|leadingZeros(2)) as $ix\r\n  | .[1]\r\n  | to_entries\r\n  | map(&quot;port\\($ix)\\(.key)=\\(.value)&quot;)\r\n  | join(&quot;;&quot;) \r\n```\r\n\r\nWith the -r command-line option, this produces one line per port:\r\n\r\n```\r\nport01name=https;port01protocol=TCP;port01port=443;port01targetPort=6443\r\nport02name=http;port02protocol=TCP;port02port=80;port02targetPort=8080\r\nport03protocol=TCP;port03port=80;port03targetPort=80;port03nodePort=40001\r\n```",
                "title": "jq add additional variable prefix"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1599495967,
        "creation_date": 1599453271,
        "last_edit_date": 1599495967,
        "question_id": 63771419,
        "body_markdown": "I recently asked a couple of jq paring questions, and with all of the perfect answers, I did learn a lot. I hope this question is still possible..\r\n\r\n    {\r\n       &quot;kind&quot;:&quot;ServiceList&quot;,\r\n       &quot;apiVersion&quot;:&quot;v1&quot;,\r\n       &quot;items&quot;:[\r\n          {\r\n             &quot;spec&quot;:{\r\n                &quot;ports&quot;:[\r\n                   {\r\n                      &quot;name&quot;:&quot;https&quot;,\r\n                      &quot;protocol&quot;:&quot;TCP&quot;,\r\n                      &quot;port&quot;:443,\r\n                      &quot;targetPort&quot;:6443\r\n                   },\r\n                                  {\r\n                      &quot;name&quot;:&quot;http&quot;,\r\n                      &quot;protocol&quot;:&quot;TCP&quot;,\r\n                      &quot;port&quot;:80,\r\n                      &quot;targetPort&quot;:8080\r\n                   }\r\n                ],\r\n                &quot;clusterIP&quot;:&quot;10.233.0.1&quot;,\r\n                &quot;type&quot;:&quot;ClusterIP&quot;,\r\n                &quot;sessionAffinity&quot;:&quot;None&quot;\r\n             },\r\n             &quot;status&quot;:{\r\n                &quot;loadBalancer&quot;:{\r\n                   \r\n                }\r\n             }\r\n          },\r\n          {\r\n             &quot;spec&quot;:{\r\n                &quot;ports&quot;:[\r\n                   {\r\n                      &quot;protocol&quot;:&quot;TCP&quot;,\r\n                      &quot;port&quot;:80,\r\n                      &quot;targetPort&quot;:80,\r\n                      &quot;nodePort&quot;:40001\r\n                   }\r\n                ],\r\n                &quot;selector&quot;:{\r\n                   &quot;run&quot;:&quot;my-httpd&quot;\r\n                },\r\n                &quot;clusterIP&quot;:&quot;10.233.27.102&quot;,\r\n                &quot;type&quot;:&quot;NodePort&quot;,\r\n                &quot;sessionAffinity&quot;:&quot;None&quot;,\r\n                &quot;externalTrafficPolicy&quot;:&quot;Cluster&quot;\r\n             },\r\n             &quot;status&quot;:{\r\n                &quot;loadBalancer&quot;:{\r\n                   \r\n                }\r\n             }\r\n          }\r\n       ]\r\n    }\r\n\r\nThe desired output is:\r\n\r\n    port01name=https;port01protocol=TCP;port01port=443;port01targetPort=6443;port02name=http;port02protocol=TCP;port02port=80;port02targetPort=8080\r\n    port01protocol=TCP;port01port=80;port01targetPort=80;port01nodePort=40001\r\n\r\nIt basically concatenates multiple ports per item into 1 line and put extra port{n} as a prefix. \r\n\r\nIs it still possible to be done in jq?\r\n\r\nAlternatively, the output can be below, and I tried to manipulate it afterward.\r\n\r\n    portname=https;portprotocol=TCP;portport=443;porttargetPort=6443;portname=http;portprotocol=TCP;portport=80;porttargetPort=8080\r\n    portprotocol=TCP;portport=80;porttargetPort=80;portnodePort=400",
        "link": "https://stackoverflow.com/questions/63771419/jq-add-additional-variable-prefix",
        "title": "jq add additional variable prefix"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1599478127,
                "last_edit_date": 1599478127,
                "creation_date": 1599477754,
                "answer_id": 63776618,
                "question_id": 63776066,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do not let your shell variables to be interpolated in `jq` under double quotes. The error is because of spaces in the value field, the variable `$value` undergoes word-splitting by and the filter expression of `jq` gets two words `Wisozk` and `Inc` instead of `&quot;Wisozk Inc&quot;`. \r\n\r\nJust pass your variables to `jq`&#39;s context using the `--arg` field and let it deal with it.\r\n\r\n    jq --arg k supplier --arg v &quot;Wisozk Inc&quot; &#39;map(select(.[$k] == $v))&#39; json\r\n\r\n---\r\n\r\nThis question is in parts duplicate to both the below questions, but not as a whole.\r\n\r\n - [passing arguments to jq filter][1]\r\n - [Passing bash variable to jq][2]\r\n\r\n\r\n  [1]: https://stackoverflow.com/q/34745451/5291015\r\n  [2]: https://stackoverflow.com/q/40027395/5291015",
                "title": "Error trying to pass both key and value to a jq filter expression"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599478900,
        "creation_date": 1599475631,
        "last_edit_date": 1599478900,
        "question_id": 63776066,
        "body_markdown": "I am trying to query json using jq in bash scripting\r\n\r\nfile customers.json contains the following\r\n```\r\n[\r\n  {\r\n    &quot;_id&quot;: &quot;5968dd23fc13ae04d9000001&quot;,\r\n    &quot;product_name&quot;: &quot;sildenafil citrate&quot;,\r\n    &quot;supplier&quot;: &quot;Wisozk Inc&quot;,\r\n    &quot;quantity&quot;: 262,\r\n    &quot;unit_cost&quot;: &quot;$1047&quot;\r\n  },\r\n  {\r\n    &quot;_id&quot;: &quot;5968dd23fc13ae04d9000002&quot;,\r\n    &quot;product_name&quot;: &quot;Mountain Juniperus ashei&quot;,\r\n    &quot;supplier&quot;: &quot;Keebler-Hilpert&quot;,\r\n    &quot;quantity&quot;: 292,\r\n    &quot;unit_cost&quot;: &quot;$874&quot;\r\n  },\r\n  {\r\n    &quot;_id&quot;: &quot;5968dd23fc13ae04d9000003&quot;,\r\n    &quot;product_name&quot;: &quot;Dextromathorphan HBr&quot;,\r\n    &quot;supplier&quot;: &quot;Schmitt-Weissnat&quot;,\r\n    &quot;quantity&quot;: 211,\r\n    &quot;unit_cost&quot;: &quot;$2053&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\nwhen i run following bash script\r\n```\r\nkey=&quot;supplier&quot;\r\nvalue=&quot;Wisozk Inc&quot;\r\njq &quot;.[] | select(.$key==$value)&quot; customers.json\r\n```\r\nIt throws the following error\r\n\r\n```\r\njq: error: syntax error, unexpected IDENT, expecting &#39;;&#39; or &#39;)&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[] | select(.supplier == Wisozk Inc)\r\njq: 1 compile error\r\n```\r\nI think the space between &quot;Wisozk&quot; and &quot;Inc&quot; is the problem, what to do?\r\n",
        "link": "https://stackoverflow.com/questions/63776066/error-trying-to-pass-both-key-and-value-to-a-jq-filter-expression",
        "title": "Error trying to pass both key and value to a jq filter expression"
    },
    {
        "tags": [
            "json",
            "dynamic",
            "nested",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1599657835,
                "last_edit_date": 1599657835,
                "creation_date": 1599594414,
                "answer_id": 63800654,
                "question_id": 63800060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use jq&#39;s so-called &quot;$-variables&quot;, e.g.\r\n```\r\nto_entries\r\n| map_values(\r\n    (.value|keys[0]) as $innerkey\r\n    | { name: .key,\r\n        version: $innerkey,\r\n        regular: .value[$innerkey].size.regular,\r\n        compressed: .value[$innerkey].size.compressed\r\n})\r\n\r\n```\r\nYou could also introduce a variable for `.value[$innerkey].size`, or better yet, simplify:\r\n```\r\nto_entries\r\n| map_values(\r\n    (.value|keys[0]) as $innerkey\r\n    | { name: .key, version: $innerkey }\r\n      + .value[$innerkey].size )\r\n```\r\n\r\nPlease note that `keys` sorts the keys, so although it does not much matter in this case, using `keys_unsorted` is a possibility worth bearing in mind.",
                "title": "How do I derive dynamic keys from a nested JSON object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1599657835,
        "creation_date": 1599591568,
        "question_id": 63800060,
        "body_markdown": "I&#39;m using `jq` to transform a JSON input with some nested dynamic keys in this format:\r\n```\r\n{\r\n  &quot;somePackage&quot;: {\r\n    &quot;someVersion&quot;: {\r\n      &quot;size&quot;: {\r\n        &quot;regular&quot;: 1234,\r\n        &quot;compressed&quot;: 123\r\n      }\r\n    }\r\n  },\r\n  &quot;someOtherPackage&quot;: {\r\n    &quot;someOtherVersion&quot;: {\r\n      &quot;size&quot;: {\r\n        &quot;regular&quot;: 5678,\r\n        &quot;compressed&quot;: 567\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n... into an array of objects in this format:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;somePackage&quot;,\r\n    &quot;version&quot;: &quot;someVersion&quot;,\r\n    &quot;regular&quot;: 1234,\r\n    &quot;compressed&quot;: 123\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;someOtherPackage&quot;,\r\n    &quot;version&quot;: &quot;someOtherVersion&quot;,\r\n    &quot;regular&quot;: 5678,\r\n    &quot;compressed&quot;: 567\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve managed to do it using:\r\n```\r\njq &#39;to_entries | map_values({\r\n  name: .key,\r\n  version: .value|keys[0],\r\n  regular: .value[.value|keys[0]].size.regular,\r\n  compressed: .value[.value|keys[0]].size.compressed\r\n})&#39; input.json\r\n```\r\n\r\nIs there a way to access the dynamic keys of each level in the original JSON so I can use them as values in my output with less repetition?",
        "link": "https://stackoverflow.com/questions/63800060/how-do-i-derive-dynamic-keys-from-a-nested-json-object-with-jq",
        "title": "How do I derive dynamic keys from a nested JSON object with jq?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 143796,
                    "reputation": 6134,
                    "user_id": 352403,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/6e8473a08926aca6bea5d246ed15e697?s=256&d=identicon&r=PG",
                    "display_name": "souser",
                    "link": "https://stackoverflow.com/users/352403/souser"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1599601721,
                "post_id": 63801953,
                "comment_id": 112822519,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1599602231,
                "post_id": 63801953,
                "comment_id": 112822636,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 12,
                "is_accepted": true,
                "score": 12,
                "last_activity_date": 1599610407,
                "creation_date": 1599610407,
                "answer_id": 63803079,
                "question_id": 63801953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, you can stick square brackets around any expression to gather all its outputs into an array.\r\n```\r\n[.[] | select(.location==&quot;Stockholm&quot;)]\r\n```\r\nSometimes it makes sense not to break up the input array in the first place, but use map to transform it:\r\n```\r\nmap(select(.location==&quot;Stockholm&quot;))\r\n```",
                "title": "JQ: How to turn output of array selector back into an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1599615997,
        "creation_date": 1599601383,
        "last_edit_date": 1599615997,
        "question_id": 63801953,
        "body_markdown": "I&#39;m using the select function with jq to parse for items in a list that contain a certain value.  I want the resulting output to be a json list, but jq gives me the objects individually:\r\n\r\nExample:\r\n\r\n```\r\n$ a=&#39;{                                                                                   \r\n  &quot;FOO&quot;: {                                                                                    \r\n    &quot;name&quot;: &quot;Donald&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  &quot;BAR&quot;: {\r\n    &quot;name&quot;: &quot;Walt&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  &quot;BAZ&quot;: {\r\n    &quot;name&quot;: &quot;Jack&quot;,\r\n    &quot;location&quot;: &quot;Whereever&quot;\r\n  }\r\n}&#39;\r\n\r\n$ echo $a | jq &#39;.[] | select(.location==&quot;Stockholm&quot;)&#39; \r\n{\r\n  &quot;name&quot;: &quot;Donald&quot;,\r\n  &quot;location&quot;: &quot;Stockholm&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Walt&quot;,\r\n  &quot;location&quot;: &quot;Stockholm&quot;\r\n}\r\n```\r\n\r\nInstead I want the output to be a json list like this:\r\n\r\n```\r\n[  \r\n  {\r\n    &quot;name&quot;: &quot;Donald&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;Walt&quot;,\r\n    &quot;location&quot;: &quot;Stockholm&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow can I do this with jq?",
        "link": "https://stackoverflow.com/questions/63801953/jq-how-to-turn-output-of-array-selector-back-into-an-array",
        "title": "JQ: How to turn output of array selector back into an array?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1599640217,
                "last_edit_date": 1599640217,
                "creation_date": 1599638680,
                "answer_id": 63807296,
                "question_id": 63807082,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to only mark &quot;that&quot; desired object for update, ways you can do that would be to use below which selects the update to be performed from the standpoint of the rootnode.\r\n\r\n    ( .routing.rules[] | \r\n     select(.outboundTag==$out_tag) | .inboundTag ) += [$in_tag]\r\n\r\nOne other way would be to use the update assignment operator `|=`, to select the object under `rules` containing your outbound tag and append to its `inboundTag`\r\n\r\n    .routing.rules |= ( map(select(.outboundTag==$out_tag).inboundTag += [$in_tag]  ) )",
                "title": "Append to an array of a nested element in jq but return root object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599640217,
        "creation_date": 1599637927,
        "last_edit_date": 1599638794,
        "question_id": 63807082,
        "body_markdown": "My json looks like this:\r\n```json\r\n{\r\n  &quot;routing&quot;: {\r\n    &quot;rules&quot;: [{\r\n      &quot;type&quot;: &quot;field&quot;,\r\n      &quot;inboundTag&quot;: [&quot;input&quot;],\r\n      &quot;outboundTag&quot;: &quot;vpn-out&quot;\r\n    },{\r\n      &quot;type&quot;: &quot;field&quot;,\r\n      &quot;inboundTag&quot;: [&quot;alternate&quot;],\r\n      &quot;outboundTag&quot;: &quot;raw-out&quot;\r\n    }]\r\n  }\r\n}\r\n\r\n```\r\nI want to append to the `.routing.rules[].inboundTag` array where the `outboundTag` has the value of &quot;vpn-out&quot;. At the same time I want the modified root object returned so that I can save it into a bash variable.\r\n\r\nSo far I have:\r\n```bash\r\n  config=$(echo &quot;$config&quot; | jq \\\r\n    --arg out_tag &quot;$outbound_tag&quot; \\\r\n    --arg in_tag &quot;$inbound_tag&quot; \\\r\n    &#39;.routing.rules[] | select(.outboundTag==$out_tag) | .inboundTag += [$in_tag]&#39;)\r\n```\r\n\r\nThe problem is that the `select`ed object is returned rather than the root object. How can I modify the code to return the root?\r\n\r\n[Here is a jq-play link][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/uNtAiHhWhj",
        "link": "https://stackoverflow.com/questions/63807082/append-to-an-array-of-a-nested-element-in-jq-but-return-root-object",
        "title": "Append to an array of a nested element in jq but return root object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599658062,
                "post_id": 63812530,
                "comment_id": 112841162,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599657624,
                "creation_date": 1599657624,
                "answer_id": 63812605,
                "question_id": 63812530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here:\r\n```\r\njq ._source.ActionId\r\n// returns:\r\n// &quot;ecdc38f369e3&quot;\r\n```\r\n",
                "title": "query underscore character with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599657815,
                "creation_date": 1599657815,
                "answer_id": 63812654,
                "question_id": 63812530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try this:\r\n\r\n    cat so.json | jq ._source.Status\r\n    &quot;OK&quot;\r\n\r\n    cat so.json | jq ._source.ActionId\r\n    &quot;ecdc38f369e3&quot;",
                "title": "query underscore character with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1599659608,
        "creation_date": 1599657359,
        "last_edit_date": 1599659608,
        "question_id": 63812530,
        "body_markdown": "I am trying to get the `ActionId` and *not* &quot;Status=OK&quot; in the following JSON with jq.\r\n\r\nI have tried the following query. but with no success:\r\n\r\n    jq &#39;_source,.Status&#39;\r\n\r\nIt doesn&#39;t work because `_source` contains the underscore character.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;_index&quot;: &quot;filebeat-7.2.0-2020.09.06-000060&quot;,\r\n    &quot;_type&quot;: &quot;_doc&quot;,\r\n    &quot;_version&quot;: 1,\r\n    &quot;_score&quot;: null,\r\n    &quot;_source&quot;: {\r\n      &quot;@timestamp&quot;: &quot;2020-09-09T11:34:21.192Z&quot;,\r\n      &quot;ActionName&quot;: &quot;Service&quot;,\r\n      &quot;ConnectionId&quot;: &quot;53NCBP&quot;,\r\n      &quot;Method&quot;: &quot;POST&quot;,\r\n      &quot;ActionId&quot;: &quot;ecdc38f369e3&quot;,\r\n      &quot;stream&quot;: &quot;stdout&quot;,\r\n      &quot;RequestId&quot;: &quot;0HM2D6Q53NC1&quot;,\r\n      &quot;Status&quot;: &quot;OK&quot;,\r\n      &quot;@t&quot;: &quot;2020-09-09T11:34:21.1926712Z&quot;,\r\n      &quot;input&quot;: {\r\n        &quot;type&quot;: &quot;docker&quot;\r\n      },\r\n      &quot;IP&quot;: &quot;1.1.1.1&quot; \r\n    },\r\n    &quot;fields&quot;: {\r\n      &quot;@timestamp&quot;: [\r\n        &quot;2020-09-09T11:34:21.192Z&quot;\r\n      ],\r\n      &quot;s.timestamp&quot;: [\r\n        &quot;2020-09-09T11:34:21.192Z&quot;\r\n      ]\r\n    },\r\n    &quot;sort&quot;: [\r\n      1599651261192\r\n    ]\r\n  },\r\n```",
        "link": "https://stackoverflow.com/questions/63812530/query-underscore-character-with-jq",
        "title": "query underscore character with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "edit"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599662052,
                "post_id": 63813622,
                "comment_id": 112843321,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599664939,
                "last_edit_date": 1599664939,
                "creation_date": 1599661431,
                "answer_id": 63813723,
                "question_id": 63813622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to select by indices, simply use the array value iterator syntax for specifying the indices to retain\r\n\r\n    .a.b |= [ .[1, 2] ]\r\n\r\n---\r\n\r\nThe following updates were provided before the question as modified to clear out the actual requirements. Retaining it for posterity\r\n\r\n**Selecting by value**\r\n\r\n    .a.b |= map(select(. == 22))\r\n\r\n**Deleting by indices**\r\n\r\nor if you want to delete by indices _if_ they are already known, use `del()` with the path expression as the indices to be deleted. For e.g. the following deletes values at indices 1,2\r\n\r\n    .a.b |= del(.[1, 2])\r\n\r\n\r\n",
                "title": "update whole json by remove all elements from array except the one at given array index"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1599662989,
                "creation_date": 1599662989,
                "answer_id": 63814182,
                "question_id": 63813622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If $i is the relevant index:\r\n\r\n    .a.b |= [.[$i]]\r\n\r\n\r\nFor example:\r\n\r\n    jq --argjson i 1 &#39;.a.b |= [.[$i]]&#39; input.json\r\n",
                "title": "update whole json by remove all elements from array except the one at given array index"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1599664939,
        "creation_date": 1599661143,
        "last_edit_date": 1599663221,
        "question_id": 63813622,
        "body_markdown": "Whole json structure to be kept, but in one array I&#39;d like to remove all values but one on given index.\r\n\r\nInput:\r\n\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [11,22,33,44]\r\n        }\r\n        \r\n    }\r\n\r\nDesired output:\r\n\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [22]\r\n        }\r\n        \r\n    }\r\n\r\n**All I have on input to identify item to be deleted is its index in array.**\r\n\r\nI thought:\r\n\r\n    .a.b|=map(select(&lt;SELECT_WHAT?&gt;))\r\n\r\nmaybe I could do `($val | index(.)) == &lt;desiredIndex&gt;` within select, but with |= I don&#39;t know how to declare variable, and it does not seem very efficient ...\r\n",
        "link": "https://stackoverflow.com/questions/63813622/update-whole-json-by-remove-all-elements-from-array-except-the-one-at-given-arra",
        "title": "update whole json by remove all elements from array except the one at given array index"
    },
    {
        "tags": [
            "bash",
            "jq",
            "string-interpolation"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1599670420,
                "last_edit_date": 1599670420,
                "creation_date": 1599670269,
                "answer_id": 63816130,
                "question_id": 63816061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The way you&#39;re inserting `${OPTIONAL_FILTER}` is causing it to be split into multiple words, meaning `jq` receives more arguments than it&#39;s expecting. Bash interprets the command as if you&#39;d written:\r\n\r\n```\r\njq &#39;to_entries[] |&#39; &#39;select(.key&#39; &#39;==&#39; &#39;&quot;key2&quot;)&#39; &#39;| .value.name&#39; &lt;&lt;&lt; $JSON\r\n```\r\n\r\nYou can quote it to ensure it remains a single word:\r\n\r\n```\r\njq &#39;to_entries[] &#39;&quot;${OPTIONAL_FILTER}&quot;&#39; | .value.name&#39; &lt;&lt;&lt; $JSON\r\n```\r\n\r\nOr use double quotes throughout so you don&#39;t have to jump in and out of single quotes:\r\n\r\n```\r\njq &quot;to_entries[] ${OPTIONAL_FILTER} | .value.name&quot; &lt;&lt;&lt; $JSON\r\n```\r\n\r\nFor more information see:\r\n\r\n* [Advanced Bash-Scripting Guide: Quoting Variables](https://tldp.org/LDP/abs/html/quotingvar.html)",
                "title": "&quot;Unexpected $end&quot; when using bash variables"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1599680483,
                "creation_date": 1599680483,
                "answer_id": 63818530,
                "question_id": 63816061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Manipulating program text by string interpolation is almost always best avoided if possible; fortunately, using jq, to my knowledge, it&#39;s always not only possible but also quite straightforward.  \r\n\r\nIn the present case, you could for example use the --arg command-line option, like so:\r\n\r\n```\r\njq --arg flag &quot;$FLAG&quot; &#39;\r\n  to_entries[]\r\n  | if $flag == &quot;value&quot; then select(.key == &quot;key2&quot;)\r\n    else . end\r\n  | .value.name&#39; &lt;&lt;&lt; $JSON\r\n```\r\n",
                "title": "&quot;Unexpected $end&quot; when using bash variables"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1599907326,
        "creation_date": 1599669992,
        "last_edit_date": 1599907326,
        "question_id": 63816061,
        "body_markdown": "I&#39;ve got a fairly simple bash script where I want to enable or disable a jq filter based on the value of an environment variable.\r\n\r\nHere&#39;s a simplified version of the script:\r\n\r\n```bash\r\nJSON=&#39;{ &quot;key1&quot;: { &quot;name&quot;:&quot;foo&quot; }, &quot;key2&quot;: { &quot;name&quot;:&quot;bar&quot; } }&#39;\r\nOPTIONAL_FILTER=&quot;&quot;\r\nif [[ &quot;$FLAG&quot; == &quot;value&quot; ]]; then\r\n\tOPTIONAL_FILTER=&#39;| select(.key == &quot;key2&quot;)&#39;\r\nfi\r\njq &#39;to_entries[] &#39;${OPTIONAL_FILTER}&#39; | .value.name&#39; &lt;&lt;&lt; $JSON\r\n```\r\n\r\nWhen I run the script with `FLAG=&quot;&quot;`, then everything works as expected and I get the output:\r\n\r\n```json\r\n&quot;foo&quot;\r\n&quot;bar&quot;\r\n```\r\n\r\nBut if I set `FLAG=&quot;value&quot;`, then I get the following error:\r\n\r\n```none\r\njq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nto_entries[] |\r\njq: 1 compile error\r\n```\r\n\r\nWhen I run the same commands in zsh, I do not get this error and I get the expected output of just `&quot;foo&quot;`\r\n\r\nI am not very experienced in shell scripting. I&#39;m guessing that there&#39;s a null character or some other input terminator like that being inserted into my string, but I haven&#39;t been able to confirm that or to find out a good alternative. It&#39;s especially vexing because it seems to be shell-specific. zsh, which I use for most of my testing, handles the code just fine. I only get that error when I attempt to run a `.sh` script that I see the error.\r\n\r\nThe ultimate goal is to get the optional filter working correctly. I am open to alternatives if there is a jq-specific option that I&#39;ve missed. I tried using `jq &#39;to_entries[] $ENV.OPTIONAL_FILTER | .value.name&#39; &lt;&lt;&lt; $JSON`, but got `jq: error: syntax error, unexpected &#39;$&#39;, expecting $end`\r\n\r\n```\r\n&gt; bash --version\r\nGNU bash, version 3.2.57(1)-release (x86_64-apple-darwin18)\r\n```",
        "link": "https://stackoverflow.com/questions/63816061/unexpected-end-when-using-bash-variables",
        "title": "&quot;Unexpected $end&quot; when using bash variables"
    },
    {
        "tags": [
            "json",
            "file",
            "merge",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599695369,
                "post_id": 63819013,
                "comment_id": 112856229,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1599695710,
                "creation_date": 1599695710,
                "answer_id": 63821000,
                "question_id": 63819013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Once the sample input files have been corrected, the following invocation should do the trick:\r\n```\r\njq --argfile uid sample1.json &#39;\r\n  ($uid | INDEX(.unique_id)) as $dict\r\n  | map( $dict[.netid] + del(.netid) )\r\n&#39; sample2.json\r\n```\r\n\r\nIf you prefer not to use --argfile because it has been deprecated, you could (for example) use --slurpfile and change `$uid` in the jq program to `$uid[0]`.\r\n\r\n",
                "title": "using jq to merge two json values based on key value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1599916875,
        "creation_date": 1599682812,
        "last_edit_date": 1599916875,
        "question_id": 63819013,
        "body_markdown": "i have two json files that i would like to merge based on the value of a key. the key name is different in both json files but the value would be the same. i am using jq to try to get this done. most of the examples i have found all merge based on key name and not value.  \r\n\r\n**sample1.json**\r\n\r\n     [\r\n      {\r\n        &quot;unique_id&quot;: &quot;pp1234&quot;,\r\n        &quot;unique_id_type&quot;: &quot;netid&quot;,\r\n        &quot;rfid&quot;: &quot;12245556890478&quot;,\r\n     },\r\n    {\r\n        &quot;unique_id&quot;: &quot;aqe123&quot;,\r\n        &quot;unique_id_type&quot;: &quot;netid&quot;,\r\n        &quot;rfid&quot;: &quot;12234556890478&quot;,\r\n     }\r\n    ] \r\n\r\n**sample2.json**\r\n\r\n    [\r\n     {\r\n     &quot;mailing_state&quot;: &quot;New York&quot;,\r\n      &quot;mobile_phone_number&quot;: &quot;(982) 2541212&quot;,\r\n      &quot;netid&quot;: &quot;pp1234&quot;,\r\n      &quot;netid_reachable&quot;: &quot;Y&quot;,\r\n     },\r\n     {\r\n     &quot;mailing_state&quot;: &quot;New York&quot;,\r\n      &quot;mobile_phone_number&quot;: &quot;(982) 5551212&quot;,\r\n      &quot;netid&quot;: &quot;aqe123&quot;,\r\n      &quot;netid_reachable&quot;: &quot;Y&quot;,\r\n     }\r\n    ] \r\n\r\ni would want the output to look something like:\r\n\r\n**results.json**\r\n   \r\n\r\n     [\r\n          {\r\n            &quot;unique_id&quot;: &quot;pp1234&quot;,\r\n            &quot;unique_id_type&quot;: &quot;netid&quot;,\r\n            &quot;rfid&quot;: &quot;12245556890478&quot;,\r\n            &quot;mailing_state&quot;: &quot;New York&quot;,\r\n            &quot;mobile_phone_number&quot;: &quot;(982) 2541212&quot;,\r\n            &quot;netid_reachable&quot;: &quot;Y&quot;,\r\n         },\r\n         {\r\n            &quot;unique_id&quot;: &quot;aqe123&quot;,\r\n            &quot;unique_id_type&quot;: &quot;netid&quot;,\r\n            &quot;rfid&quot;: &quot;12234556890478&quot;,\r\n            &quot;mailing_state&quot;: &quot;New York&quot;,\r\n            &quot;mobile_phone_number&quot;: &quot;(982) 5551212&quot;,\r\n            &quot;netid_reachable&quot;: &quot;Y&quot;,\r\n        }\r\n    ]\r\n\r\n \r\n\r\norder of results would not matter as long as the records are merged based on netid/unique_id keys. i am open to using something other than jq if necessary. thanks in advance. \r\n\r\n",
        "link": "https://stackoverflow.com/questions/63819013/using-jq-to-merge-two-json-values-based-on-key-value",
        "title": "using jq to merge two json values based on key value"
    },
    {
        "tags": [
            "json",
            "jq",
            "variadic-templates",
            "template-engine"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599694754,
                "post_id": 63819015,
                "comment_id": 112856084,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599740792,
                "post_id": 63819015,
                "comment_id": 112871283,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8007387,
                    "reputation": 29,
                    "user_id": 6040304,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-EF26LVFsxIc/AAAAAAAAAAI/AAAAAAAABjE/4AnB7Az4W2k/s256-rj/photo.jpg",
                    "display_name": "MADHU RAGHAV",
                    "link": "https://stackoverflow.com/users/6040304/madhu-raghav"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599745707,
                "post_id": 63819015,
                "comment_id": 112874013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599750225,
                "post_id": 63819015,
                "comment_id": 112876615,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8007387,
                    "reputation": 29,
                    "user_id": 6040304,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-EF26LVFsxIc/AAAAAAAAAAI/AAAAAAAABjE/4AnB7Az4W2k/s256-rj/photo.jpg",
                    "display_name": "MADHU RAGHAV",
                    "link": "https://stackoverflow.com/users/6040304/madhu-raghav"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599751098,
                "post_id": 63819015,
                "comment_id": 112877119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599763065,
                "creation_date": 1599763065,
                "answer_id": 63835812,
                "question_id": 63819015,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution:\r\n```\r\n&lt; abc.json jq --argfile vars xyz.json &#39;\r\n  $vars.dev as $dict\r\n  | .dev |= map_values( $dict[.] // .)&#39;\r\n```\r\n\r\nIf you&#39;re squeamish about using --argfile, you could (for example) use --slurpfile instead, though in that case `$vars.dev` would be replaced by `$vars[0].dev`\r\n",
                "title": "jq compare two jsons and replace the value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599776140,
        "creation_date": 1599682818,
        "last_edit_date": 1599776140,
        "question_id": 63819015,
        "body_markdown": "I have two JSON files\r\n\r\nFilename `Abc.json`\r\n\r\n    {\r\n      &quot;name&quot;: &quot;testfile&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;,\r\n      &quot;dev&quot;: {\r\n        &quot;LoggingLevel&quot;: &quot;DEBUG&quot;,\r\n        &quot;logging.level.HikariPool&quot;: &quot;DEBUG&quot;,\r\n        &quot;spring.testname&quot;: &quot;@@CONSENT_RW@@&quot;,\r\n        &quot;spring.testpassword&quot;: &quot;@@CONSETNPWD@@&quot;\r\n      }\r\n    }\r\n\r\nFilename `xyz.json`\r\n\r\n    {\r\n      &quot;name&quot;: &quot;testset&quot;,\r\n      &quot;version&quot;: &quot;1.0&quot;,\r\n      &quot;dev&quot;: {\r\n        &quot;@@CONSENT_RW@@&quot;: &quot;ARM&quot;,\r\n        &quot;@@CONSETNPWD@@&quot;: &quot;ARMPWD&quot;\r\n      }\r\n    }\r\n\r\nSo if a &quot;dev&quot; value in `abc.json` matches a &quot;dev&quot; key in `xyz.json` then I need to replace the value in `abc.json` by the corresponding value in `xyz.json`.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63819015/jq-compare-two-jsons-and-replace-the-value",
        "title": "jq compare two jsons and replace the value"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599810743,
                "post_id": 63842811,
                "comment_id": 112895112,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19477513,
                    "reputation": 1,
                    "user_id": 14248630,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f0e2ad25fb7a0ad28555a7e6011dba11?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cherry",
                    "link": "https://stackoverflow.com/users/14248630/cherry"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599811101,
                "post_id": 63842811,
                "comment_id": 112895272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19477513,
                    "reputation": 1,
                    "user_id": 14248630,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f0e2ad25fb7a0ad28555a7e6011dba11?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cherry",
                    "link": "https://stackoverflow.com/users/14248630/cherry"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599811243,
                "post_id": 63842811,
                "comment_id": 112895336,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599812238,
                "post_id": 63842811,
                "comment_id": 112895795,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19477513,
                    "reputation": 1,
                    "user_id": 14248630,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f0e2ad25fb7a0ad28555a7e6011dba11?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cherry",
                    "link": "https://stackoverflow.com/users/14248630/cherry"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599818908,
                "post_id": 63842811,
                "comment_id": 112898883,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599820305,
                "creation_date": 1599820305,
                "answer_id": 63845334,
                "question_id": 63842811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the JSON file is just an array of the objects, you don&#39;t need to loop over them in bash. `jq` will loop over them implicitely:\r\n\r\n    jq -r &#39;.[][][] | (.VpcId + &quot;||&quot; + .GroupId)&#39; file.json\r\n\r\nTested on the following input:\r\n\r\n```javascript\r\n[\r\n    { &quot;SG&quot;: [\r\n        {\r\n            &quot;Description&quot;: &quot;des&quot;,\r\n            &quot;GroupName&quot;: &quot;Gpname&quot;,\r\n            &quot;GroupId&quot;: &quot;sg&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-123&quot;\r\n        }\r\n    ] },\r\n    { &quot;SG&quot;: [\r\n        {\r\n            &quot;Description&quot;: &quot;des&quot;,\r\n            &quot;GroupName&quot;: &quot;xyz&quot;,\r\n            &quot;GroupId&quot;: &quot;sg-12345&quot;,\r\n            &quot;VpcId&quot;: &quot;vpc-12345&quot;\r\n        }\r\n    ] }\r\n]\r\n```\r\n\r\nOutput:\r\n\r\n```\r\nvpc-123||sg\r\nvpc-12345||sg-12345\r\n```",
                "title": "Loop on JSON array in bash script and pull data through JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599820305,
        "creation_date": 1599810281,
        "question_id": 63842811,
        "body_markdown": "i want to pull data from jSON file through jq in bash script. I have 50 plus SG objects in JSON . \r\n\r\nhere is an example of one SG . I want to print a VPC id and group id in one line and so on for another objects.\r\n\r\nSolution i tried :\r\n\r\n    jq -c . $old |\r\n    while IFS= read -r obj; do \r\n        vpcidold=$( printf &#39;%s&#39; &quot;$obj&quot; | jq &#39;.SecurityGroups[].VpcId&#39;)\r\n        securityidold=$( printf &#39;%s&#39; &quot;$obj&quot; | jq &#39;.SecurityGroups[].GroupId&#39;)\r\n        echo &quot;${vpcidold}||${securityidold}&quot;\r\n    done &gt; oldtest.json\r\nit is working file but giving data in a line by line and want to do more optimised this with for loop. \r\n\r\nHow can I create a loop on JSON array to get desire output\r\n\r\n        &quot;SG&quot;: [\r\n          {\r\n            &quot;Description&quot;: &quot;des&quot;,\r\n            &quot;GroupName&quot;: &quot;Gpname&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n              {\r\n                &quot;FromPort&quot;: 80,\r\n                &quot;IpProtocol&quot;: &quot;tcp&quot;,\r\n                &quot;IpRanges&quot;: [\r\n                  {\r\n                    &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                  }\r\n                ],\r\n                &quot;Ipv6Ranges&quot;: [],\r\n                &quot;PrefixListIds&quot;: [],\r\n                &quot;ToPort&quot;: 80,\r\n                &quot;UserIdGroupPairs&quot;: []\r\n              }\r\n            ],\r\n            &quot;OwnerId&quot;: &quot;123&quot;,\r\n            &quot;GroupId&quot;: &quot;sg&quot;,\r\n            &quot;IpPermissionsEgress&quot;: [\r\n              {\r\n                &quot;IpProtocol&quot;: &quot;-1&quot;,\r\n                &quot;IpRanges&quot;: [\r\n                  {\r\n                    &quot;CidrIp&quot;: &quot;0.0.0.0/0&quot;\r\n                  }\r\n                ],\r\n                &quot;Ipv6Ranges&quot;: [],\r\n                &quot;PrefixListIds&quot;: [],\r\n                &quot;UserIdGroupPairs&quot;: []\r\n              }\r\n            ],\r\n            &quot;Tags&quot;: [\r\n              {\r\n                &quot;Key&quot;: &quot;projectcode&quot;,\r\n                &quot;Value&quot;: &quot;none&quot;\r\n              },\r\n              {\r\n                &quot;Key&quot;: &quot;sgid&quot;,\r\n                &quot;Value&quot;: &quot;sg-123&quot;\r\n              }\r\n            ],\r\n            &quot;VpcId&quot;: &quot;vpc-123&quot;\r\n          }\r\n        ]\r\n      }, ",
        "link": "https://stackoverflow.com/questions/63842811/loop-on-json-array-in-bash-script-and-pull-data-through-jq",
        "title": "Loop on JSON array in bash script and pull data through JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599819539,
                "post_id": 63844909,
                "comment_id": 112899187,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16647290,
                    "reputation": 23,
                    "user_id": 12031283,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mBGJdlX2Plx3BgsX8EOtijE94lVY4mO6ktHG5i0=k-s256",
                    "display_name": "leitmedium",
                    "link": "https://stackoverflow.com/users/12031283/leitmedium"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599824307,
                "post_id": 63844909,
                "comment_id": 112901364,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1599827705,
                "post_id": 63844909,
                "comment_id": 112903049,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599825684,
                "creation_date": 1599825684,
                "answer_id": 63846692,
                "question_id": 63844909,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can group the actions together using `(..)` as below. Also instead of using the array notation `.[]`, you can use `map(..)` to handle apply the filter expression inside the `result` array\r\n\r\n    .result | map((.newValueJson.action, .oldValueJson.action, .metadata.value ) |= (. | tostring // .))",
                "title": "How to apply function to multiple fields in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599825684,
        "creation_date": 1599818608,
        "last_edit_date": 1599824273,
        "question_id": 63844909,
        "body_markdown": "I try to reduce the size of a jq call. The current command is:\r\n\r\n```shell\r\njq &#39;.result | .[].newValueJson.action |= (. | tostring // .) | .[].oldValueJson.action |= (. | tostring // .) | .[].metadata.value |= (. | tostring // .)&#39;\r\n```\r\n\r\nAs you can see, the function &quot;tostring&quot; is being applied to &quot;newValueJson.action&quot;, &quot;oldValueJson.action&quot; and &quot;metadata.value&quot; in just the same way. I am wondering if there is a more compact syntax so I only need to apply tostring once?\r\n\r\nI extracted sample data show what is being done (this is not the full json tree). \r\n\r\nSource:\r\n```json\r\n{\r\n\t&quot;result&quot;: [{\r\n\t\t\t&quot;id&quot;: 1,\r\n\t\t\t&quot;action&quot;: {\r\n\t\t\t\t&quot;result&quot;: true,\r\n\t\t\t\t&quot;type&quot;: &quot;filter_create&quot;\r\n\t\t\t},\r\n\t\t\t&quot;newValueJson&quot;: {\r\n\t\t\t\t&quot;action&quot;: &quot;simulate&quot;\r\n\t\t\t},\r\n\t\t\t&quot;oldValueJson&quot;: {\r\n\t\t\t\t&quot;action&quot;: &quot;enforce&quot;\r\n\t\t\t},\r\n\t\t\t&quot;metadata&quot;: {\r\n\t\t\t\t&quot;value&quot;: false\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: 2,\r\n\t\t\t&quot;action&quot;: {\r\n\t\t\t\t&quot;result&quot;: true,\r\n\t\t\t\t&quot;type&quot;: &quot;filter_create&quot;\r\n\t\t\t},\r\n\t\t\t&quot;newValueJson&quot;: {\r\n\t\t\t\t&quot;action&quot;: {\r\n\t\t\t\t\t&quot;mode&quot;: &quot;simulate&quot;,\r\n\t\t\t\t\t&quot;timeout&quot;: 3600\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t&quot;oldValueJson&quot;: {\r\n\t\t\t\t&quot;action&quot;: {\r\n\t\t\t\t\t&quot;mode&quot;: &quot;enforce&quot;,\r\n\t\t\t\t\t&quot;timeout&quot;: 3600\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t&quot;metadata&quot;: {\r\n\t\t\t\t&quot;value&quot;: &quot;off&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nResult:\r\n\r\n\r\n```json\r\n[{\r\n\t\t&quot;id&quot;: 1,\r\n\t\t&quot;action&quot;: {\r\n\t\t\t&quot;result&quot;: true,\r\n\t\t\t&quot;type&quot;: &quot;filter_create&quot;\r\n\t\t},\r\n\t\t&quot;newValueJson&quot;: {\r\n\t\t\t&quot;action&quot;: &quot;simulate&quot;\r\n\t\t},\r\n\t\t&quot;oldValueJson&quot;: {\r\n\t\t\t&quot;action&quot;: &quot;enforce&quot;\r\n\t\t},\r\n\t\t&quot;metadata&quot;: {\r\n\t\t\t&quot;value&quot;: &quot;false&quot;\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: 2,\r\n\t\t&quot;action&quot;: {\r\n\t\t\t&quot;result&quot;: true,\r\n\t\t\t&quot;type&quot;: &quot;filter_create&quot;\r\n\t\t},\r\n\t\t&quot;newValueJson&quot;: {\r\n\t\t\t&quot;action&quot;: &quot;{\\&quot;mode\\&quot;:\\&quot;simulate\\&quot;,\\&quot;timeout\\&quot;:3600}&quot;\r\n\t\t},\r\n\t\t&quot;oldValueJson&quot;: {\r\n\t\t\t&quot;action&quot;: &quot;{\\&quot;mode\\&quot;:\\&quot;enforce\\&quot;,\\&quot;timeout\\&quot;:3600}&quot;\r\n\t\t},\r\n\t\t&quot;metadata&quot;: {\r\n\t\t\t&quot;value&quot;: &quot;off&quot;\r\n\t\t}\r\n\t}\r\n]\r\n```\r\n\r\n  \r\n\r\n\r\nThanks and Best.\r\n",
        "link": "https://stackoverflow.com/questions/63844909/how-to-apply-function-to-multiple-fields-in-jq",
        "title": "How to apply function to multiple fields in jq"
    },
    {
        "tags": [
            "json",
            "append",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1599833583,
                "last_edit_date": 1599833583,
                "creation_date": 1599822600,
                "answer_id": 63845914,
                "question_id": 63845393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `--argfile` on the nodekey file, and use that later with the genesis.json file for appending\r\n\r\n    jq --argfile node nodekey.json &#39;.alloc += { ($node.address): {balance: &quot;1000000000000000000000000000&quot;} }&#39; genesis.json\r\n\r\nNote that this will print the resulting output to the terminal. If you want the file to be modified in-place, follow the steps from [Modify a key-value in a json using jq in-place][1].\r\n\r\n\r\n  [1]: https://stackoverflow.com/q/42716734/5291015",
                "title": "Use a value from one JSON to append in another using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1599910102,
        "creation_date": 1599820520,
        "last_edit_date": 1599910102,
        "question_id": 63845393,
        "body_markdown": "&gt; Can some one please help me I have a nodekey file from which I want to take the address and \r\n  append it in a genesis.json file.\r\n \r\n\r\n&gt; This is the &quot;nodekey file&quot; . I want to fetch the address&#39;s value \r\n  {4cb6046ae395bb6b5f9febc7bdcae28489268725} from this file and append it in the \r\n  genesis.json file in nested key.\r\n\r\n\r\n    {&quot;address&quot;:&quot;4cb6046ae395bb6b5f9febc7bdcae28489268725&quot;,&quot;crypto&quot;:{&quot;cipher&quot;:&quot;aes-128-ctr&quot;,&quot;ciphertext&quot;:&quot;04c9b4c56b717d2f64714de8aa9112c182eccc4e8e578b4c6d89b1621a3cd7c7&quot;,&quot;cipherparams&quot;:{&quot;iv&quot;:&quot;fca58569c4c864f9d9ac5953ee29f713&quot;},&quot;kdf&quot;:&quot;scrypt&quot;,&quot;kdfparams&quot;:{&quot;dklen&quot;:32,&quot;n&quot;:262144,&quot;p&quot;:1,&quot;r&quot;:8,&quot;salt&quot;:&quot;c2331c103e8a3321796fbaa79bcff301e22fa9b8cc4fb811ca0cbf96b48e697b&quot;},&quot;mac&quot;:&quot;0656363e9828aa0f29215261c442169f33816156ce7d7ea795849c971a39fb7a&quot;},&quot;id&quot;:&quot;3da32d09-f0b0-44a0-98ab-e9d03df7c952&quot;,&quot;version&quot;:3}\r\n\r\n\r\n&gt;The below is the genesis file. In this file I want to append the address inside the alloc section at the end like this..\r\n\r\n\r\n   \r\n\r\n    {\r\n        &quot;alloc&quot;: {\r\n           &quot;0xed9d02e382b34818e88b88a309c7fe71e65f419d&quot;: {\r\n              &quot;balance&quot;: &quot;1000000000000000000000000000&quot;\r\n           },\r\n           &quot;0xca843569e3427144cead5e4d5999a3d0ccf92b8e&quot;: {\r\n              &quot;balance&quot;: &quot;1000000000000000000000000000&quot;\r\n           },\r\n           &quot;0x0fbdc686b912d7722dc86510934589e0aaf3b55a&quot;: {\r\n              &quot;balance&quot;: &quot;1000000000000000000000000000&quot;\r\n           },\r\n           &quot;0x9186eb3d20cbd1f5f992a950d808c4495153abd5&quot;: {\r\n              &quot;balance&quot;: &quot;1000000000000000000000000000&quot;\r\n           },\r\n           &quot;0x0638e1574728b6d862dd5d3a3e0942c3be47d996&quot;: {\r\n           &quot;balance&quot;: &quot;1000000000000000000000000000&quot;\r\n           }\r\n           --want to add my address here\r\n        },\r\n        &quot;coinbase&quot;: &quot;0x0000000000000000000000000000000000000000&quot;,\r\n            &quot;config&quot;: {\r\n            &quot;homesteadBlock&quot;: 0,\r\n            &quot;byzantiumBlock&quot;: 0,\r\n            &quot;constantinopleBlock&quot;: 0,\r\n            &quot;chainId&quot;: 10,\r\n            &quot;eip150Block&quot;: 0,\r\n            &quot;eip155Block&quot;: 0,\r\n            &quot;eip150Hash&quot;: &quot;0x0000000000000000000000000000000000000000000000000000000000000000&quot;,\r\n            &quot;eip158Block&quot;: 0,\r\n            &quot;maxCodeSize&quot;: 35,\r\n            &quot;isQuorum&quot;: true\r\n        },\r\n       &quot;difficulty&quot;: &quot;0x0&quot;,\r\n       &quot;extraData&quot;: &quot;0x0000000000000000000000000000000000000000000000000000000000000000&quot;,\r\n       &quot;gasLimit&quot;: &quot;0xE0000000&quot;,\r\n       &quot;mixhash&quot;: &quot;0x00000000000000000000000000000000000000647572616c65787365646c6578&quot;,\r\n       &quot;nonce&quot;: &quot;0x0&quot;,\r\n       &quot;parentHash&quot;: &quot;0x0000000000000000000000000000000000000000000000000000000000000000&quot;,\r\n       &quot;timestamp&quot;: &quot;0x00&quot;\r\n \r\n\r\n    }\r\n\r\n&gt; I tried using jq .alloc +=  --   . But this replaces the last existing address in the alloc \r\n  section.\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63845393/use-a-value-from-one-json-to-append-in-another-using-jq",
        "title": "Use a value from one JSON to append in another using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "curl",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1599848267,
                "post_id": 63850964,
                "comment_id": 112912390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599849206,
                "post_id": 63850964,
                "comment_id": 112912736,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19493975,
                    "reputation": 21,
                    "user_id": 14261635,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiBwUvppdXeDWF_ZfGGV93QBZ2PCVnhdzQATgkSkA=k-s256",
                    "display_name": "Samuel Bartels",
                    "link": "https://stackoverflow.com/users/14261635/samuel-bartels"
                },
                "reply_to_user": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599850756,
                "post_id": 63850964,
                "comment_id": 112913389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1599850912,
                "last_edit_date": 1599850912,
                "creation_date": 1599850796,
                "answer_id": 63852847,
                "question_id": 63850964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to use  MarcoLucidi&#39;s suggestion in the comments to solve the problem\r\n\r\n```\r\njq &#39;.accounts[].tokens[] | select(. == &quot;tokens2&quot;)\r\n```",
                "title": "How to filter values from an array that was cURL&#39;ed - JSON with .JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1599868994,
                "creation_date": 1599868994,
                "answer_id": 63855633,
                "question_id": 63850964,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; how to filter out whatever token so that I can at a glance see so has what?\r\n&gt;\r\n&gt; Could anyone else let me know how I could take the data I have and search it to see if it has token2?\r\n\r\nI&#39;m not exactly sure I understand the question, but given the interpretation &quot;How do I filter the accounts that has `&quot;tokens2&quot;` listed as a token?&quot; since that would be a meaningful and not completely trivial thing you could do with the data.\r\n\r\nGiven [this jqplay snippet](https://jqplay.org/s/ToV__sOmnZ), the jq query:\r\n\r\n```\r\n.accounts | map(select(.tokens | index(&quot;tokens2&quot;)) | .accountId)\r\n```\r\n\r\nfinds `[&quot;account001&quot;, &quot;account003&quot;]` from the following data:\r\n\r\n```\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;accountId&quot;: &quot;account001&quot;,\r\n      &quot;tokens&quot;: [\r\n        &quot;tokens1&quot;,\r\n        &quot;tokens2&quot;,\r\n        &quot;tokens3&quot;,\r\n        &quot;tokens4&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;accountId&quot;: &quot;account002&quot;,\r\n      &quot;tokens&quot;: [\r\n        &quot;tokens3&quot;,\r\n        &quot;tokens4&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;accountId&quot;: &quot;account003&quot;,\r\n      &quot;tokens&quot;: [\r\n        &quot;tokens1&quot;,\r\n        &quot;tokens2&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAn explanation follows:\r\n - `.accounts` reduces the document to the list of accounts.\r\n - `... | map(select(...))` filters out the accounts for which `...` produces `null`.\r\n - `.tokens | ...` reduces each account object to its list of tokens (`.` inside `map(...)` is each element of the accounts array being mapped over, so `.tokens` is the sub-list of that account object).\r\n - `... | index(&quot;tokens2&quot;)` produces either a non-zero index, or `null` if the value isn&#39;t found in the list.\r\n - Subsequently, inside the `map(...)` but outside the `select(...)`, a `... | .accountId` is applied, so each object that passes the `select(...)` filter is reduced to only its account id.\r\n\r\nYou can also experiment with how each of these work by removing certain parts:\r\n\r\n```\r\n.accounts | map(select(.tokens | index(&quot;tokens2&quot;)) | .accountId)\r\n.accounts | map(select(.tokens | index(&quot;tokens2&quot;)))\r\n[ .accounts[] | select(.tokens | index(&quot;tokens2&quot;)) | .accountId ]\r\n```\r\n\r\n",
                "title": "How to filter values from an array that was cURL&#39;ed - JSON with .JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1599868994,
        "creation_date": 1599841828,
        "question_id": 63850964,
        "body_markdown": "```\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;accountId&quot;: &quot;account001&quot;,\r\n      &quot;tokens&quot;: [\r\n        &quot;tokens1&quot;,\r\n        &quot;tokens2&quot;,\r\n        &quot;tokens3&quot;,\r\n        &quot;tokens4&quot;,\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nso the above is an example of what I am working with, my question is how to filter out whatever token so that I can at a glance see so has what?\r\n\r\nI have seen a ton of other answers like this \r\n\r\n```\r\n{\r\n    &quot;ok&quot;: true,\r\n    &quot;items&quot;: [\r\n        {&quot;id&quot;: 123, &quot;name&quot;: &quot;thing-1&quot;},\r\n        {&quot;id&quot;: 124, &quot;name&quot;: &quot;thing-2&quot;},\r\n        {&quot;id&quot;: 125, &quot;name&quot;: &quot;thing-3&quot;}\r\n    ]\r\n}\r\n```\r\n```\r\n\r\ncat file.json | jq &#39;.items[] | select(.name == &quot;thing-3&quot;) | .&#39;\r\n```\r\nHowever, as you can see the tokens don&#39;t have a .name like their example has. \r\n\r\nCould anyone else let me know how I could take the data I have and search it to see if it has token2?\r\n\r\nThanks in advance for any assistance that can be provided.",
        "link": "https://stackoverflow.com/questions/63850964/how-to-filter-values-from-an-array-that-was-curled-json-with-jq",
        "title": "How to filter values from an array that was cURL&#39;ed - JSON with .JQ"
    },
    {
        "tags": [
            "json",
            "regex",
            "bash",
            "jq",
            "inplace-editing"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599950230,
                "post_id": 63865464,
                "comment_id": 112935457,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1599950357,
                "post_id": 63865464,
                "comment_id": 112935481,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599972418,
                "post_id": 63865464,
                "comment_id": 112938382,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1599982668,
                "post_id": 63865464,
                "comment_id": 112940010,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1599996736,
                "last_edit_date": 1599996736,
                "creation_date": 1599952772,
                "answer_id": 63865754,
                "question_id": 63865464,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, let&#39;s define a helper function to perform the incrementation:\r\n\r\n```\r\n# return a string\r\ndef inc:\r\n  (capture(&quot;(?&lt;pre&gt;.*)-(?&lt;post&gt;[0-9]+$)&quot;) | &quot;\\(.pre)-\\( (.post|tonumber) + 1 )&quot;)\r\n  // &quot;\\(tonumber+1)&quot; ;\r\n```\r\nThe remainder of the solution can now be written in two lines, one for each value to be incremented:\r\n```\r\n.tag |= inc\r\n| .apps |= map(if .name == &quot;abc-app&quot; then .version |= inc else . end)\r\n```\r\n\r\n## In-place editing\r\nYou could use `sponge`, or a temporary file, or ... (see e.g. \r\n`&quot;How can &quot;in-place&quot; editing of a JSON file be accomplished?&quot;`\r\non jq&#39;s [FAQ][1]).\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "increment a numerical value in a json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1599996736,
        "creation_date": 1599949585,
        "last_edit_date": 1599954636,
        "question_id": 63865464,
        "body_markdown": "I have a json which looks like this:-\r\n```\r\n{\r\n    &quot;name&quot;: &quot;abc&quot;,\r\n    &quot;version&quot;: &quot;20.02.01&quot;,\r\n    &quot;tag&quot;: &quot;24&quot;,\r\n    &quot;abc_version&quot;: &quot;20.02&quot;,\r\n    &quot;registry&quot;: &quot;registry.abc.com&quot;,\r\n    &quot;vendor&quot;: &quot;greenplanet&quot;,\r\n    &quot;apps&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;abc-app&quot;,\r\n        &quot;version&quot;: &quot;20.02.01-16&quot;,\r\n        &quot;volumes&quot;: [\r\n          &quot;/dev/log:/dev/log&quot;\r\n        ],\r\n        &quot;max_instances&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;xyz-app&quot;,\r\n        &quot;version&quot;: &quot;2.0.0-2&quot;,\r\n        &quot;volumes&quot;: [\r\n          &quot;/dev/log:/dev/log&quot;\r\n        ],\r\n        &quot;max_instances&quot;: &quot;1&quot;\r\n      }      \r\n    ]\r\n}\r\n```\r\nbased on a condition I need to increment the abc-app&#39;s or xyz-app&#39;s version. At present its at &quot;20.02.01-16&quot; for abc-app and I need to change it to &quot;20.02.01-17&quot;. Also I need to increment the tag of the parent app which is &quot;abc&quot;  to &quot;25&quot;\r\nI am able to increment the version with sed but that is not working for me:-\r\n```\r\n./jq -r &quot;.apps&quot; version.json | ./jq -r &quot;.[] | .version&quot; | grep -v &#39;1.0.2&#39; |sed -r &#39;s/([0-9]+.[0-9]+.[0-9]+)(.*)([0-9]+)/echo &quot;\\1\\2$((\\3+1))&quot;/e&#39;\r\n```\r\nI need to increment all the above conditions in-place in json or maybe into a temporary file which I can move to original.\r\n\r\nThank you in advance.",
        "link": "https://stackoverflow.com/questions/63865464/increment-a-numerical-value-in-a-json-with-jq",
        "title": "increment a numerical value in a json with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600008982,
                "creation_date": 1600008982,
                "answer_id": 63872166,
                "question_id": 63871422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map_values` is up to the task, or at least the following jq expression does the job:\r\n\r\n    map_values( .ExprMap.data | map_values(.ExprString.data) )",
                "title": "how can I eliminate redundant fields containing data from json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600012980,
                "creation_date": 1600012980,
                "answer_id": 63872775,
                "question_id": 63871422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that uses a more generic approach:\r\n```\r\nwalk(if type == &quot;object&quot;\r\n     then if has(&quot;ExprMap&quot;) then del(.ExprMap) + (.ExprMap.data | map_values(.ExprString.data)) else . end\r\n     else . end)\r\n```     ",
                "title": "how can I eliminate redundant fields containing data from json with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1600049878,
                "creation_date": 1600049878,
                "answer_id": 63877292,
                "question_id": 63871422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s what I believe to be a solution to the extended problem presented in the comments.  That is, it handles ExprTuple, ExprList, ExprMap, and ExprString, and can easily be extended to cover other &quot;Expr&quot; types.\r\n```\r\ndef detype:\r\n  if type == &quot;object&quot;\r\n  then if has(&quot;ExprTuple&quot;) then .ExprTuple.data | map(detype)\r\n       elif has(&quot;ExprList&quot;) then .ExprList.data | map(detype)\r\n       elif has(&quot;ExprMap&quot;) then .ExprMap.data | detype\r\n       elif has(&quot;ExprString&quot;) then .ExprString.data\r\n       else . end\r\n  else . end;\r\n\r\nwalk(detype)\r\n```\r\n",
                "title": "how can I eliminate redundant fields containing data from json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1600049878,
        "creation_date": 1600004121,
        "last_edit_date": 1600009131,
        "question_id": 63871422,
        "body_markdown": "I have json that has info enclosed in type and data structures that need to be removed. I have a stucture like:\r\n```\r\n{\r\n  &quot;Board: WEC&quot;: {\r\n    &quot;ExprMap&quot;: {\r\n      &quot;data&quot;: {\r\n        &quot;noAddr&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;11112aoa6NLYomYZro566XZVGEXyCDqeqDcp8Pzg81Ckuws6SexC99&quot;\r\n          }\r\n        },\r\n        &quot;shortDesc&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;Wile E. Coyote for Board Member&quot;\r\n          }\r\n        },\r\n        &quot;yesAddr&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;11112gUFvJR6JBDYJURETaWUBpEDa1EyjgRHFncEfQ4hGECnciPnhw&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;Board: DaD&quot;: {\r\n    &quot;ExprMap&quot;: {\r\n      &quot;data&quot;: {\r\n        &quot;noAddr&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;11112Cwtg2Bs4WUAYrXhL9xZXXSXr9Gn62Cty39RhUaBnqjrKkqwAZ&quot;\r\n          }\r\n        },\r\n        &quot;shortDesc&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;Daffy Duck for Board Member&quot;\r\n          }\r\n        },\r\n        &quot;yesAddr&quot;: {\r\n          &quot;ExprString&quot;: {\r\n            &quot;data&quot;: &quot;1111TnFUN7eZBWXp3QQACQRRxpcS5uH5Bpf67vikWhA5e3F6ikAmU&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nI am trying to eliminate the extraneous nesting of\r\n- &quot;ExprMap&quot;: { &quot;data&quot;: KEEP-THIS } }\r\n- &quot;ExprString&quot;: { &quot;data&quot;: KEEP-THIS } }\r\nto get\r\n\r\n```\r\n    {\r\n      &quot;Board: WEC&quot;: {\r\n        &quot;noAddr&quot;: &quot;11112aoa6NLYomYZro566XZVGEXyCDqeqDcp8Pzg81Ckuws6SexC99&quot;,\r\n        &quot;shortDesc&quot;: &quot;Wile E. Coyote for Board Member&quot;,\r\n        &quot;yesAddr&quot;: &quot;11112gUFvJR6JBDYJURETaWUBpEDa1EyjgRHFncEfQ4hGECnciPnhw&quot;\r\n      },\r\n      &quot;Board: DaD&quot;: {\r\n        &quot;noAddr&quot;: &quot;11112Cwtg2Bs4WUAYrXhL9xZXXSXr9Gn62Cty39RhUaBnqjrKkqwAZ&quot;,\r\n        &quot;shortDesc&quot;: &quot;Daffy Duck for Board Member&quot;,\r\n        &quot;yesAddr&quot;: &quot;1111TnFUN7eZBWXp3QQACQRRxpcS5uH5Bpf67vikWhA5e3F6ikAmU&quot;\r\n      }\r\n```\r\nhelp would be appreciated. thanks. ",
        "link": "https://stackoverflow.com/questions/63871422/how-can-i-eliminate-redundant-fields-containing-data-from-json-with-jq",
        "title": "how can I eliminate redundant fields containing data from json with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "split",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1600028437,
                "creation_date": 1600028437,
                "answer_id": 63875191,
                "question_id": 63874826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use your filters to fill in the values of a new object and use the keys to refer to the arrays.\r\n\r\n    jq -r &#39;{\r\n             &quot;all-tenants&quot;: [.[].Header.Tenant],\r\n             &quot;filter1&quot;: [.[]|select (all(.Body.values[]; .name !=&quot;LoadTest&quot;))]|[.[].Header.Tenant]\r\n           } | .[&quot;all-tenants&quot;] - .filter1 | .[]&#39;\r\n\r\nNote: .[&quot;all-tenants&quot;] is required by the special character &quot;-&quot; in that key. See the entry under [Object Identifier-Index](https://stedolan.github.io/jq/manual/v1.6/#Basicfilters) in the manual.",
                "title": "jq - subtracting one array from another using a single command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600050471,
                "creation_date": 1600050471,
                "answer_id": 63877351,
                "question_id": 63874826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; how can I assign and use these two arrays into vars directly in a single command not involving the intermediate files?\r\n\r\nSimply store the intermediate arrays as jq &quot;$-variables&quot;:\r\n```\r\n[.[].Header.Tenant] as $x\r\n| ([.[] | select (all(.Body.values[]; .name !=&quot;LoadTest&quot;)  )  ] | [.[].Header.Tenant]) as $y\r\n| $x - $y\r\n```\r\nIf you want to itemize the contents of $x - $y, then simply add a final `.[]` to the pipeline.\r\n",
                "title": "jq - subtracting one array from another using a single command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1600050471,
        "creation_date": 1600025813,
        "last_edit_date": 1600027283,
        "question_id": 63874826,
        "body_markdown": "I have three operations with jq to get the right result. How can I do it within one command? \r\nHere is a fragment from the source JSON file\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;tenant-1&quot;,\r\n            &quot;Rcode&quot;: 200\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;0b0b-0c0c&quot;,\r\n                    &quot;name&quot;: &quot;NumberOfSearchResults&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a&quot;,\r\n                    &quot;name&quot;: &quot;LoadTest&quot;\r\n                }\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;tenant-2&quot;,\r\n            &quot;Rcode&quot;: 200\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: []\r\n        }\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;tenant-3&quot;,\r\n            &quot;Rcode&quot;: 200\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;cccca0003-0b0b&quot;,\r\n                    &quot;name&quot;: &quot;LoadTest&quot;\r\n                }\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;tenant-4&quot;,\r\n            &quot;Rcode&quot;: 200\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;0f0g-0e0a&quot;,\r\n                    &quot;name&quot;: &quot;NumberOfSearchResults&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nI apply two filters and create two intermediate JSON files. First I create the list of all tenants\r\n```\r\njq -r &#39;[.[].Header.Tenant]&#39; source.json &gt;all-tenants.json\r\n```\r\nAnd then I select to create an array of all tenants not having a particular key present in the ``Body.values[]`` array:\r\n```\r\njq -r &#39;[.[] | select (all(.Body.values[]; .name !=&quot;LoadTest&quot;)  )  ] | [.[].Header.Tenant]&#39; source.json &gt;filter1.json\r\n```\r\nResults - all-tenants.json\r\n```\r\n[&quot;tenant-1&quot;,\r\n&quot;tenant-2&quot;,\r\n&quot;tenant-3&quot;,\r\n&quot;tenant-4&quot;\r\n]\r\n```\r\nfilter1.json\r\n```\r\n[&quot;tenant-2&quot;,\r\n&quot;tenant-4&quot;\r\n]\r\n```\r\nAnd then I substruct filter1.json from all-tenants.json to get the difference:\r\n```\r\njq  -r -n --argfile filter filter1.json --argfile alltenants all-tenants.json &#39;$alltenants - $filter|.[]&#39;\r\n```\r\nResult:\r\n```\r\ntenant-1\r\ntenant-3\r\n```\r\n\r\n\r\nTenant names - values for the &quot;Tenant&quot; key are unique and each of them occurs only once in the source.json file.\r\n\r\nJust to clarify - I understand that I can have a select condition(s) that would give me the same resut as subtracting two arrays. \r\n\r\nWhat I want to understand - how can I assign and use these two arrays into vars directly in a single command not involving the intermediate files?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63874826/jq-subtracting-one-array-from-another-using-a-single-command",
        "title": "jq - subtracting one array from another using a single command"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600042609,
                "creation_date": 1600042609,
                "answer_id": 63876719,
                "question_id": 63876705,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Run `jq` _only once_ with a filter that emits your addresses one-per-line, using a `while read` loop to iterate over lines of output that one copy of jq emits. Per [BashFAQ #1](https://mywiki.wooledge.org/BashFAQ/001):\r\n\r\n```\r\n#!/bin/bash\r\n\r\nNEW_PEERS_JSON=&quot;${CNODE_HOME}/files/peers/20201309.json&quot;\r\n\r\nwhile IFS= read -r addr; do\r\n  echo &quot;Handling address: $addr&quot;\r\ndone &lt; &lt;(jq -r &#39;.Producers[].addr&#39; &lt;&quot;$NEW_PEERS_JSON&quot;)\r\n```\r\n\r\nThis is much, much more efficient than running a separate copy of `jq` per item you want to extract.",
                "title": "Bash Loop thru Array Nested in JSON of unknown length with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600042609,
        "creation_date": 1600042467,
        "question_id": 63876705,
        "body_markdown": "The following code works, but what is the industry-standard way of doing this?  I&#39;m more comfortable with languages that return FALSE when they fail.  The idea of comparing a string with &quot;null&quot; doesn&#39;t sit right with me.  Is jq actually returning the string &quot;null&quot; or is bash translating the false/empty return to that string?\r\n\r\nNote, the array is nested in the JSON file and has an unknown number of elements.\r\n\r\n    #!/bin/bash\r\n\r\n    NEW_PEERS_JSON=&quot;${CNODE_HOME}/files/peers/20201309.json&quot;\r\n\r\n    index=0\r\n    while [ 1 ]\r\n    do\r\n            addr=$(jq -r .Producers[$index].addr &lt; $NEW_PEERS_JSON)\r\n            if [ &quot;$addr&quot; == &quot;null&quot; ]\r\n\r\n            then\r\n                    break\r\n            fi\r\n            echo $addr\r\n            index=$index+1\r\n    done\r\n\r\nthe JSON file looks like this:\r\n\r\n    { &quot;resultcode&quot;: &quot;201&quot;, &quot;networkMagic&quot;: &quot;764824073&quot;, &quot;ipType&quot;:4, &quot;Producers&quot;: [\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3030, &quot;valency&quot;: 1, &quot;distance&quot;:14 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3001, &quot;valency&quot;: 1, &quot;distance&quot;:955 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3001, &quot;valency&quot;: 1, &quot;distance&quot;:1307 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3001, &quot;valency&quot;: 1, &quot;distance&quot;:1976 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 4251, &quot;valency&quot;: 1, &quot;distance&quot;:3025 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3001, &quot;valency&quot;: 1, &quot;distance&quot;:3497 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3001, &quot;valency&quot;: 1, &quot;distance&quot;:3539 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 3301, &quot;valency&quot;: 1, &quot;distance&quot;:3685 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 4002, &quot;valency&quot;: 1, &quot;distance&quot;:7303 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 4601, &quot;valency&quot;: 1, &quot;distance&quot;:7737 },\r\n      { &quot;addr&quot;: &quot;xx.xxx.xxx.xx&quot;, &quot;port&quot;: 4001, &quot;valency&quot;: 1, &quot;distance&quot;:7866 }\r\n    ] }\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/63876705/bash-loop-thru-array-nested-in-json-of-unknown-length-with-jq",
        "title": "Bash Loop thru Array Nested in JSON of unknown length with jq"
    },
    {
        "tags": [
            "bash",
            "while-loop",
            "jq",
            "ifs"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 141612,
                    "reputation": 162638,
                    "user_id": 348785,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/7f3dcb0c380783d1be77bfdd5fc5fda6?s=256&d=identicon&r=PG",
                    "display_name": "kev",
                    "link": "https://stackoverflow.com/users/348785/kev"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600054333,
                "post_id": 63877660,
                "comment_id": 112956505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10286519,
                    "reputation": 5985,
                    "user_id": 7589636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa78a73e889b0b4e61a931d9237012c5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "thanasisp",
                    "link": "https://stackoverflow.com/users/7589636/thanasisp"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600182294,
                "post_id": 63877660,
                "comment_id": 113003862,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1600055618,
                "creation_date": 1600055618,
                "answer_id": 63877870,
                "question_id": 63877660,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` command from @Kev in comment will extract the values you want, each pair per line, like this:\r\n\r\n    &gt; jq -r &#39;.list[]|[.key,.fields.field_1]|@tsv&#39; test.json\r\n    test-11\t1234\r\n    test-10\t1235\r\n\r\nHere is how you can modify your script to make your `curl` requests per value pair.\r\n\r\n    #!/bin/bash\r\n    while read -r key field_1; do\r\n        echo curl -s https://thisistest.com/api/$key/$field_1\r\n    done &lt; &lt;( jq -r &#39;.list[]|[.key,.fields.field_1]|@tsv&#39; test.json )\r\n\r\nRemove `echo` if you are ok with your testing.\r\n",
                "title": "jq: parse and display multiple values in JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600182079,
        "creation_date": 1600053666,
        "last_edit_date": 1600182079,
        "question_id": 63877660,
        "body_markdown": "I have this `test.json` file\r\n\r\n    {\r\n      &quot;list&quot;: [\r\n        {\r\n          &quot;expand&quot;: &quot;xx&quot;,\r\n          &quot;id&quot;: &quot;xxxxx&quot;,\r\n          &quot;self&quot;: &quot;https&quot;,\r\n          &quot;key&quot;: &quot;test-11&quot;,\r\n          &quot;fields&quot;: {\r\n            &quot;field_1&quot;: &quot;1234&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;expand&quot;: &quot;xx&quot;,\r\n          &quot;id&quot;: &quot;xxxxx&quot;,\r\n          &quot;self&quot;: &quot;https&quot;,\r\n          &quot;key&quot;: &quot;test-10&quot;,\r\n          &quot;fields&quot;: {\r\n            &quot;field_1&quot;: &quot;1235&quot;,\r\n            &quot;field_2&quot;: null\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI am trying to read the values using IFS while loops:\r\n\r\n    cat test.json| jq -r &#39;[.list[]| ([.key]|tostring) + &quot;,&quot; + &quot;\\(.fields| .field_1)&quot;]|@tsv&#39; \\\r\n    | while IFS=&quot;,&quot; read -r key field_1; do\r\n    echo &quot;$key $field_1&quot;\r\n    curl -s https ://thisistest.com/api/$key/$field_1\r\n    done;\r\n    echo output displays only: test-11\r\n\r\nI would like to get the values of  `key` and `field_1` to use them in the `curl` request.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63877660/jq-parse-and-display-multiple-values-in-json",
        "title": "jq: parse and display multiple values in JSON"
    },
    {
        "tags": [
            "json",
            "match",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5577407,
                    "reputation": 800,
                    "user_id": 4420422,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lAXQ1.jpg?s=256",
                    "display_name": "khari-sing",
                    "link": "https://stackoverflow.com/users/4420422/khari-sing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600067183,
                "post_id": 63879453,
                "comment_id": 112959516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5577407,
                    "reputation": 800,
                    "user_id": 4420422,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lAXQ1.jpg?s=256",
                    "display_name": "khari-sing",
                    "link": "https://stackoverflow.com/users/4420422/khari-sing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600067336,
                "post_id": 63879453,
                "comment_id": 112959574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10628464,
                    "reputation": 479,
                    "user_id": 7827425,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/6f1a94b70184e0305d6dd1f6055a33b0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "mf94",
                    "link": "https://stackoverflow.com/users/7827425/mf94"
                },
                "reply_to_user": {
                    "account_id": 5577407,
                    "reputation": 800,
                    "user_id": 4420422,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lAXQ1.jpg?s=256",
                    "display_name": "khari-sing",
                    "link": "https://stackoverflow.com/users/4420422/khari-sing"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600067702,
                "post_id": 63879453,
                "comment_id": 112959694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600086807,
                "creation_date": 1600086807,
                "answer_id": 63884433,
                "question_id": 63879453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After correcting the input files, the following can be used to achieve the desired result:\r\n\r\n    jq --argfile a a.json -f program.jq b.json\r\n\r\nwhere program.jq holds:\r\n```\r\n(INDEX($a[]; .i) | map_values(.f)) as $dict\r\n| map( .f = $dict[.i] )\r\n```",
                "title": "JSON: Modify specific value based on matched key:value of another JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600088927,
        "creation_date": 1600066708,
        "last_edit_date": 1600088927,
        "question_id": 63879453,
        "body_markdown": "I have 2 JSON files and I want to update one of them based on the other. **More specifically, if a specific key:value pair matches between the file, I want to update another (and only 1 other) key:value pair.**\r\n\r\na.json looks as follows:\r\n\r\n    [\r\n    {&quot;i&quot;:&quot;1234&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1235&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1236&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1237&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1238&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;0&quot;}\r\n    ]\r\n\r\nb.json looks as follows:\r\n\r\n    [\r\n    {&quot;i&quot;:&quot;1234&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1235&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1236&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1237&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1238&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;1&quot;}\r\n    ]\r\n\r\nI want to update b.json so that if the &quot;i&quot; value of b.json matches the &quot;i&quot; value of a.json, the value for &quot;f&quot; is replaced by a.json&#39;s value. I.e. I want b.json to look like this:\r\n\r\n    [\r\n    {&quot;i&quot;:&quot;1234&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1235&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1236&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1237&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;1&quot;},\r\n    {&quot;i&quot;:&quot;1238&quot;,&quot;f&quot;:&quot;123&quot;,&quot;a&quot;:&quot;1&quot;}\r\n    ]\r\n\r\nSo to be clear, **only the f values must be replaced, not the ones for a**.\r\n\r\nI have found this partial solution:\r\n\r\n**1)** Make a file called update.jq such that:\r\n\r\n    reduce keys[] as $k (.; if $a|has($k) then .[$k] = $a[$k] else . end)\r\n\r\n**2)** Run:\r\n\r\n    jq --argfile a a.json -f a.jq b.json \r\n\r\nThis gives me this where both f and a have been updated **but I only want f to be updated.** How can I ensure that only f gets updated?\r\n\r\n    [\r\n    {&quot;i&quot;:&quot;1234&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1235&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1236&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1237&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;0&quot;},\r\n    {&quot;i&quot;:&quot;1238&quot;,&quot;f&quot;:&quot;555&quot;,&quot;a&quot;:&quot;0&quot;}\r\n    ]",
        "link": "https://stackoverflow.com/questions/63879453/json-modify-specific-value-based-on-matched-keyvalue-of-another-json",
        "title": "JSON: Modify specific value based on matched key:value of another JSON"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1600092429,
                "creation_date": 1600092429,
                "answer_id": 63885988,
                "question_id": 63885229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try something like this: `jq &#39;.result[] | .id , .name&#39; data.json`.\r\n\r\nThe main problem with the other command you tried is that `result` is an array, so you need to specify to iterate over it before you&#39;re able to extract `id` and `name` from the elements inside the array.\r\n\r\n*Also the json you posted misses a closing curly bracket `}`*",
                "title": "jq extracting two fields from a json array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1600092429,
        "creation_date": 1600089799,
        "question_id": 63885229,
        "body_markdown": "I&#39;m trying to extract two fields (id and name) from the following output using jq. I&#39;m continually getting a compile error. I&#39;ve tried jq .result.id|.name among other variations.\r\n\r\nThis is the output, I&#39;m working with.\r\n\r\nAny feedback would be appreciated.\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;6e55aff5ff4a74a234112c1d341b2e31&quot;,\r\n      &quot;zone_id&quot;: &quot;d018a8f437462900bbe514c916a492a5&quot;,\r\n      &quot;zone_name&quot;: &quot;example.com&quot;,\r\n      &quot;name&quot;: &quot;example.com&quot;,\r\n      &quot;type&quot;: &quot;A&quot;,\r\n      &quot;content&quot;: &quot;98.158.193.66&quot;,\r\n      &quot;proxiable&quot;: true,\r\n      &quot;proxied&quot;: true,\r\n      &quot;ttl&quot;: 1,\r\n      &quot;locked&quot;: false,\r\n      &quot;meta&quot;: {\r\n        &quot;auto_added&quot;: false,\r\n        &quot;managed_by_apps&quot;: false,\r\n        &quot;managed_by_argo_tunnel&quot;: false,\r\n        &quot;source&quot;: &quot;primary&quot;\r\n      },\r\n      &quot;created_on&quot;: &quot;2020-09-14T12:48:23.952656Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2020-09-14T12:48:23.952656Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;3e1243be83fdaca735b419c224e670e7&quot;,\r\n      &quot;zone_id&quot;: &quot;d018a8f437462900bbe514c916a492a5&quot;,\r\n      &quot;zone_name&quot;: &quot;example.com&quot;,\r\n      &quot;name&quot;: &quot;localhost.example.com&quot;,\r\n      &quot;type&quot;: &quot;A&quot;,\r\n      &quot;content&quot;: &quot;127.0.0.1&quot;,\r\n      &quot;proxiable&quot;: false,\r\n      &quot;proxied&quot;: false,\r\n      &quot;ttl&quot;: 14400,\r\n      &quot;locked&quot;: false,\r\n      &quot;meta&quot;: {\r\n        &quot;auto_added&quot;: false,\r\n        &quot;managed_by_apps&quot;: false,\r\n        &quot;managed_by_argo_tunnel&quot;: false,\r\n        &quot;source&quot;: &quot;primary&quot;\r\n      },\r\n      &quot;created_on&quot;: &quot;2020-09-14T12:17:53.68773Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2020-09-14T12:17:53.68773Z&quot;\r\n    }\r\n]\r\n",
        "link": "https://stackoverflow.com/questions/63885229/jq-extracting-two-fields-from-a-json-array",
        "title": "jq extracting two fields from a json array"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "dynamically-generated"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1600111320,
                "last_edit_date": 1600111320,
                "creation_date": 1600109771,
                "answer_id": 63890326,
                "question_id": 63889946,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A functional solution:\r\n\r\n    [to_entries[] | {(.key+1|tostring): .value}] | add\r\n\r\nOr, more succinctly:\r\n\r\n    with_entries(.key |= (1+.|tostring))\r\n\r\nOr, more prosaically:\r\n\r\n    . as $in\r\n    | reduce range(0;length) as $i (null; \r\n        . + {($i+1|tostring): $in[$i]})\r\n",
                "title": "JQ to map array to object with index - how to"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1600111320,
        "creation_date": 1600108117,
        "last_edit_date": 1600110809,
        "question_id": 63889946,
        "body_markdown": "pretty simple:\r\n\r\nWhat I have: `&#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39;`\r\n\r\nWhat I want: \r\n```json\r\n{\r\n  &quot;1&quot;:&quot;a&quot;,\r\n  &quot;2&quot;:&quot;b&quot;,\r\n  &quot;3&quot;:&quot;c&quot;\r\n}\r\n```\r\nWhat I am working with. \r\n\r\n```bash\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;. | map({(index(.)) : (.)})&#39;\r\n```\r\n\r\nWhat I am getting (it seems to be operating on successively smaller arrays):\r\n\r\n```\r\n echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;. | map(index((.)))&#39;\r\n[\r\n  0,\r\n  0,\r\n  0\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/63889946/jq-to-map-array-to-object-with-index-how-to",
        "title": "JQ to map array to object with index - how to"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600163791,
                "creation_date": 1600163791,
                "answer_id": 63899408,
                "question_id": 63899314,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe this\r\n\r\nhttps://stackoverflow.com/questions/6386308/http-requests-and-json-parsing-in-python\r\n\r\n```\r\nimport json\r\n\r\ndata = json.loads(jsonResponse)\r\n```",
                "title": "similar sentence with python like bash with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600163791,
        "creation_date": 1600163454,
        "question_id": 63899314,
        "body_markdown": "I&#39;m trying to traslate shell script bash to pyhton.\r\nI use jq to extract fileds of json response but with jsonresponse I can&#39;t do it with python.\r\nSomeone knows?\r\nMy bash line\r\n\r\n    jq -r &#39;.search_objects[].price&#39; file\r\n\r\nI&#39;m trying with\r\n\r\n    print(jsonResponse[&quot;search_objects&quot;][&quot;price&quot;])\r\n\r\nBut fails :-(\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63899314/similar-sentence-with-python-like-bash-with-jq",
        "title": "similar sentence with python like bash with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600179295,
                "creation_date": 1600179295,
                "answer_id": 63903817,
                "question_id": 63903553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get all the objects in the `values` array with\r\n\r\n```\r\n.[].Body.values[]\r\n```\r\n\r\nand then select the `id` of the objects where `name` matches your string:\r\n\r\n```\r\n.[].Body.values[] | select(.name == &quot;Attribute1&quot;).id\r\n```",
                "title": "jq - find a value of a non-unique key when another value is known"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600179295,
        "creation_date": 1600178430,
        "question_id": 63903553,
        "body_markdown": "I am struggling to construct a proper filter for jq to find the value of a specific key when the value of another key is known.\r\n\r\nHere is the json file:\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;TenantX&quot;,\r\n            &quot;Rcode&quot;: 200\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-0a95-6625bef115e5&quot;,\r\n                    &quot;name&quot;: &quot;Attribute1&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-9926-f5dc47d312dd&quot;,\r\n                    &quot;name&quot;: &quot;Attribute2&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-aea9-6b39641a0695&quot;,\r\n                    &quot;name&quot;: &quot;Attribute3&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aaaa0001-0a0a-0b0b-a62b-5b26838eeca7&quot;,\r\n                    &quot;name&quot;: &quot;Attribute4&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nMy goal - for any given value of the &quot;name&quot; key, find the value of the &quot;id&quot; key in the same {} block. Or to have as an example as pseudocode/task:\r\n```\r\nWhen Header.Tenant ===&quot;TenantX&quot; and Body.values[].name ==&quot;Attribute1&quot; \r\nthen\r\ndisplay the value of &quot;id&quot;  \r\nin the same block where &quot;Attribute1&quot; is\r\n```\r\nValues of the ``&quot;id&quot;`` and ``&quot;name&quot;`` are unique, but the position of the combination of name/id in the ``Body.values[]`` array can be anywhere. In other words, for one tenant ``Attribute1`` can be in the first element of the array, and for another tenant - in 10th. Also, some tenants can have certain ``name/id`` in the array and others do not. \r\n\r\nI guess if I can find the unique position ``n`` for the given attribute within the array -  ``Body.values[n].name``, then ``Body.values[n].id`` should give me the answer, right?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63903553/jq-find-a-value-of-a-non-unique-key-when-another-value-is-known",
        "title": "jq - find a value of a non-unique key when another value is known"
    },
    {
        "tags": [
            "json",
            "jq",
            "zero-padding"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1600192008,
                "last_edit_date": 1600192008,
                "creation_date": 1600191049,
                "answer_id": 63907086,
                "question_id": 63906770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you are trying to use the `lpad/2` from [this peak’s comment][1], you can do\n\n    def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .;\n    map(.batch_id |= lpad(8; &quot;0&quot;))\n\nThe key here is when using the update assignment operator `|=` the field being modified is passed on internally, so that you don’t have to call it out explicitly in the RHS\n\n  [1]: https://github.com/stedolan/jq/issues/2033#issuecomment-586083471",
                "title": "How to combine update with function result in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600228295,
        "creation_date": 1600189715,
        "last_edit_date": 1600228295,
        "question_id": 63906770,
        "body_markdown": "Given data like this:\r\n```\r\ncat &lt;&lt; EOF &gt; xyz.json\r\n[\r\n  {\r\n    &quot;batch_id&quot;: 526,\r\n    &quot;aCods&quot;: [\r\n      &quot;IBDD879&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;batch_id&quot;: 357,\r\n    &quot;aCods&quot;: [\r\n      &quot;IBDD212&quot;\r\n    ]\r\n  }\r\n]\r\nEOF\r\n```\r\n\r\n\r\n**What is the correct way to get this result?**\r\n\r\n```\r\n[\r\n  {\r\n    &quot;batch_id&quot;: &quot;00000526&quot;,\r\n    &quot;aCods&quot;: [\r\n      &quot;IBDD879&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;batch_id&quot;: &quot;00000357&quot;,\r\n    &quot;aCods&quot;: [\r\n      &quot;IBDD212&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\nI have tried three different commands hoping to be able to update a object element in an array with the result of a function on that element.\r\n\r\nI just cannot find the right syntax.\r\n\r\n```\r\njq -r &#39;.[] | .batch_id |= 9999999&#39; xyz.json;\r\n\r\n{\r\n  &quot;batch_id&quot;: 9999999,\r\n  &quot;aCods&quot;: [\r\n    &quot;IBDD879&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;batch_id&quot;: 9999999,\r\n  &quot;aCods&quot;: [\r\n    &quot;IBDD212&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\n```\r\njq -r &#39;.[] | lpad(&quot;\\(.batch_id)&quot;;8;&quot;0&quot;)&#39; xyz.json;\r\n00000526\r\n00000357\r\n```\r\n\r\n```\r\njq -r &#39;.[] | .batch_id |= lpad(&quot;\\(.batch_id)&quot;;8;&quot;0&quot;)&#39; xyz.json;\r\njq: error (at /dev/shm/xyz.json:14): Cannot index number with string &quot;batch_id&quot;\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/63906770/how-to-combine-update-with-function-result-in-jq",
        "title": "How to combine update with function result in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600201632,
                "post_id": 63907698,
                "comment_id": 113012250,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600210555,
                "last_edit_date": 1600210555,
                "creation_date": 1600209913,
                "answer_id": 63910797,
                "question_id": 63907698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although your JSON is invalid, you can probably achieve what you need using the alternative operator `//`. Here&#39;s a minimal, complete example:\r\n\r\n    $ jq . test.json\r\n    [\r\n      {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: [\r\n          {\r\n            &quot;c&quot;: 3\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;a&quot;: 2,\r\n        &quot;b&quot;: []\r\n      }\r\n    ]\r\n    $ jq &#39;.[] | {aa: .a, bb: .b[].c}&#39; test.json # attempt 1\r\n    {\r\n      &quot;aa&quot;: 1,\r\n      &quot;bb&quot;: 3\r\n    }\r\n    $ jq &#39;.[] | {aa: .a, bb: (.b[].c // &quot;&quot;)}&#39; test.json # attempt 2\r\n    {\r\n      &quot;aa&quot;: 1,\r\n      &quot;bb&quot;: 3\r\n    }\r\n    {\r\n      &quot;aa&quot;: 2,\r\n      &quot;bb&quot;: &quot;&quot;\r\n    }\r\n\r\nYou can see that the second element&#39;s `b` array is empty, causing it to be omitted from the result in the first attempt which resembles your approach. In the second attempt, we used the alternative operator to coalesce to the empty string.\r\n\r\nDeleting the nonexistent entries can be done multiple ways, for example:\r\n\r\n    $ jq &#39;.[] \r\n      | {aa: .a, bb: (.b[].c // null)} \r\n      | if .bb == null then del(.bb) else . end\r\n    &#39; test.json\r\n    {\r\n      &quot;aa&quot;: 1,\r\n      &quot;bb&quot;: 3\r\n    }\r\n    {\r\n      &quot;aa&quot;: 2\r\n    }",
                "title": "How to handle empty string in jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600210555,
        "creation_date": 1600193893,
        "question_id": 63907698,
        "body_markdown": "I have a jq command like so:\r\n\r\n```\r\njq &#39;.SecurityGroups[] | {name: .GroupName, groupid: .GroupId, ips: .IpPermissions[].IpRanges[].CidrIp, sourcegroup: .IpPermissions[].UserIdGroupPairs[].GroupId}&#39;\r\n```\r\n\r\nIt works well except for one thing. It doesn&#39;t seem to handle having that value not exist. It only returns when all values exist.\r\n\r\n**Expected Output**:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;group1&quot;,\r\n  &quot;groupid&quot;: &quot;sg-012345&quot;,\r\n  &quot;ips&quot;: &quot;10.0.0.0/8&quot;,\r\n  &quot;sourcegroup&quot;: &quot;&quot;           # having this value not return at all would suffice\r\n}\r\n{\r\n  &quot;name&quot;: &quot;group2&quot;,\r\n  &quot;groupid&quot;: &quot;sg-06789&quot;,\r\n  &quot;ips&quot;: &quot;&quot;,                  # having this value not return at all would suffice\r\n  &quot;sourcegroup&quot;: &quot;sg-abcd&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;group3&quot;,\r\n  &quot;groupid&quot;: &quot;sg-xyz&quot;,\r\n  &quot;ips&quot;: &quot;192.0.0.0/8&quot;,\r\n  &quot;sourcegroup&quot;: &quot;sg-xyz&quot;\r\n}\r\n\r\n```\r\n\r\n**JSON Input**:\r\n```\r\n{\r\n    &quot;SecurityGroups&quot;: [\r\n        {\r\n            &quot;GroupName&quot;: &quot;group1&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n                {\r\n                    &quot;IpRanges&quot;: [\r\n                        {\r\n                            &quot;CidrIp&quot;: &quot;10.0.0.0/8&quot;\r\n                        }\r\n                    ],\r\n                    &quot;UserIdGroupPairs&quot;: []\r\n                },\r\n            &quot;GroupId&quot;: &quot;sg-012345&quot;,\r\n        },\r\n        {\r\n            &quot;GroupName&quot;: &quot;group2&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n                {\r\n                    &quot;IpRanges&quot;: [],\r\n                    &quot;UserIdGroupPairs&quot;: [\r\n                        {\r\n                            &quot;GroupId&quot;: &quot;sg-abcd&quot;,\r\n                        }\r\n                    ]\r\n                },\r\n            &quot;GroupId&quot;: &quot;sg-06789&quot;,\r\n        },\r\n        {\r\n            &quot;GroupName&quot;: &quot;group3&quot;,\r\n            &quot;IpPermissions&quot;: [\r\n                {\r\n                    &quot;IpRanges&quot;: [\r\n                        {\r\n                            &quot;CidrIp&quot;: &quot;192.0.0.0/8&quot;\r\n                        }\r\n                    ],\r\n                    &quot;UserIdGroupPairs&quot;: [\r\n                        {\r\n                            &quot;GroupId&quot;: &quot;sg-xyz&quot;,\r\n                        }\r\n                    ]\r\n                },\r\n            &quot;GroupId&quot;: &quot;sg-xyz&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\nI found the following but I can&#39;t see to get it to work for my situation so not sure what I&#39;m doing wrong here:\r\n\r\nhttps://stackoverflow.com/questions/63635682/jq-remove-keys-with-empty-string-values",
        "link": "https://stackoverflow.com/questions/63907698/how-to-handle-empty-string-in-jq",
        "title": "How to handle empty string in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2399358,
                    "reputation": 419,
                    "user_id": 2097442,
                    "user_type": "registered",
                    "accept_rate": 27,
                    "profile_image": "https://www.gravatar.com/avatar/ca18f475ee1495a02604517d7cd829cc?s=256&d=identicon&r=PG",
                    "display_name": "Neo Mosaid",
                    "link": "https://stackoverflow.com/users/2097442/neo-mosaid"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1600195979,
                "post_id": 63908137,
                "comment_id": 113010099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2399358,
                    "reputation": 419,
                    "user_id": 2097442,
                    "user_type": "registered",
                    "accept_rate": 27,
                    "profile_image": "https://www.gravatar.com/avatar/ca18f475ee1495a02604517d7cd829cc?s=256&d=identicon&r=PG",
                    "display_name": "Neo Mosaid",
                    "link": "https://stackoverflow.com/users/2097442/neo-mosaid"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600196100,
                "post_id": 63908137,
                "comment_id": 113010149,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600196107,
                "post_id": 63908137,
                "comment_id": 113010153,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2399358,
                    "reputation": 419,
                    "user_id": 2097442,
                    "user_type": "registered",
                    "accept_rate": 27,
                    "profile_image": "https://www.gravatar.com/avatar/ca18f475ee1495a02604517d7cd829cc?s=256&d=identicon&r=PG",
                    "display_name": "Neo Mosaid",
                    "link": "https://stackoverflow.com/users/2097442/neo-mosaid"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600196448,
                "post_id": 63908137,
                "comment_id": 113010287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1293198,
                    "reputation": 19192,
                    "user_id": 1244884,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79435cc2571ffa23dfcef703f8d762e0?s=256&d=identicon&r=PG",
                    "display_name": "customcommander",
                    "link": "https://stackoverflow.com/users/1244884/customcommander"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600197776,
                "post_id": 63908137,
                "comment_id": 113010787,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1729980916,
                "last_edit_date": 1729980916,
                "creation_date": 1600196593,
                "answer_id": 63908311,
                "question_id": 63908137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand correctly, you want to produce an array as output. You can move your array wrapper from around the final object to the entire `jq` call to do this:\r\n\r\n```bash\r\nurl=https://raw.githubusercontent.com/qualified/challenge-data/605fb67/corona.json\r\ncurl -s $url | \r\njq &#39;[ .data[] \r\n      | select(.continent | test(&quot;Europe&quot;))\r\n      | {(.country): .cases} \r\n    ]&#39;\r\n```\r\n\r\nOutput after `| [0:4]`:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    [\r\n      {\r\n        &quot;Russia&quot;: 1073849\r\n      },\r\n      {\r\n        &quot;Spain&quot;: 603167\r\n      },\r\n      {\r\n        &quot;France&quot;: 395104\r\n      },\r\n      {\r\n        &quot;UK&quot;: 374228\r\n      }\r\n    ]\r\n\r\nIf you want an object, you could use:\r\n\r\n```bash\r\ncurl -s $url | \r\njq &#39;[ .data[]\r\n      | select(.continent | test(&quot;Europe&quot;))\r\n    ] \r\n    | map({(.country): .cases}) \r\n    | add&#39;\r\n```\r\n\r\nor:\r\n\r\n```bash\r\ncurl -s $url | \r\njq &#39;[ .data[]\r\n      | select(.continent | test(&quot;Europe&quot;))\r\n    ]\r\n    | reduce .[] as $e ({}; .[$e.country] = $e.cases)&#39;\r\n```\r\n\r\nOutput:\r\n\r\n&lt;!-- language: json --&gt;\r\n\r\n    {\r\n      &quot;Russia&quot;: 1073849,\r\n      &quot;Spain&quot;: 603167,\r\n      &quot;France&quot;: 395104,\r\n      &quot;UK&quot;: 374228,\r\n      &quot;Italy&quot;: 289990,\r\n      &quot;Germany&quot;: 264375,\r\n      &quot;Ukraine&quot;: 159702,\r\n      &quot;Romania&quot;: 105298,\r\n      &quot;Belgium&quot;: 94306,\r\n      &quot;Sweden&quot;: 87345,\r\n      &quot;Netherlands&quot;: 84778,\r\n      &quot;Poland&quot;: 75134,\r\n      &quot;Belarus&quot;: 74552,\r\n      &quot;Portugal&quot;: 65021,\r\n      &quot;Switzerland&quot;: 47751,\r\n      &quot;Moldova&quot;: 43734,\r\n      &quot;Czechia&quot;: 38187,\r\n      &quot;Austria&quot;: 34305,\r\n      &quot;Serbia&quot;: 32511,\r\n      &quot;Ireland&quot;: 31549,\r\n      &quot;Bosnia&quot;: 23929,\r\n      &quot;Denmark&quot;: 20571,\r\n      &quot;Bulgaria&quot;: 18061,\r\n      &quot;Macedonia&quot;: 15925,\r\n      &quot;Hungary&quot;: 13879,\r\n      &quot;Croatia&quot;: 13749,\r\n      &quot;Greece&quot;: 13730,\r\n      &quot;Norway&quot;: 12330,\r\n      &quot;Albania&quot;: 11672,\r\n      &quot;Finland&quot;: 8725,\r\n      &quot;Luxembourg&quot;: 7244,\r\n      &quot;Montenegro&quot;: 6900,\r\n      &quot;Slovakia&quot;: 5768,\r\n      &quot;Slovenia&quot;: 3831,\r\n      &quot;Lithuania&quot;: 3397,\r\n      &quot;Estonia&quot;: 2722,\r\n      &quot;Malta&quot;: 2454,\r\n      &quot;Iceland&quot;: 2174,\r\n      &quot;Latvia&quot;: 1482,\r\n      &quot;Andorra&quot;: 1438,\r\n      &quot;San Marino&quot;: 723,\r\n      &quot;Channel Islands&quot;: 639,\r\n      &quot;Faroe Islands&quot;: 428,\r\n      &quot;Isle of Man&quot;: 339,\r\n      &quot;Gibraltar&quot;: 334,\r\n      &quot;Monaco&quot;: 177,\r\n      &quot;Liechtenstein&quot;: 111,\r\n      &quot;Holy See (Vatican City State)&quot;: 12\r\n    }\r\n\r\nAlthough it doesn&#39;t matter on this dataset, I&#39;d prefer using `== &quot;Europe&quot;` rather than `test(&quot;Europe&quot;)` which is a bit less precise.\r\n\r\n\r\n\r\n\r\n",
                "title": "jq how to merge multiple arrays?"
            },
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1600205360,
                "last_edit_date": 1600205360,
                "creation_date": 1600197488,
                "answer_id": 63908503,
                "question_id": 63908137,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `input.json` file is:\r\n\r\n```json\r\n[{&quot;Russia&quot;: 1073849}]\r\n[{&quot;Spain&quot;: 593730}]\r\n[{&quot;France&quot;: 387252}]\r\n[{ &quot;UK&quot;: 371125}]\r\n```\r\n\r\nThen this:\r\n\r\n```lang-none\r\njq -s &#39;reduce .[] as $x ([]; . + $x)&#39; input.json\r\n```\r\n\r\nreturns:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Russia&quot;: 1073849\r\n  },\r\n  {\r\n    &quot;Spain&quot;: 593730\r\n  },\r\n  {\r\n    &quot;France&quot;: 387252\r\n  },\r\n  {\r\n    &quot;UK&quot;: 371125\r\n  }\r\n]\r\n```\r\n\r\nNotes:\r\n\r\n- `jq` can merge arrays with the `+` operator, e.g. `[1]+[2]` returns `[1,2]`.\r\n- The `-s` flag reads `input.json` and put all entries into an array. So you end up with an array of arrays that you can merge with `reduce`.\r\n\r\nThis can be simplified even further with:\r\n\r\n```lang-none\r\njq -s &#39;add&#39; input.json\r\n```",
                "title": "jq how to merge multiple arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1729980916,
        "creation_date": 1600195780,
        "last_edit_date": 1627430230,
        "question_id": 63908137,
        "body_markdown": "I have the following data, the output of multiple jq pipes:\r\n\r\n     [\r\n       {\r\n         &quot;Russia&quot;: 1073849\r\n       }\r\n     ]\r\n     [\r\n       {\r\n         &quot;Spain&quot;: 593730\r\n       }\r\n     ]\r\n     [\r\n       {\r\n         &quot;France&quot;: 387252\r\n       }\r\n     ]\r\n     [\r\n       {\r\n         &quot;UK&quot;: 371125\r\n       }\r\n     ]\r\n\r\nMy desired output is:\r\n\r\n     [\r\n       {\r\n         &quot;Russia&quot;: 1073849\r\n       },\r\n       {\r\n         &quot;Spain&quot;: 593730\r\n       },\r\n       {\r\n         &quot;France&quot;: 387252\r\n       },\r\n       {\r\n         &quot;UK&quot;: 371125\r\n       }\r\n     ]\r\n\r\nBased on similar questions I tried `&#39;.[]|transpose|map(add)&#39;` and it gives an error: `Cannot index object with number`. Also I cannot `group_by(key)` because there is no common key in the objects.",
        "link": "https://stackoverflow.com/questions/63908137/jq-how-to-merge-multiple-arrays",
        "title": "jq how to merge multiple arrays?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "group-by",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600242318,
                "last_edit_date": 1600242318,
                "creation_date": 1600226019,
                "answer_id": 63912571,
                "question_id": 63909759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I guess I should use group_by and/or reduce?\r\n\r\nIt can be done quite easily with just `group_by` and `map`:\r\n```\r\nmap(.Header.Tenant as $tenant\r\n    | .Body.values[] | {name, id, tenant: $tenant})\r\n| group_by(.name)\r\n| map(group_by(.id))\r\n| map( .[] |  (.[0] | { name }) + { (.[0].id): map(.tenant) })\r\n\r\n```\r\n\r\nOne way to understand this is to run the first two lines of the program, and then the first three lines, and proceeding incrementally from there. You could also add `debug` statements along the way.\r\n",
                "title": "jq - reformat the JSON and put values as keys into new array and objects?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600247056,
                "last_edit_date": 1600247056,
                "creation_date": 1600227913,
                "answer_id": 63912801,
                "question_id": 63909759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a more efficient solution than is possible using `group_by`. It uses `GROUPS_BY`, which is a stream-oriented generalization of `group_by`:\r\n```\r\n\r\n# Emit a stream of arrays, each corresponding to a group\r\n# defined by f, which can be any jq filter\r\n# that maps every item in the stream to a single value.\r\ndef GROUPS_BY(stream; f): \r\n   reduce stream as $x ({};\r\n     ($x|f) as $s\r\n     | ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n     | .[$t][$y] += [$x] )\r\n   | select(.)\r\n   | .[][] ;\r\n```\r\nThe solution can now be written in a straightforward manner without further recourse to `reduce`:\r\n```\r\n[ GROUPS_BY(.[]\r\n            | .Header.Tenant as $tenant\r\n            | .Body.values[] | {name, id, tenant: $tenant};\r\n            {name,id}) \r\n  | (.[0] | { name }) + { (.[0].id): map(.tenant) } ]\r\n```\r\n",
                "title": "jq - reformat the JSON and put values as keys into new array and objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1600247056,
        "creation_date": 1600203415,
        "last_edit_date": 1600228653,
        "question_id": 63909759,
        "body_markdown": "How can I reformat the JSON, create a new array based on selection criteria and by and put values as keys?\r\n\r\nHere is one fragment of the json file:\r\n```\r\n[\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;Tenant1&quot;\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;ca95&quot;,\r\n                    &quot;name&quot;: &quot;Property1&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;b126&quot;,\r\n                    &quot;name&quot;: &quot;Property2&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;aec0&quot;,\r\n                    &quot;name&quot;: &quot;Property3&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;a62b&quot;,\r\n                    &quot;name&quot;: &quot;Property4&quot;\r\n                }\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;Header&quot;: {\r\n            &quot;Tenant&quot;: &quot;Tenant2&quot;\r\n        },\r\n        &quot;Body&quot;: {\r\n            &quot;values&quot;: [\r\n                {\r\n                    &quot;id&quot;: &quot;ca95&quot;,\r\n                    &quot;name&quot;: &quot;Property1&quot;\r\n                },\r\n                {\r\n                    &quot;id&quot;: &quot;b4cd&quot;,\r\n                    &quot;name&quot;: &quot;Property4&quot;\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\nValues for the keys ``Header.Tenant`` and ``Body.values[].name`` are unique, but for the  ``Body.values[].id`` are not - for the *Property4* corresponding ``&quot;id&quot;`` from the same object is *a62b* for the *Tenant1* and *b4cd* for the *Tenant2*.\r\n\r\nI need to find out for the particular ``&quot;name/Property&quot;`` key/value how many different corresponding ``&quot;id&quot;`` and ``&quot;Tenant&quot;`` exist and group them by the value of ``&quot;id&quot;`` instead.\r\n\r\nThe result should look like the following: \r\n\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;Property1&quot;,\r\n        &quot;ca95&quot;: [\r\n            &quot;Tenant1&quot;,\r\n            &quot;Tenant2&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Property2&quot;,\r\n        &quot;b126&quot;: [\r\n            &quot;Tenant1&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Property3&quot;,\r\n        &quot;aec0&quot;: [\r\n            &quot;Tenant1&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Property4&quot;,\r\n        &quot;a62b&quot;: [\r\n            &quot;Tenant1&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Property4&quot;,\r\n        &quot;b4cd&quot;: [\r\n            &quot;Tenant2&quot;\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nHow can this be done with jq? I guess I should use group_by and/or reduce?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/63909759/jq-reformat-the-json-and-put-values-as-keys-into-new-array-and-objects",
        "title": "jq - reformat the JSON and put values as keys into new array and objects?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600264920,
                "post_id": 63920277,
                "comment_id": 113033727,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600268002,
                "post_id": 63920277,
                "comment_id": 113035512,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600288943,
                "creation_date": 1600288943,
                "answer_id": 63927661,
                "question_id": 63920277,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the -r command-line option, the following program produces the output as shown below:\r\n\r\n```\r\ngroup_by(.city)[]\r\n| .[0].city as $city\r\n| map(keys_unsorted[] | select(test(&quot;^array&quot;))) as $arrays\r\n| &quot;Now working on \\($city)&quot;,\r\n  &quot;\\($city) has the following arrays:&quot;,\r\n  $arrays[],\r\n  (.[] | to_entries[] | select(.key | test(&quot;^array&quot;))\r\n   | &quot;Content of the \\(.key)&quot;, .value[])\r\n```\r\n\r\n### Output\r\n```\r\nNow working on Chicago\r\nChicago has the following arrays:\r\narray20\r\nContent of the array20\r\n1\r\n2\r\nNow working on Denver\r\nDenver has the following arrays:\r\narray30\r\nContent of the array30\r\n3\r\nNow working on Reno\r\nReno has the following arrays:\r\narray50\r\nContent of the array50\r\n1\r\nNow working on Seattle\r\nSeattle has the following arrays:\r\narray10\r\narray11\r\nContent of the array10\r\n1\r\n2\r\nContent of the array11\r\n3\r\n```",
                "title": "jq - find the name of the array inside JSON object and then get the content of the array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600288943,
        "creation_date": 1600259927,
        "question_id": 63920277,
        "body_markdown": "I have the following JSON array\r\n\r\n```\r\n[\r\n    {\r\n        &quot;city&quot;: &quot;Seattle&quot;,\r\n        &quot;array10&quot;: [\r\n            &quot;1&quot;,\r\n            &quot;2&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;city&quot;: &quot;Seattle&quot;,\r\n        &quot;array11&quot;: [\r\n            &quot;3&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;city&quot;: &quot;Chicago&quot;,\r\n        &quot;array20&quot;: [\r\n            &quot;1&quot;,\r\n            &quot;2&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;city&quot;: &quot;Denver&quot;,\r\n        &quot;array30&quot;: [\r\n            &quot;3&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;city&quot;: &quot;Reno&quot;,\r\n        &quot;array50&quot;: [\r\n            &quot;1&quot;\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\n\r\nMy task is the following: for each ``&quot;city&quot;`` values, which are known, get the names of arrays and for each array, get its contents printed/displayed. Names of cities and arrays are unique, the content of arrays - are not.\r\n\r\nThe result should look like the following:\r\n```\r\nNow working on Seattle\r\nSeattle has the following arrays: \r\narray10\r\narray11\r\nContent of the array10\r\n1\r\n2\r\nContent of the array11\r\n3\r\n\r\nNow working on Chicago\r\nChicago has the following arrays: \r\narray20\r\nContent of the array array20\r\n1\r\n2\r\n\r\nNow working on Denver\r\nDenver has the following arrays: \r\narray30\r\nContent of the array array30\r\n3\r\n\r\nNow working on Reno\r\nDenver has the following arrays: \r\narray50\r\nContent of the array array50\r\n1\r\n```\r\n\r\nNow, for each city name (which are provided/known) I can find names of arrays using the following filter (I can put city names in the vars obviously):\r\n```\r\njq  -r .[] | select ( .name | test(&quot;Seattle&quot;) ) | del (.name) | keys |@tsv\r\n```\r\nThen assign these names to a bash variable and iterate in the new cycle to get the content of each array.\r\n\r\nWhile I can get what I want with the above, my question - is there a more efficient way to do it with jq? \r\n\r\nAnd the second, related question - if my JSON had the following structure below, would it make my task easier for the speed/efficiency/simplicity standpoint?\r\n\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;Seattle&quot;,\r\n        &quot;content&quot;: {\r\n            &quot;array10&quot;: [\r\n                &quot;1&quot;,\r\n                &quot;2&quot;\r\n            ],\r\n            &quot;array11&quot;: [\r\n                &quot;3&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Chicago&quot;,\r\n        &quot;content&quot;: {\r\n            &quot;array20&quot;: [\r\n                &quot;1&quot;,\r\n                &quot;2&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Denver&quot;,\r\n        &quot;content&quot;: {\r\n            &quot;array30&quot;: [\r\n                &quot;3&quot;\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;Reno&quot;,\r\n        &quot;content&quot;: {\r\n            &quot;array50&quot;: [\r\n                &quot;1&quot;\r\n            ]\r\n        }\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/63920277/jq-find-the-name-of-the-array-inside-json-object-and-then-get-the-content-of-t",
        "title": "jq - find the name of the array inside JSON object and then get the content of the array"
    },
    {
        "tags": [
            "json",
            "jq",
            "adjacency-matrix",
            "data-wrangling"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600262165,
                "creation_date": 1600262165,
                "answer_id": 63920900,
                "question_id": 63920424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following :\r\n\r\n    to_entries | map([[.key|tonumber],.value] | combinations) | .[]\r\n\r\n[`combinations`](https://stedolan.github.io/jq/manual/#combinations,combinations(n)) takes an array of two arrays as input and outputs an array of the combinations of the elements of the two input arrays. In our case we want to provide it with an array that contains the key and the value arrays.\r\n\r\nYou can [try it here](https://jqplay.org/s/aKd6zuLqkB).",
                "title": "Wrangling network adjacency data in jq: dictionary to array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600294541,
                "creation_date": 1600294541,
                "answer_id": 63928619,
                "question_id": 63920424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using an elementary approach here produces an efficient solution:\r\n```\r\nkeys_unsorted[] as $k\r\n| .[$k][] as $v\r\n| [$k|tonumber] + [$v]\r\n```\r\n",
                "title": "Wrangling network adjacency data in jq: dictionary to array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1600485183,
        "creation_date": 1600260538,
        "last_edit_date": 1600485183,
        "question_id": 63920424,
        "body_markdown": "I have graph data in JSON and would like to massage it a bit so that:\r\n\r\n    {&quot;1&quot;: [1, 2, 3, 4],\r\n    &quot;2&quot;: [3, 4, 7]}\r\n\r\nBecomes\r\n\r\n    [1, 1]\r\n    [1, 2]\r\n    [1, 3]\r\n    [1, 4]\r\n    [2, 3]\r\n    [2, 4]\r\n    [2, 7]\r\n\r\nIs it possible using **jq**?",
        "link": "https://stackoverflow.com/questions/63920424/wrangling-network-adjacency-data-in-jq-dictionary-to-array",
        "title": "Wrangling network adjacency data in jq: dictionary to array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "concatenation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1600271343,
                "creation_date": 1600271343,
                "answer_id": 63923675,
                "question_id": 63922373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would definitely need `group_by/1` on the `.name` field and later reorder the objects as desired.\r\n\r\n    [ group_by(.name)[] | add ] | map( { name: .name, Arrays: del(.name) } )\r\n\r\nSince the group-by functions do an internal sort on the fields applied, i.e. `.name` in your case, the key ordering of the final result is determined by the ascending order of `.name` field.\r\n\r\n&lt;sup&gt;[Demo - jqplay][1]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://jqplay.org/s/Hw5ljTydDn",
                "title": "Group arrays and move them under new object when array names are not known"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1600271343,
        "creation_date": 1600266931,
        "last_edit_date": 1600266993,
        "question_id": 63922373,
        "body_markdown": "I have the following JSON\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;T1&quot;,\r\n        &quot;R10&quot;: [&quot;A&quot;,&quot;B&quot;]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;T1&quot;,\r\n        &quot;M20&quot;: [&quot;C&quot;]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;A1&quot;,\r\n        &quot;C20&quot;: [&quot;A&quot;,&quot;B&quot;]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;B1&quot;,\r\n        &quot;V30&quot;: [&quot;3&quot;]\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;C1&quot;,\r\n        &quot;X50&quot;: [&quot;1&quot;]\r\n    }\r\n]\r\n```\r\nI want to group arrays based on ``&quot;name&quot;`` and push them under new ``&quot;Arrays&quot;`` object. So the result should look like the following:\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;T1&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;R10&quot;: [&quot;A&quot;,&quot;B&quot;],\r\n            &quot;M20&quot;: [&quot;C&quot;]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;A1&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;C20&quot;: [&quot;A&quot;,&quot;B&quot;]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;B1&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;V30&quot;: [&quot;3&quot;]\r\n        }\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;C1&quot;,\r\n        &quot;Arrays&quot;: {\r\n            &quot;X50&quot;: [&quot;1&quot;]\r\n        }\r\n    }\r\n]\r\n```\r\nI can do a selection based on the value of ``&quot;name&quot;``\r\n``[.[] | select ( .name | test(&quot;T1&quot;) )] | add`` - it does group arrays together, But I can&#39;t figure out how to generalize the filter - to apply it to the whole JSON instead of filtering based on the name.\r\n \r\nI am also stuck on how to push arrays under the ``&quot;Arrays&quot;`` object if I do not know the names of the arrays in advance.",
        "link": "https://stackoverflow.com/questions/63922373/group-arrays-and-move-them-under-new-object-when-array-names-are-not-known",
        "title": "Group arrays and move them under new object when array names are not known"
    },
    {
        "tags": [
            "json",
            "shell",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 484418,
                    "reputation": 21132,
                    "user_id": 900078,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/m5Mpk.jpg?s=256",
                    "display_name": "pynexj",
                    "link": "https://stackoverflow.com/users/900078/pynexj"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1600321035,
                "post_id": 63931452,
                "comment_id": 113051530,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1600326367,
                "last_edit_date": 1600326367,
                "creation_date": 1600325890,
                "answer_id": 63932802,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following will produce the output as shown if jq is invoked with the -r option:\r\n```\r\n.inventory[]\r\n| .profile as $profile\r\n| .invState[]\r\n| [$profile] + [.count, .Status]\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nNote, however, that if CSV output is desired, then it might be better to replace the `join` in the last line by `@csv`.\r\n\r\n### Shorter versions\r\nThe following is equivalent to the above:\r\n```\r\n.inventory[]\r\n| [.profile] + (.invState[] | [.count, .Status])\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nIf the order of the &quot;count&quot; and &quot;Status&quot; keys is fixed, you could get away with:\r\n\r\n```\r\n.inventory[] \r\n| [.profile] + (.invState[] | [.[]])\r\n| join(&quot;,&quot;)\r\n```\r\n\r\n\r\n\r\n",
                "title": "Extracting data from a json file and formatting the result in csv"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1600325985,
                "creation_date": 1600325985,
                "answer_id": 63932822,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one using GNU awk&#39;s JSON extension:\r\n\r\n    $ gawk &#39;\r\n    @load &quot;json&quot;\r\n    BEGIN {\r\n        OFS=&quot;,&quot;\r\n    }\r\n    {\r\n        lines=lines $0                           # keep appending lines\r\n        if(json_fromJSON(lines,data)!=0) {       # until you have a valid object\r\n            for(inventory in data[&quot;inventory&quot;])  # then we iterate the arrays and output\r\n                for(invState in data[&quot;inventory&quot;][inventory][&quot;invState&quot;])\r\n                print data[&quot;inventory&quot;][inventory][&quot;profile&quot;],\r\n                    data[&quot;inventory&quot;][inventory][&quot;invState&quot;][invState][&quot;count&quot;],\r\n                    data[&quot;inventory&quot;][inventory][&quot;invState&quot;][invState][&quot;Status&quot;]\r\n            lines=&quot;&quot;                             # reset the object array for next round\r\n        }\r\n    }&#39; file.json\r\n\r\nParts of the output:\r\n\r\n    Earth,6,ONLINE\r\n    Earth,8,EXIST\r\n    ...\r\n    Mars,7,EXIST\r\n    Mars,20,INSTOCK\r\n    ...\r\n    Mercury,4,EXIST\r\n    Mercury,1224,INSTOCK\r\n    ...\r\n",
                "title": "Extracting data from a json file and formatting the result in csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600326600,
                "creation_date": 1600326600,
                "answer_id": 63932961,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n\r\n    awk -F: &#39;BEGIN{ OFS=&quot;&quot;; p=c=s=&quot;&quot;; }\r\n        /&quot;profile&quot;/{ p=$2 }\r\n        /&quot;count&quot;/{ c=$2 }\r\n        /&quot;Status&quot;/{ s=$2 }\r\n        { if(s!=&quot;&quot;) { print p,c,s; s=&quot;&quot; }}&#39;  file.json\r\n\r\noutput:\r\n\r\n     &quot;Earth&quot;, 6, &quot;ONLINE&quot;\r\n     &quot;Earth&quot;, 8, &quot;EXIST&quot;\r\n     &quot;Earth&quot;, 1, &quot;GIVEN&quot;\r\n     &quot;Earth&quot;, 4, &quot;ERROR&quot;\r\n     &quot;Earth&quot;, 49, &quot;INSTOCK&quot;\r\n     &quot;Earth&quot;, 389, &quot;RELEASED&quot;\r\n     &quot;Earth&quot;, 68, &quot;DELETED&quot;\r\n     &quot;Earth&quot;, 280, &quot;CONNECTED&quot;\r\n     &quot;Earth&quot;, 1, &quot;UNINSTOCK&quot;\r\n     &quot;Mars&quot;, 7, &quot;EXIST&quot;\r\n     &quot;Mars&quot;, 20, &quot;INSTOCK&quot;\r\n     &quot;Mars&quot;, 110, &quot;RELEASED&quot;\r\n     &quot;Mars&quot;, 16, &quot;DELETED&quot;\r\n     &quot;Mars&quot;, 41, &quot;CONNECTED&quot;\r\n     &quot;Mars&quot;, 1, &quot;UNINSTOCK&quot;\r\n     &quot;Mercury&quot;, 4, &quot;EXIST&quot;\r\n     &quot;Mercury&quot;, 1224, &quot;INSTOCK&quot;\r\n     &quot;Mercury&quot;, 3, &quot;CONNECTED&quot;\r\n     &quot;Mercury&quot;, 18, &quot;RELEASED&quot;\r\n     &quot;Mercury&quot;, 5, &quot;DELETED&quot;\r\n\r\nIt is csv, that why text fields are surrounded by double quotes.... &#128513;&#128526;\r\n\r\n\r\nIf you json is not in &#39;pretty_print&#39; you might have to do something like:\r\n\r\n`cat file.json | json_pp | awk .....`\r\n",
                "title": "Extracting data from a json file and formatting the result in csv"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1600327151,
                "last_edit_date": 1600327151,
                "creation_date": 1600326777,
                "answer_id": 63932998,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I produced quite a few CSV files out of JSON files with `jq`. I find `jq` quite suited for this.\r\n\r\n### Breaking out of an array\r\n\r\nFrom:\r\n\r\n```json\r\n[&quot;Earth&quot;,&quot;Mars&quot;,&quot;Mercury&quot;]\r\n```\r\n\r\nTo:\r\n\r\n```lang-none\r\n&quot;Earth&quot;\r\n&quot;Mars&quot;\r\n&quot;Mercury&quot;\r\n```\r\n\r\nIs achieved with this filter: `.[]` which iterates over the array. As the documentation puts it:\r\n\r\n&gt; Running .[] with the input [1,2,3] will produce the numbers as three separate results, rather than as a single array.\r\n\r\n### From string to text\r\n\r\nFrom:\r\n\r\n```json\r\n[&quot;Earth&quot;,&quot;Mars&quot;,&quot;Mercury&quot;]\r\n```\r\n\r\nTo:\r\n\r\n```lang-none\r\nEarth\r\nMars\r\nMercury\r\n```\r\n\r\nIs achieved with the `--raw-output` parameter on the CLI combined with the `.[]` filter. e.g.,\r\n\r\n```lang-none\r\njq --raw-output &#39;.[]&#39; input.json\r\n```\r\n\r\n### Saving to variables\r\n\r\nYou&#39;ll need to hold a reference to `.profile` while you process the rest of the inventory. Here&#39;s a contrived example:\r\n\r\nFrom:\r\n\r\n```json\r\n[ {&quot;x&quot;: &quot;Earth&quot;, &quot;y&quot;: [&quot;1&quot;, &quot;2&quot;, &quot;3&quot;]}\r\n, {&quot;x&quot;: &quot;Mars&quot;, &quot;y&quot;: [&quot;1&quot;, &quot;2&quot;, &quot;3&quot;]}\r\n]\r\n```\r\n\r\nTo:\r\n\r\n```lang-none\r\n&quot;Earth1&quot;\r\n&quot;Earth2&quot;\r\n&quot;Earth3&quot;\r\n&quot;Mars1&quot;\r\n&quot;Mars2&quot;\r\n&quot;Mars3&quot;\r\n```\r\n\r\nIs achieved with this filter: `.[] | .x as $x | .y[] | $x + .`\r\n\r\n(You save `.x` into var `$x` that you can refer to in your filter.)\r\n\r\n\r\n\r\n---\r\n\r\nTo answer your question, given this `input.json`:\r\n\r\n```json\r\n{\r\n  &quot;inventory&quot;: [\r\n    {\r\n      &quot;profile&quot;: &quot;Earth&quot;,\r\n      &quot;invState&quot;: [\r\n        {\r\n          &quot;count&quot;: 6,\r\n          &quot;Status&quot;: &quot;ONLINE&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 8,\r\n          &quot;Status&quot;: &quot;EXIST&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 1,\r\n          &quot;Status&quot;: &quot;GIVEN&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 4,\r\n          &quot;Status&quot;: &quot;ERROR&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 49,\r\n          &quot;Status&quot;: &quot;INSTOCK&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 389,\r\n          &quot;Status&quot;: &quot;RELEASED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 68,\r\n          &quot;Status&quot;: &quot;DELETED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 280,\r\n          &quot;Status&quot;: &quot;CONNECTED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 1,\r\n          &quot;Status&quot;: &quot;UNINSTOCK&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;profile&quot;: &quot;Mars&quot;,\r\n      &quot;invState&quot;: [\r\n        {\r\n          &quot;count&quot;: 7,\r\n          &quot;Status&quot;: &quot;EXIST&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 20,\r\n          &quot;Status&quot;: &quot;INSTOCK&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 110,\r\n          &quot;Status&quot;: &quot;RELEASED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 16,\r\n          &quot;Status&quot;: &quot;DELETED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 41,\r\n          &quot;Status&quot;: &quot;CONNECTED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 1,\r\n          &quot;Status&quot;: &quot;UNINSTOCK&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;profile&quot;: &quot;Mercury&quot;,\r\n      &quot;invState&quot;: [\r\n        {\r\n          &quot;count&quot;: 4,\r\n          &quot;Status&quot;: &quot;EXIST&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 1224,\r\n          &quot;Status&quot;: &quot;INSTOCK&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 3,\r\n          &quot;Status&quot;: &quot;CONNECTED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 18,\r\n          &quot;Status&quot;: &quot;RELEASED&quot;\r\n        },\r\n        {\r\n          &quot;count&quot;: 5,\r\n          &quot;Status&quot;: &quot;DELETED&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe following invokation of `jq` should do the trick:\r\n\r\n```lang-none\r\njq --raw-output &#39;.inventory[] | .profile as $p | .invState[] | &quot;\\($p),\\(.count),\\(.Status)&quot;&#39; input.json\r\n```\r\n\r\n```lang-none\r\nEarth,6,ONLINE\r\nEarth,8,EXIST\r\nEarth,1,GIVEN\r\nEarth,4,ERROR\r\nEarth,49,INSTOCK\r\nEarth,389,RELEASED\r\nEarth,68,DELETED\r\nEarth,280,CONNECTED\r\nEarth,1,UNINSTOCK\r\nMars,7,EXIST\r\nMars,20,INSTOCK\r\nMars,110,RELEASED\r\nMars,16,DELETED\r\nMars,41,CONNECTED\r\nMars,1,UNINSTOCK\r\nMercury,4,EXIST\r\nMercury,1224,INSTOCK\r\nMercury,3,CONNECTED\r\nMercury,18,RELEASED\r\nMercury,5,DELETED\r\n```",
                "title": "Extracting data from a json file and formatting the result in csv"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600332542,
                "creation_date": 1600332542,
                "answer_id": 63934478,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU sed):\r\n\r\n    sed -nE &#39;/profile/{s/.*&quot;(\\S+)&quot;.*/\\1/;h};\r\n             /count/{s/.* (\\S+),.*/\\1/;H};\r\n             /Status/{s/.*&quot;(\\S+)&quot;.*/\\1/;H;g;s/\\n/,/gp;g;s/\\n.*\\n.*//;h}&#39; file\r\nStuff the `profile`, `count` and `Status` info in the hold space and after doing so for `Status`, retrieve the hold space, replace the newlines by commas, print and then remove `count` and `Status` details, ready for the next time.\r\n\r\nN.B. As this is json, it is better to use `jq` as this will always be a more robust solution.",
                "title": "Extracting data from a json file and formatting the result in csv"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1600365693,
                "creation_date": 1600365693,
                "answer_id": 63943805,
                "question_id": 63931452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you don&#39;t have jq or gawks json extension (requires gawkextlib) and your input is always as simple and regular as in your example then this will do what you want using GNU awk for the 3rd arg to match() and gensub():\r\n\r\n    $ cat tst.awk\r\n    BEGIN { OFS=&quot;,&quot; }\r\n    match($0,/&quot;([^&quot;]+)&quot;: *(&quot;[^&quot;]*&quot;|[0-9]+)/,a) {\r\n        tag = a[1]\r\n        val = gensub(/^&quot;|&quot;$/,&quot;&quot;,&quot;g&quot;,a[2])\r\n        f[tag] = val\r\n        if ( tag == &quot;Status&quot; ) {\r\n            print f[&quot;profile&quot;], f[&quot;count&quot;], f[&quot;Status&quot;]\r\n        }\r\n    }\r\n\r\n&lt;p&gt;\r\n\r\n    $ awk -f tst.awk file\r\n    Earth,6,ONLINE\r\n    Earth,8,EXIST\r\n    Earth,1,GIVEN\r\n    Earth,4,ERROR\r\n    Earth,49,INSTOCK\r\n    Earth,389,RELEASED\r\n    Earth,68,DELETED\r\n    Earth,280,CONNECTED\r\n    Earth,1,UNINSTOCK\r\n    Mars,7,EXIST\r\n    Mars,20,INSTOCK\r\n    Mars,110,RELEASED\r\n    Mars,16,DELETED\r\n    Mars,41,CONNECTED\r\n    Mars,1,UNINSTOCK\r\n    Mercury,4,EXIST\r\n    Mercury,1224,INSTOCK\r\n    Mercury,3,CONNECTED\r\n    Mercury,18,RELEASED\r\n    Mercury,5,DELETED\r\n\r\n",
                "title": "Extracting data from a json file and formatting the result in csv"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 2,
        "last_activity_date": 1600368295,
        "creation_date": 1600318144,
        "last_edit_date": 1600368295,
        "question_id": 63931452,
        "body_markdown": "Trying to convert the json data below into csv, using jq and or awk or python or perl or anything from Linux shell.\r\nWill appreciate your scripting help here.\r\n\r\n\r\n```json\r\n{\r\n    &quot;inventory&quot;: [\r\n        {\r\n          &quot;profile&quot;: &quot;Earth&quot;,\r\n          &quot;invState&quot;: [\r\n            {\r\n              &quot;count&quot;: 6,\r\n              &quot;Status&quot;: &quot;ONLINE&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 8,\r\n              &quot;Status&quot;: &quot;EXIST&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 1,\r\n              &quot;Status&quot;: &quot;GIVEN&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 4,\r\n              &quot;Status&quot;: &quot;ERROR&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 49,\r\n              &quot;Status&quot;: &quot;INSTOCK&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 389,\r\n              &quot;Status&quot;: &quot;RELEASED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 68,\r\n              &quot;Status&quot;: &quot;DELETED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 280,\r\n              &quot;Status&quot;: &quot;CONNECTED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 1,\r\n              &quot;Status&quot;: &quot;UNINSTOCK&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;profile&quot;: &quot;Mars&quot;,\r\n          &quot;invState&quot;: [\r\n            {\r\n              &quot;count&quot;: 7,\r\n              &quot;Status&quot;: &quot;EXIST&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 20,\r\n              &quot;Status&quot;: &quot;INSTOCK&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 110,\r\n              &quot;Status&quot;: &quot;RELEASED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 16,\r\n              &quot;Status&quot;: &quot;DELETED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 41,\r\n              &quot;Status&quot;: &quot;CONNECTED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 1,\r\n              &quot;Status&quot;: &quot;UNINSTOCK&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;profile&quot;: &quot;Mercury&quot;,\r\n          &quot;invState&quot;: [\r\n            {\r\n              &quot;count&quot;: 4,\r\n              &quot;Status&quot;: &quot;EXIST&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 1224,\r\n              &quot;Status&quot;: &quot;INSTOCK&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 3,\r\n              &quot;Status&quot;: &quot;CONNECTED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 18,\r\n              &quot;Status&quot;: &quot;RELEASED&quot;\r\n            },\r\n            {\r\n              &quot;count&quot;: 5,\r\n              &quot;Status&quot;: &quot;DELETED&quot;\r\n            }\r\n          ]\r\n        }\r\n       ]\r\n}\r\n```\r\n\r\n\r\nThe csv output should look like this:\r\n\r\n    Earth,6,ONLINE\r\n    Earth,8,EXIST\r\n    Earth,1,GIVEN\r\n    Earth,4,ERROR\r\n    Earth,49,INSTOCK\r\n    Earth,389,RELEASED\r\n    Earth,68,DELETED\r\n    Earth,280,CONNECTED\r\n    Earth,1,UNINSTOCK\r\n    Mars,7,EXIST\r\n    Mars,20,INSTOCK\r\n    etc\r\n\r\nPlease see the attached image\r\n\r\n[csv output][1]\r\netc  \r\n\r\nWill appreciate any advice here.\r\nI have tried using jq and awk but not getting the right result.\r\n\r\n\r\n  [1]: https://i.sstatic.net/2Rh0B.png\r\n",
        "link": "https://stackoverflow.com/questions/63931452/extracting-data-from-a-json-file-and-formatting-the-result-in-csv",
        "title": "Extracting data from a json file and formatting the result in csv"
    },
    {
        "tags": [
            "arrays",
            "json",
            "search",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600352651,
                "post_id": 63938687,
                "comment_id": 113066414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600352914,
                "post_id": 63938687,
                "comment_id": 113066582,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600355316,
                "post_id": 63938687,
                "comment_id": 113067964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600352925,
                "last_edit_date": 1600352925,
                "creation_date": 1600348771,
                "answer_id": 63938954,
                "question_id": 63938687,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could very simply use the recursive descent on the `webServerName` field, ignore the empty ones and select ones ending with `:443` using the `endswith/1` function which is much straightforward than using a regex based approach. \r\n\r\nOn the obtained result use the `unique` function to remove the duplicated entries.\r\n\r\n    [ .. | .webServerName? | select(. != null and endswith(&quot;:443&quot;)) ] | unique[]\r\n\r\nUse the `-r` flag in command line to emit the output in raw output mode to loose the quotes.\r\n\r\nAnother variant involving `map`, traversing from top down\r\n\r\n    map(.Body[].webServerName | select(. != null and endswith(&quot;:443&quot;) ) ) | unique[]\r\n\r\n---\r\n\r\nOP had a follow-up requirement to ignore URLs containing the part `&quot;server-internal&quot;` for which you could add another condition to the select\r\n\r\n    map( .Body[].webServerName | \r\n      select( ( . != null and endswith(&quot;:443&quot;) ) and \r\n        ( test(&quot;server-internal&quot;) | not ) ) ) | \r\n    unique[]",
                "title": "jq - select all non-empty unique values of a key matching a regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601876603,
        "creation_date": 1600347944,
        "last_edit_date": 1601876603,
        "question_id": 63938687,
        "body_markdown": "Here is my `JSON` file\r\n```\r\n[\r\n    {\r\n        &quot;Body&quot;: [\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;webApplicationId&quot;: &quot;/solr&quot;,\r\n                &quot;webServerName&quot;: &quot;localhost&quot;\r\n            },\r\n           {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;contextRoot&quot;: &quot;/backoffice&quot;,\r\n                &quot;webApplicationId&quot;: &quot;backoffice&quot;,\r\n                &quot;webServerName&quot;: &quot;Catalina/localhost&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;discoveredName&quot;: &quot;ImpExImportJob&quot;,\r\n                &quot;displayName&quot;: &quot;ImpExImportJob&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-D2B53C681D503292&quot;,\r\n                &quot;toRelationships&quot;: {\r\n                    &quot;calls&quot;: [\r\n                        &quot;SERVICE-A744C713BB5D832B&quot;\r\n                    ]\r\n                }\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;JAVA&quot;,\r\n                &quot;discoveredName&quot;: &quot;CronJobs&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n                &quot;contextRoot&quot;: &quot;/&quot;,\r\n                &quot;discoveredName&quot;: &quot;www.example.com:443&quot;,\r\n                &quot;displayName&quot;: &quot;www.example.com:443&quot;,\r\n                &quot;serviceType&quot;: &quot;WebRequest&quot;,\r\n                &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n                &quot;contextRoot&quot;: &quot;/service&quot;,\r\n                &quot;discoveredName&quot;: &quot;www.example.com:443&quot;,\r\n                &quot;displayName&quot;: &quot;www.example.com:443&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-96405085FB29CC50&quot;,\r\n                &quot;webServerName&quot;: &quot;www.example.com:443&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n                &quot;contextRoot&quot;: &quot;/nodes&quot;,\r\n                &quot;discoveredName&quot;: &quot;www.exampleA.com:443&quot;,\r\n                &quot;displayName&quot;: &quot;www.exampleA.com:443&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-15578BCF4A5FF4D5&quot;,\r\n                &quot;toRelationships&quot;: {},\r\n                &quot;webServerName&quot;: &quot;www.exampleA.com:443&quot;\r\n            },\r\n            {\r\n                &quot;agentTechnologyType&quot;: &quot;APACHE&quot;,\r\n                &quot;contextRoot&quot;: &quot;/&quot;,\r\n                &quot;discoveredName&quot;: &quot;www.example.com:80&quot;,\r\n                &quot;displayName&quot;: &quot;www.example.com:80&quot;,\r\n                &quot;entityId&quot;: &quot;SERVICE-F9193C47A131E506&quot;,\r\n                &quot;toRelationships&quot;: {},\r\n                &quot;webServerName&quot;: &quot;www.example.com:80&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\nMy task - to select all *unique, non-empty* values of the ``&quot;webServerName&quot;`` key which have the web URL form, ending at ``:443`` and display all these values without double quotes one on each line. \r\n\r\nThe result should look like the following:\r\n\r\n```\r\nwww.example.com:443\r\nwww.exampleA.com:443\r\n```\r\nPlease note that ``&quot;webServerName&quot;`` is not present in certain objects and might have duplicate values as well.\r\n\r\nI came up with the following jq filter\r\n```\r\njq -r &#39;[.[] |.Body | .[]  | select((.webServerName !=null) and (.webServerName | test (&quot;\\\\w[a-z0-9-.]+.[a-z]{2,3}:443$&quot;)) ) ] | [.[].webServerName] | unique | .[]&#39; services.json\r\n```\r\n\r\nMy question - is there a much more elegant, less complicated filter with `jq` accomplishing the same?\r\n\r\nP.S. One additional requirement - exclude values that have certain patterns in the `url`. \r\nSo for example the `url` contains ``server-internal`` in the `url`, then ``www.server-internal.example.com:443`` or ``server-internal.b.example.com:443`` should be filtered out.\r\nIs the above better to do with regex or there are better ways?",
        "link": "https://stackoverflow.com/questions/63938687/jq-select-all-non-empty-unique-values-of-a-key-matching-a-regex",
        "title": "jq - select all non-empty unique values of a key matching a regex"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600359611,
                "creation_date": 1600359611,
                "answer_id": 63942229,
                "question_id": 63941787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use just `jq` to create the json:\r\n\r\n    jq &#39; .stageName  = .stageStates[0].stageName\r\n       | .actionName = .stageStates[0].actionStates[0].actionName\r\n       | .token      = .stageStates[0].actionStates[0].latestExecution.token\r\n       | .result     = { &quot;status&quot;: &quot;Approved&quot;, &quot;summary&quot;: &quot;&quot; }\r\n       | del(.stageStates, .pipelineVersion)\r\n       &#39; file.json",
                "title": "Write json from bash pipe with several variable interpolations"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600367342,
                "creation_date": 1600367342,
                "answer_id": 63944202,
                "question_id": 63941787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your `select(.stageName == &quot;Approval&quot;)`, it would appear that you are attempting to parameterize by the &quot;stageName&quot;, so the following might be close to what you&#39;re looking for:\r\n\r\n```\r\n&quot;Approval&quot; as $stage\r\n| { pipelineName, stageName: $stage, actionName: $stage }\r\n  + (.stageStates[] \r\n     | select(.stageName == $stage).actionStates[]\r\n     | select(.actionName == $stage)\r\n     | {token: .latestExecution.token, result: {status: &quot;Approved&quot;, summary: &quot;&quot;}})\r\n```\r\n\r\n",
                "title": "Write json from bash pipe with several variable interpolations"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1600434196,
        "creation_date": 1600357945,
        "last_edit_date": 1600434196,
        "question_id": 63941787,
        "body_markdown": "I have this output from a pipe \r\n\r\n```\r\n{\r\n  &quot;pipelineName&quot;: &quot;pipelineName-AAAAQ6UFM&quot;,\r\n  &quot;pipelineVersion&quot;: 2,\r\n  &quot;stageStates&quot;: [\r\n    {\r\n      &quot;stageName&quot;: &quot;Approval&quot;,\r\n      &quot;inboundTransitionState&quot;: {\r\n        &quot;enabled&quot;: true\r\n      },\r\n      &quot;actionStates&quot;: [\r\n        {\r\n          &quot;actionName&quot;: &quot;Approval&quot;,\r\n          &quot;latestExecution&quot;: {\r\n            &quot;status&quot;: &quot;InProgress&quot;,\r\n            &quot;token&quot;: &quot;aaaa-aaaa-4316-a95f-2efc51d05761&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;latestExecution&quot;: {\r\n        &quot;pipelineExecutionId&quot;: &quot;fc73f4cb-c5a9-44a8-8fc1-d7e50259f485&quot;,\r\n        &quot;status&quot;: &quot;InProgress&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nI am trying to write a json like this \r\n\r\n```\r\n{\r\n  &quot;pipelineName&quot;: &quot;pipelineName-AAAAQ6UFM&quot;,\r\n  &quot;stageName&quot;: &quot;Approval&quot;,\r\n  &quot;actionName&quot;: &quot;Approval&quot;,\r\n  &quot;token&quot;: &quot;aaaa-aaaa-4316-a95f-2efc51d05761&quot;,\r\n  &quot;result&quot;: {\r\n    &quot;status&quot;: &quot;Approved&quot;,\r\n    &quot;summary&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\n\r\nI could maybe set two variables from the pipeoutput with the read command but I don&#39;t know how to set both of them. \r\n\r\n**token**\r\n```\r\njq -r &#39; .stageStates[] | select(.stageName == &quot;Approval&quot;) | .actionStates[0].latestExecution.token&#39;\r\n```\r\n\r\n\r\n**pipelineName**\r\n```\r\njq -r &#39;.pipelineName&#39;\r\n```\r\n\r\nThen I might be able to write the json with the jq command. \r\n\r\nWhat would be the best way to do this ?",
        "link": "https://stackoverflow.com/questions/63941787/write-json-from-bash-pipe-with-several-variable-interpolations",
        "title": "Write json from bash pipe with several variable interpolations"
    },
    {
        "tags": [
            "json",
            "bash",
            "match",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600404205,
                "post_id": 63948803,
                "comment_id": 113082942,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1600405289,
                "creation_date": 1600405289,
                "answer_id": 63949604,
                "question_id": 63948803,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After making the obvious corrections in the files, the following invocation:\r\n\r\n    jq --argfile file1 file1.json -f program.jq file2.json\r\n\r\nproduces the desired result, where program.jq contains:\r\n```\r\n($file1 | INDEX(.value[]; .id) | map_values(.description)) as $dict\r\n| map(.description = $dict[.descriptionId] | del(.descriptionId))\r\n```\r\n  \r\nYou could use moreutil&#39;s [tag:sponge] to overwrite file2.json if you&#39;re confident that that&#39;s what you really want.\r\n\r\n",
                "title": "Join Match on JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1600405959,
        "creation_date": 1600398576,
        "last_edit_date": 1600405959,
        "question_id": 63948803,
        "body_markdown": "I have two output files, and they have multiple repeating entries with the following structure:\r\n\r\n`file1.json`\r\n```json\r\n{\r\n &quot;value&quot;: [\r\n    {\r\n          &quot;description&quot;: &quot;foo bar&quot;,\r\n          &quot;id&quot;: &quot;111111-0000-0000-1111-foobar&quot;,\r\n    },\r\n  ]\r\n}\r\n```\r\n`file2.json`\r\n```json\r\n[\r\n    {\r\n        &quot;businessPhones&quot;: [555-505-4321],\r\n        &quot;displayName&quot;: &quot;Abc&quot;,\r\n        &quot;givenName&quot;: &quot;abc&quot;,\r\n        &quot;id&quot;: &quot;000000-1111-1111-0000-abcabc&quot;,\r\n        &quot;descriptionId&quot;: &quot;111111-0000-0000-1111-foobar&quot;\r\n    },\r\n]\r\n```\r\nMy need is to match the value of `descriptionId` from *file2* found in *file1*; But want to produce a final out —even if it is *file3*, that replaces that key value in a way to ends up into something like this:\r\n\r\n`file3.json`\r\n```json\r\n[\r\n    {\r\n        &quot;businessPhone&quot;: [555-505-4321],\r\n        &quot;displayName&quot;: &quot;Abc&quot;,\r\n        &quot;givenName&quot;: &quot;abc&quot;,\r\n        &quot;id&quot;: &quot;000000-1111-1111-0000-abcabc&quot;,\r\n        &quot;description&quot;: &quot;foo bar&quot;\r\n    },\r\n]\r\n```\r\nSo far, I&#39;ve been able to massage some data using Bash and JQ —but at odds on how I can then parse these together.\r\n",
        "link": "https://stackoverflow.com/questions/63948803/join-match-on-json-using-jq",
        "title": "Join Match on JSON using JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19540829,
                    "reputation": 11,
                    "user_id": 14298593,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e916cc5b891dfae4c8fb76dff5681f92?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bat_singer",
                    "link": "https://stackoverflow.com/users/14298593/bat-singer"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600899325,
                "post_id": 63950396,
                "comment_id": 113238510,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600415024,
                "creation_date": 1600415024,
                "answer_id": 63951329,
                "question_id": 63950396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get just the elements of the array with a different domain via:\r\n\r\n```sh\r\n$ jq &#39;.data[] | select(.domain != &quot;moderator&quot; and .domain != &quot;owner&quot;)&#39; input.json\r\n{\r\n  &quot;id&quot;: 3,\r\n  &quot;domain&quot;: &quot;34b5756175a848f7a1395e1a19e10602&quot;\r\n}\r\n```\r\n\r\nIf you just want the id value and not the entire object, add `| .id` to the end of the `jq` filter.",
                "title": "filter json using jq and get entire other value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600415086,
                "creation_date": 1600415086,
                "answer_id": 63951351,
                "question_id": 63950396,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `jq` function `select`\r\n\r\n    cat text.json | jq &#39;.data[] | select((.domain != &quot;moderator&quot;) and (.domain != &quot;owner&quot;))&#39;\r\n\r\nAlso, you can use the `length` function to get the size of the array.\r\n\r\n    jq &#39;.[] | length&#39; test.json\r\n\r\n",
                "title": "filter json using jq and get entire other value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1600899306,
        "creation_date": 1600410517,
        "last_edit_date": 1600899306,
        "question_id": 63950396,
        "body_markdown": "I&#39;m trying to filter the following json object to get the id which doesn&#39;t have a domain value which is either &quot;moderator&quot; or &quot;owner&quot; using jq in bash script.The problem is my third domain value is random and not predetermined. How do I filter it? \r\n\r\n   ```\r\n{\r\n    &quot;data&quot;:[\r\n      {\r\n         &quot;id&quot;:1,\r\n         &quot;domain&quot;:&quot;moderator&quot;\r\n      },\r\n      {\r\n         &quot;id&quot;:2,\r\n         &quot;domain&quot;:&quot;owner&quot;\r\n      },\r\n      {\r\n         &quot;id&quot;:3,\r\n         &quot;domain&quot;:&quot;34b5756175a848f7a1395e1a19e10602&quot;\r\n      }\r\n    ]\r\n}\r\n",
        "link": "https://stackoverflow.com/questions/63950396/filter-json-using-jq-and-get-entire-other-value",
        "title": "filter json using jq and get entire other value"
    },
    {
        "tags": [
            "json",
            "bash",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1600427953,
                "creation_date": 1600427953,
                "answer_id": 63954752,
                "question_id": 63954278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the error message suggests, put parentheses around the key:\r\n```\r\njq -r --arg k &quot;foo&quot; --arg v &quot;bar&quot;  &#39;.newField += {($k):$v}&#39; myfile\r\n```\r\njq requires keys given by expressions (i.e. not literal strings) to be parenthesized ([noted in the manual](https://stedolan.github.io/jq/manual/v1.6/#ObjectConstruction:{})).",
                "title": "jq pass argument as a key to new field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1600428072,
                "creation_date": 1600428072,
                "answer_id": 63954787,
                "question_id": 63954278,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If this helps, using the following uses the arg var itself as json key, and the arg value as the json value:\r\n\r\n    $ jq -r --arg foo &quot;bar&quot;  &#39;.newField += {$foo}&#39; myfile\r\n    ....\r\n    &quot;newField&quot;: {\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n  ",
                "title": "jq pass argument as a key to new field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1600433958,
        "creation_date": 1600426011,
        "last_edit_date": 1600433958,
        "question_id": 63954278,
        "body_markdown": "I&#39;m trying to add new field in a json file using jq:\r\n```\r\njq -r --arg k &quot;foo&quot; --arg v &quot;bar&quot;  &#39;.newField += {$k:$v}&#39; myfile\r\n```\r\nBut it results in:\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.newField += {$k:$v}                \r\njq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 1:\r\n.newField += {$k:$v}              \r\njq: 2 compile errors\r\n\r\n```\r\n\r\nWhen I remove key variable like below it works fine:\r\n```\r\njq -r --arg k &quot;foo&quot; --arg v &quot;bar&quot;  &#39;.newField += {&quot;static_key&quot;:$v}&#39; myfile\r\n```\r\n\r\nAny idea how to use key name from jq arg?",
        "link": "https://stackoverflow.com/questions/63954278/jq-pass-argument-as-a-key-to-new-field",
        "title": "jq pass argument as a key to new field"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "replace",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1600601539,
                "post_id": 63977910,
                "comment_id": 113133511,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600604791,
                "post_id": 63977910,
                "comment_id": 113134361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600605241,
                "post_id": 63977910,
                "comment_id": 113134483,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600605502,
                "post_id": 63977910,
                "comment_id": 113134561,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8760742,
                    "reputation": 2207,
                    "user_id": 13527856,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/IZXmn.jpg?s=256",
                    "display_name": "MarcoLucidi",
                    "link": "https://stackoverflow.com/users/13527856/marcolucidi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600607363,
                "post_id": 63977910,
                "comment_id": 113135044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600607669,
                "post_id": 63977910,
                "comment_id": 113135130,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600607709,
                "post_id": 63977910,
                "comment_id": 113135146,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600607914,
                "post_id": 63977910,
                "comment_id": 113135198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600618114,
                "post_id": 63977910,
                "comment_id": 113138050,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600643086,
                "post_id": 63977910,
                "comment_id": 113144087,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600667694,
                "post_id": 63977910,
                "comment_id": 113148043,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600691834,
                "post_id": 63977910,
                "comment_id": 113158101,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600691890,
                "post_id": 63977910,
                "comment_id": 113158137,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600693647,
                "post_id": 63977910,
                "comment_id": 113159030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1600693825,
                "post_id": 63977910,
                "comment_id": 113159125,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600693874,
                "post_id": 63977910,
                "comment_id": 113159158,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1600695620,
                "post_id": 63977910,
                "comment_id": 113160177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8420642,
                    "reputation": 577,
                    "user_id": 6319555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c980bfdff56e5504ecc6b23d3227f384?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Invisible999",
                    "link": "https://stackoverflow.com/users/6319555/invisible999"
                },
                "reply_to_user": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601280314,
                "post_id": 63977910,
                "comment_id": 113346993,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1601291825,
                "post_id": 63977910,
                "comment_id": 113352192,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1601876716,
                "last_edit_date": 1601876716,
                "creation_date": 1600694094,
                "answer_id": 63993053,
                "question_id": 63977910,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, we&#39;re going to want to make your `URL_list` be an array instead of a string:\r\n\r\n```\r\nreadarray -t URL_list &lt; &lt;(jq -r &#39;map(.Body[].webServerName | \r\n                                 select( (. != null and endswith(&quot;:443&quot;) ) and\r\n                                         ( test(&quot;commerce|backoffice&quot;) | not ) ) ) | \r\n                                 unique[] | .[0:-4]&#39; &lt;&lt;&lt;&quot;$services_json&quot;)\r\n```\r\n\r\nNext, we&#39;re going to make only one copy of `jq` take all your URLs as line-oriented input, and emit one `JSON` document per URL on `stdout`, with a tab between the URL and the document itself:\r\n\r\n```\r\nbuild_updated_json_documents() {\r\n  jq --slurpfile loc &quot;loc.json&quot; \\\r\n     --argjson tmpl &quot;$(&lt;tmpl.json)&quot; \\\r\n     -c -Rr  &#39;\r\n    ($tmpl | .locations|=$loc[]) as $tmpl_with_loc |\r\n    . as $URL |\r\n    ($tmpl_with_loc |\r\n     .name=$URL |\r\n     .script.events[].url=$URL | \r\n     .script.events[].description=&quot;Loading of URL \\&quot;\\($URL)\\&quot;&quot;) |\r\n    &quot;\\($URL)\\t\\(. | tojson)&quot;\r\n  &#39; &lt; &lt;(printf &#39;%s\\n&#39; &quot;${URL_list[@]}&quot;)\r\n}\r\n```\r\n\r\n...and pipe the resulting stream to a function that reads it line-by-line and does the curl requests, piping direct from the copy of `curl` that would otherwise be generating a temp file to the one that&#39;s coming up with your final result to be stored:\r\n\r\n```\r\nhandle_each_document() {\r\n  while IFS=$&#39;\\t&#39; read -r url doc; do\r\n    # first, ask our remote server to update this document for us\r\n    # (would be nice if the server would do this in bulk, no?)\r\n    # ...and then forward that request to the other server.\r\n    curl --location \\\r\n         --request PUT \\\r\n         &quot;$curl_combined_update_put&quot; \\\r\n         -H &quot;accept: application/json; charset=utf-8&quot; \\\r\n         -H &quot;Content-Type: application/json; charset=utf-8&quot; \\\r\n         -H &quot;Authorization: Bearer ${token}&quot; \\\r\n         -d- &lt;&lt;&lt;&quot;$doc&quot; \\\r\n    | curl --location \\\r\n           --request PUT \\\r\n           &quot;$curl_combined_update_put&quot; \\\r\n           -H &quot;accept: application/json; charset=utf-8&quot; \\\r\n           -H &quot;Content-Type: application/json; charset=utf-8&quot; \\\r\n           -H &quot;Authorization: Bearer ${token}&quot; \\\r\n           -d- &gt;&quot;${url}-updated.json&quot;\r\n  done\r\n}\r\n\r\nbuild_updated_json_documents | handle_each_document\r\n```\r\n",
                "title": "Modifying JSON inside bash loop using jq - reading/writing from files or store all data at vars?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1601876716,
        "creation_date": 1600597505,
        "last_edit_date": 1601876691,
        "question_id": 63977910,
        "body_markdown": "I have the following `JSON` template file - `tmpl.json`\r\n```\r\n{\r\n  &quot;locations&quot;: [],\r\n  &quot;name&quot;: &quot;&quot;,\r\n  &quot;script&quot;: {\r\n    &quot;events&quot;: [\r\n      {\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;type&quot;: &quot;navigate&quot;,\r\n        &quot;url&quot;: &quot;&quot;,\r\n        &quot;wait&quot;: {\r\n          &quot;waitFor&quot;: &quot;page_complete&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;version&quot;: &quot;1.0&quot;\r\n  },\r\n  &quot;type&quot;: &quot;BROWSER&quot;\r\n}\r\n```\r\nI need to use the above file as a template and add content into ``.locations[]``, ``.name``, ``.script.events[].description`` and ``.script.events[].url`` inside a loop dynamically and then use in the same loop the resulted `JSON` with ``curl`` PUT call. \r\n\r\nThe content of the ``locations[]`` which needs to be added is a static array in a separate `loc.json` file:\r\n```\r\n[&quot;LOCATION-577B&quot;,&quot;LOCATION-D7FF&quot;,&quot;LOCATION-8BE4&quot;,&quot;LOCATION-0CE9&quot;]\r\n```\r\nWhile the values for other keys are calculated dynamically inside the loop.\r\n\r\nHere is the way I manipulate the data to create a temporary `JSON` file for each iteration of the loop. $1 is the parameter calculated in the loop and then passed to the function to create temporary `JSON` which then is used with the ``curl``.\r\n```\r\njq --slurpfile loc &quot;loc.json&quot; \\\r\n        --arg URL &quot;$1&quot; \\\r\n        &#39;.locations|=$loc[] |\r\n        .name=$URL |\r\n    .script.events[].url=$URL | \r\n    .script.events[].description=&quot;Loading of URL \\&quot;&quot; +$URL + &quot;\\&quot;&quot;&#39; \\\r\n        &quot;tmpl.json&quot; &gt;&quot;$1-temp.json&quot;\r\n```\r\n\r\nWhile the above works, I don&#39;t consider it a very clean or efficient way to deal with the problem. I need to iterate the loop over 1000 times which means creating 1000 temporary files locally and clean up afterward.\r\n\r\nWhat would be a better way to deal with the problem? Read both the static locations array and the template files into variables via `heredocs` and use them inside the loop? \r\nOr assign the resulted `JSON` output to a variable and then use it in the curl PUT call? \r\n\r\nHowever, in the latter case, careful handling needs to be done of `whitespaces` and other special characters... The template file I&#39;ve shown is just a fragment from the whole `JSON` file which contains way more key/values, but I need to modify only the keys outlined in the above.\r\n\r\n**Update/clarification:** ``$1`` parameter used in the `jq` call is a single URL without http/https prefix. The list of URLs is calculated using another function/jq call and assigned to a bash var $URL_list. Then this var is used in the ``for`` loop to call the function which creates updates `JSON` for each URL. \r\n\r\nThe REST calls to also use ``curl_combined_parameter`` and ``curl_combined_update_put`` vars which are full requests with various parameters but they don&#39;t have a relation with the problem I am trying to solve.\r\n\r\n\r\nSo the cut-down version of the whole script is the following:\r\n```\r\n#!/bin/bash\r\n# Initiate the REST call which generates URL list\r\n\r\n\r\nfunction get_url_list() {\r\n# The function initiates REST call via curl with the $curl_combined_parameter, \r\n# pipes the result to `jq`, and assigns the resulted list to a var URL_list. \r\n\r\n    services_json=$(curl -s \\\r\n        --location \\\r\n        --request GET \\\r\n        &quot;$curl_combined_parameter&quot; \\\r\n        --header &quot;Authorization: Bearer ${token}&quot;)\r\n\r\n    # Now we filter the resulted `json` and get the list of sites\r\n    URL_list=$(echo &quot;$services_json&quot; | \r\n                     jq -r &#39; map(.Body[].webServerName | \r\n                     select( (. != null and endswith(&quot;:443&quot;) ) and ( test(&quot;commerce|backoffice&quot;) | not ) ) ) | \r\n                     unique[] | .[0:-4] &#39;)\r\n}\r\n\r\nfunction update_json() {\r\njq --slurpfile loc &quot;loc.json&quot; \\\r\n        --arg URL &quot;$1&quot; \\\r\n        &#39;.locations|=$loc[] |\r\n        .name=$URL |\r\n    .script.events[].url=$URL | \r\n    .script.events[].description=&quot;Loading of URL \\&quot;&quot; +$URL + &quot;\\&quot;&quot;&#39; \\\r\n        &quot;tmpl.json&quot; &gt;&quot;$1-temp.json&quot;\r\n}\r\n\r\npush_changes(){\r\n# take the resulted `JSON` generated from `update_json` and push it via curl PUT call\r\n curl --location \\\r\n        --request PUT \\\r\n        &quot;$curl_combined_update_put&quot; \\\r\n        -H &quot;accept: application/json; charset=utf-8&quot; \\\r\n        -H &quot;Content-Type: application/json; charset=utf-8&quot; \\\r\n        -H &quot;Authorization: Bearer ${token}&quot; \\\r\n        -d &quot;@$1-temp.json&quot; &gt;&gt;&quot;$1-updated.json&quot;\r\n}\r\n\r\nfor i in $URL_list; do \r\nupdate_json &quot;$i&quot;\r\npush_changes &quot;$i&quot;\r\ndone\r\n``` \r\n \r\n\r\nSuggestions are welcome. I just want to reduce creating unnecessary temp files and encapsulate all data inside the script.\r\nThanks.",
        "link": "https://stackoverflow.com/questions/63977910/modifying-json-inside-bash-loop-using-jq-reading-writing-from-files-or-store-a",
        "title": "Modifying JSON inside bash loop using jq - reading/writing from files or store all data at vars?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1600728384,
                "last_edit_date": 1600728384,
                "creation_date": 1600702195,
                "answer_id": 63995419,
                "question_id": 63989426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following response may be of interest in the case (contrary to the specifics of this particular question)\r\nthat the output array is small enough to fit into memory.\r\n\r\nOne option would be to change the second invocation of jq to this form:\r\n\r\n    jq -nc &#39;[inputs | .... ]&#39;\r\n\r\nThe -n option here goes with `inputs`, and the outer square brackets put everything into an array.  \r\n\r\nAnother possibility, again based on the above assumption, might be to combine the two calls to jq into one:\r\n\r\n```\r\n&lt; data.json jq -cn --stream &#39;\r\n  [fromstream(1|truncate_stream(inputs))\r\n   | if has (&quot;middleName&quot;) then .sortableMiddleName=.middleName \r\n     else . end\r\n     | if has(&quot;middleName&quot;) then .middleName=[.middleName] \r\n       else . end ]&#39;\r\n\r\n",
                "title": "How to use jq streaming for processing large array of objects and convert into array of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1600713919,
                "creation_date": 1600713919,
                "answer_id": 63998249,
                "question_id": 63989426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There should be no need to invoke jq twice, but because the output array is going to be so large, your best bet is probably to convert your stream of objects to a JSON array in a funky way, e.g.\r\n\r\n```\r\necho &#39;[&#39;\r\n&lt; data.json jq -nr --stream &#39;\r\n  fromstream(1|truncate_stream(inputs))\r\n  | (if has (&quot;middleName&quot;) then .sortableMiddleName=.middleName \r\n     else . end\r\n     | if has(&quot;middleName&quot;) then .middleName=[.middleName] \r\n       else . end), &quot;,&quot;&#39; | sed &#39;$d&#39;\r\necho &#39;]&#39;\r\n```",
                "title": "How to use jq streaming for processing large array of objects and convert into array of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1665808719,
                "creation_date": 1665808719,
                "answer_id": 74076729,
                "question_id": 63989426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thanks to the &quot;[JSON Machine&quot;][1] library, there&#39;s a simple and relatively fast solution to the original problem that avoids the disadvantages (*) of jq&#39;s streaming parser (jq --stream), though it does entail installing more software.\r\n\r\nTo make it trivial to use, I wrote a script named `jm` (which can be found [here][2]).  A solution can then be derived from one of the other solutions on this page by simply calling `jm` to create a stream of the top-level objects. For example:\r\n```\r\njm data.json | jq &#39;\r\n  (if has (&quot;middleName&quot;) then .sortableMiddleName=.middleName \r\n   else . end\r\n  | if has(&quot;middleName&quot;) then .middleName=[.middleName] \r\n    else . end), &quot;,&quot;&#39; | sed &#39;$d&#39;; echo &#39;]&#39;\r\n```\r\n\r\n---\r\n\r\n(*) The main disadvantages being slowness and obscurity.\r\n\r\n  [1]: https://github.com/halaxa/json-machine\r\n  [2]: https://github.com/pkoppstein/jq",
                "title": "How to use jq streaming for processing large array of objects and convert into array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1665808719,
        "creation_date": 1600680100,
        "last_edit_date": 1642585077,
        "question_id": 63989426,
        "body_markdown": "I have a verge large file, 24 GB which consists an array of 22M JSON objects. I have to do some manipulation for each JSON object and write into another file. I am using below command\r\n```\r\njq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; test.json \\\r\n| jq -c &#39; if has (&quot;middleName&quot;) then .sortableMiddleName=.middleName else . end | if has(&quot;middleName&quot;) then .middleName=[.middleName] else . end&#39; \\\r\n&gt; test_new.json\r\n```\r\nThe command works without any issues but the output contains JSON objects separated by new line and there is no parent array. For eg initially, the structure of file was like below\r\n```\r\n[\r\n\r\nobject 1,\r\nobject 2,\r\n........,\r\n.........\r\n\r\n]\r\n```\r\nAfter processing the file, the structure of output file was like below.\r\n```\r\nobject 1\r\n\r\nobject 2\r\n\r\n........\r\n\r\n........\r\n```\r\nHere there are no array brackets plus each object is separated by new line. I want to convert it into original structure with an array consists of objects separated by comma without affecting memory\r\n\r\nAny help is appreciated\r\n",
        "link": "https://stackoverflow.com/questions/63989426/how-to-use-jq-streaming-for-processing-large-array-of-objects-and-convert-into-a",
        "title": "How to use jq streaming for processing large array of objects and convert into array of objects"
    }
]