[
    {
        "tags": [
            "json",
            "jq",
            "flatten"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638964240,
                "creation_date": 1638964240,
                "answer_id": 70274532,
                "question_id": 70272321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure if I understood correctly what you were trying to achieve but this at least works on your sample data:\r\n```\r\n[\r\n  .[0] | [.level1key] + (\r\n    .children[] | [.level2key] + (\r\n      .children[] | select(.level3key2 == &quot;level3value22&quot;) | [.level3key1] + (\r\n        .level3key3[] | [.level4key]\r\n      )\r\n    )\r\n  )\r\n  | with_entries(.key |= &quot;v\\(. + 1)&quot;)\r\n]\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;v1&quot;: &quot;level1value&quot;,\r\n    &quot;v2&quot;: &quot;level2value1&quot;,\r\n    &quot;v3&quot;: &quot;level3value1&quot;,\r\n    &quot;v4&quot;: &quot;level4value1&quot;\r\n  },\r\n  {\r\n    &quot;v1&quot;: &quot;level1value&quot;,\r\n    &quot;v2&quot;: &quot;level2value1&quot;,\r\n    &quot;v3&quot;: &quot;level3value2&quot;,\r\n    &quot;v4&quot;: &quot;level4value2&quot;\r\n  },\r\n  {\r\n    &quot;v1&quot;: &quot;level1value&quot;,\r\n    &quot;v2&quot;: &quot;level2value2&quot;,\r\n    &quot;v3&quot;: &quot;level3value3&quot;,\r\n    &quot;v4&quot;: &quot;level4value3&quot;\r\n  },\r\n  {\r\n    &quot;v1&quot;: &quot;level1value&quot;,\r\n    &quot;v2&quot;: &quot;level2value2&quot;,\r\n    &quot;v3&quot;: &quot;level3value4&quot;,\r\n    &quot;v4&quot;: &quot;level4value4&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/JTk_awvIt0)",
                "title": "jq flatten a deeply nested json document"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1638964240,
        "creation_date": 1638954045,
        "last_edit_date": 1638956621,
        "question_id": 70272321,
        "body_markdown": "Considering the following deeply nested json object\r\n\r\n```\r\n[\r\n    {\r\n        &quot;level1key&quot;: &quot;level1value&quot;,\r\n        &quot;children&quot;: [\r\n            {\r\n                &quot;level2key&quot;: &quot;level2value1&quot;,\r\n                &quot;children&quot;: [\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;ignored&quot;,\r\n                        &quot;level3key2&quot;: &quot;ignored&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;ignored&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;level3value1&quot;,\r\n                        &quot;level3key2&quot;: &quot;level3value22&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;level4value1&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;level3value2&quot;,\r\n                        &quot;level3key2&quot;: &quot;level3value22&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;level4value2&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;level2key&quot;: &quot;level2value2&quot;,\r\n                &quot;children&quot;: [\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;ignored&quot;,\r\n                        &quot;level3key2&quot;: &quot;ignored&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;ignored&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;level3value3&quot;,\r\n                        &quot;level3key2&quot;: &quot;level3value22&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;level4value3&quot;\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;level3key1&quot;: &quot;level3value4&quot;,\r\n                        &quot;level3key2&quot;: &quot;level3value22&quot;,\r\n                        &quot;level3key3&quot;: [\r\n                            {\r\n                                &quot;level4key&quot;: &quot;level4value4&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nI need to filter by &quot;level3value22&quot; at `.[0].children[].children[].level3key2` and flatten this deeply nested json object into an array. The expected result is the following. How should the jq sentence look like?\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;v1&quot;: &quot;level1value&quot;,\r\n        &quot;v2&quot;: &quot;level2value1&quot;,\r\n        &quot;v3&quot;: &quot;level3value1&quot;,\r\n        &quot;v4&quot;: &quot;level4value1&quot;\r\n    },\r\n    {\r\n        &quot;v1&quot;: &quot;level1value&quot;,\r\n        &quot;v2&quot;: &quot;level2value1&quot;,\r\n        &quot;v3&quot;: &quot;level3value2&quot;,\r\n        &quot;v4&quot;: &quot;level4value2&quot;\r\n    },\r\n    {\r\n        &quot;v1&quot;: &quot;level1value&quot;,\r\n        &quot;v2&quot;: &quot;level2value2&quot;,\r\n        &quot;v3&quot;: &quot;level3value3&quot;,\r\n        &quot;v4&quot;: &quot;level4value3&quot;\r\n    },\r\n    {\r\n        &quot;v1&quot;: &quot;level1value&quot;,\r\n        &quot;v2&quot;: &quot;level2value2&quot;,\r\n        &quot;v3&quot;: &quot;level3value4&quot;,\r\n        &quot;v4&quot;: &quot;level4value4&quot;\r\n    }\r\n]\r\n```\r\n\r\nThanks in advance!",
        "link": "https://stackoverflow.com/questions/70272321/jq-flatten-a-deeply-nested-json-document",
        "title": "jq flatten a deeply nested json document"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1638960730,
                "post_id": 70272694,
                "comment_id": 124224696,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638956223,
                "creation_date": 1638956223,
                "answer_id": 70272748,
                "question_id": 70272694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want `.packages |= . + [ { ... } ]`, which appends an element (well, an entire array, really), to the `packages` array, and not `.packages[3] |= { ... }`, which adds/merges some keys into the object at `.packages[3]`.",
                "title": "How to create new obj on JSON array without a replacement old one"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1638960284,
                "creation_date": 1638960284,
                "answer_id": 70273663,
                "question_id": 70272694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` the `.packages` field by redifining it as a new array consisting of the first three elements `.[:3]`, the new one `[{…}]` and the the rest `.[3:]`. Technically, we are constructing an array by piecing three arrays together `+`.\r\n```sh\r\njq &#39;.packages |= .[:3] + [{Group: &quot;group4&quot;, Name: &quot;name4&quot;, Version: &quot;1.0.0&quot;}] + .[3:]&#39;\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;json&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;packages&quot;: [\r\n    {\r\n      &quot;Group&quot;: &quot;group1&quot;,\r\n      &quot;Name&quot;: &quot;name1&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group2&quot;,\r\n      &quot;Name&quot;: &quot;name2&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group3&quot;,\r\n      &quot;Name&quot;: &quot;name3&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group4&quot;,\r\n      &quot;Name&quot;: &quot;name4&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group5&quot;,\r\n      &quot;Name&quot;: &quot;name5&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/pMNN2_5Nol)",
                "title": "How to create new obj on JSON array without a replacement old one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638996040,
                "last_edit_date": 1638996040,
                "creation_date": 1638974420,
                "answer_id": 70276826,
                "question_id": 70272694,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You desire to insert a record into an array such that it remains sorted. The best and easiest solution is simply to append the record than sort the array. This has the advantage that knowing the insert position isn&#39;t needed.\r\n\r\n```jq\r\n.packages |= (\r\n   . + [ { &quot;Group&quot;: &quot;group4&quot;, &quot;Name&quot;: &quot;name4&quot;, &quot;Version&quot;: &quot;1.0.0&quot; } ] |\r\n   sort_by( .Group )\r\n)\r\n```\r\n",
                "title": "How to create new obj on JSON array without a replacement old one"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1638996040,
        "creation_date": 1638955952,
        "last_edit_date": 1638978911,
        "question_id": 70272694,
        "body_markdown": "i have a JSON file\r\n\r\njs.json\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;json&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;packages&quot;: [\r\n    {\r\n      &quot;Group&quot;: &quot;group1&quot;,\r\n      &quot;Name&quot;: &quot;name1&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group2&quot;,\r\n      &quot;Name&quot;: &quot;name2&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group3&quot;,\r\n      &quot;Name&quot;: &quot;name3&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group5&quot;,\r\n      &quot;Name&quot;: &quot;name5&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIt has 4 elements in the .packages array. I want to add a fifth element &quot;group4&quot; to the array to get \r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;json&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;packages&quot;: [\r\n    {\r\n      &quot;Group&quot;: &quot;group1&quot;,\r\n      &quot;Name&quot;: &quot;name1&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group2&quot;,\r\n      &quot;Name&quot;: &quot;name2&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group3&quot;,\r\n      &quot;Name&quot;: &quot;name3&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group4&quot;,\r\n      &quot;Name&quot;: &quot;name4&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group5&quot;,\r\n      &quot;Name&quot;: &quot;name5&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nif i&#39;m use \r\n```\r\njq &#39;.packages[3] |= . + {&quot;Group&quot;:&quot;group4&quot;, &quot;Name&quot;:&quot;name4&quot;, &quot;Version&quot;:&quot;1.0.0&quot;}&#39; jq.json \r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;json&quot;,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;packages&quot;: [\r\n    {\r\n      &quot;Group&quot;: &quot;group1&quot;,\r\n      &quot;Name&quot;: &quot;name1&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group2&quot;,\r\n      &quot;Name&quot;: &quot;name2&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group3&quot;,\r\n      &quot;Name&quot;: &quot;name3&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    },\r\n    {\r\n      &quot;Group&quot;: &quot;group4&quot;,\r\n      &quot;Name&quot;: &quot;name4&quot;,\r\n      &quot;Version&quot;: &quot;1.0.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd i&#39;m lost group5 element. \r\nIs it possible to add an item without losing the previous one?\r\nI understand that I can save the output of lost indexes and insert them with the new index, but this seems wrong",
        "link": "https://stackoverflow.com/questions/70272694/how-to-create-new-obj-on-json-array-without-a-replacement-old-one",
        "title": "How to create new obj on JSON array without a replacement old one"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1638986073,
                "creation_date": 1638986073,
                "answer_id": 70279599,
                "question_id": 70278944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n```sh\r\njq --arg query &quot;FIND_ME&quot; &#39;\r\n  reduce ((paths | select(.[-1] == $query)) as $p | [$p, getpath($p)])\r\n    as $f ({}; setpath($f[0]; $f[1]))\r\n&#39; json_file\r\n```\r\n```json\r\n{\r\n  &quot;system&quot;: {\r\n    &quot;operating_system_1&quot;: {\r\n      &quot;FIND_ME&quot;: {\r\n        &quot;special_detail_1&quot;: &quot;some_detail&quot;,\r\n        &quot;special_detail_2&quot;: &quot;some_detail&quot;\r\n      }\r\n    },\r\n    &quot;operating_system_2&quot;: {\r\n      &quot;feature_1&quot;: {\r\n        &quot;FIND_ME&quot;: {\r\n          &quot;special_detail_3&quot;: &quot;some_detail&quot;,\r\n          &quot;special_detail_4&quot;: &quot;some_detail&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/Bd1ILkBFPm)",
                "title": "Find nested JSON objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638986073,
        "creation_date": 1638982977,
        "question_id": 70278944,
        "body_markdown": "Is there a way to find the location, and values, of specific objects in heavily-nested JSON files, using jq?\r\n\r\nI never know where they are going to occur in the structure of the JSON, and I never know the names of the parents. I just know the name of the object I&#39;m searching for.\r\n\r\nFor example, I&#39;m trying to find where the &quot;FIND_ME&quot; objects are in the following JSON, in relation to the JSON structure as a whole, but also the values contained in &quot;FIND_ME&quot;. So for this JSON:\r\n\r\n    {\r\n        &quot;system&quot;: {\r\n            &quot;operating_system_1&quot;: {\r\n                &quot;FIND_ME&quot;: {\r\n                    &quot;special_detail_1&quot;: &quot;some_detail&quot;,\r\n                    &quot;special_detail_2&quot;: &quot;some_detail&quot;\r\n                },\r\n                &quot;feature_1&quot;: {\r\n                    &quot;detail_1&quot;: &quot;some_detail&quot;\r\n                },\r\n                &quot;feature_2&quot;: {\r\n                    &quot;detail_2&quot;: &quot;some_detail&quot;\r\n                }\r\n            },\r\n            &quot;operating_system_2&quot;: {\r\n                &quot;feature_1&quot;: {\r\n                    &quot;FIND_ME&quot;: {\r\n                        &quot;special_detail_3&quot;: &quot;some_detail&quot;,\r\n                        &quot;special_detail_4&quot;: &quot;some_detail&quot;\r\n                    },\r\n                    &quot;detail_3&quot;: &quot;some_detail&quot;\r\n                },\r\n                &quot;feature_2&quot;: {\r\n                    &quot;detail_4&quot;: &quot;some_detail&quot;\r\n                }\r\n            },\r\n            &quot;operating_system_3&quot;: {\r\n                &quot;feature_1&quot;: {\r\n                    &quot;detail_5&quot;: &quot;some_detail&quot;\r\n                },\r\n                &quot;feature_2&quot;: {\r\n                    &quot;detail_6&quot;: &quot;some_detail&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\nI&#39;d ideally get the following output:\r\n\r\n    {\r\n        &quot;system&quot;: {\r\n            &quot;operating_system_1&quot;: {\r\n                &quot;FIND_ME&quot;: {\r\n                    &quot;special_detail_1&quot;: &quot;some_detail&quot;,\r\n                    &quot;special_detail_2&quot;: &quot;some_detail&quot;\r\n                }\r\n            },\r\n            &quot;operating_system_2&quot;: {\r\n                &quot;feature_1&quot;: {\r\n                    &quot;FIND_ME&quot;: {\r\n                        &quot;special_detail_3&quot;: &quot;some_detail&quot;,\r\n                        &quot;special_detail_4&quot;: &quot;some_detail&quot;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\nThis is so I can check numerous files to make sure &quot;FIND_ME&quot; isn&#39;t appearing somewhere it shouldn&#39;t be, causing errors.\r\nI&#39;ve tried the following from other questions:\r\n\r\n    cat json_file | jq &#39;..|.FIND_ME? | select(. != null)&#39;\r\n\r\nWhich gives the values of &quot;FIND_ME&quot;, like this\r\n\r\n    {\r\n      &quot;special_detail_1&quot;: &quot;some_detail&quot;,\r\n      &quot;special_detail_2&quot;: &quot;some_detail&quot;\r\n    }\r\n    {\r\n      &quot;special_detail_3&quot;: &quot;some_detail&quot;,\r\n      &quot;special_detail_4&quot;: &quot;some_detail&quot;\r\n    }\r\n\r\nbut it doesn&#39;t display the parent structure.",
        "link": "https://stackoverflow.com/questions/70278944/find-nested-json-objects-using-jq",
        "title": "Find nested JSON objects using jq"
    },
    {
        "tags": [
            "c++",
            "jq",
            "popen"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7195349,
                    "reputation": 37457,
                    "user_id": 5494370,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10152989584621642/picture?type=large",
                    "display_name": "Alan Birtles",
                    "link": "https://stackoverflow.com/users/5494370/alan-birtles"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639035808,
                "post_id": 70286089,
                "comment_id": 124246719,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23596035,
                    "reputation": 45,
                    "user_id": 17633125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/884e007708059ec801b63d14601cb320?s=256&d=identicon&r=PG",
                    "display_name": "Betheev",
                    "link": "https://stackoverflow.com/users/17633125/betheev"
                },
                "reply_to_user": {
                    "account_id": 7195349,
                    "reputation": 37457,
                    "user_id": 5494370,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10152989584621642/picture?type=large",
                    "display_name": "Alan Birtles",
                    "link": "https://stackoverflow.com/users/5494370/alan-birtles"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639036193,
                "post_id": 70286089,
                "comment_id": 124246844,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639039517,
                "post_id": 70286089,
                "comment_id": 124247966,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23596035,
                    "reputation": 45,
                    "user_id": 17633125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/884e007708059ec801b63d14601cb320?s=256&d=identicon&r=PG",
                    "display_name": "Betheev",
                    "link": "https://stackoverflow.com/users/17633125/betheev"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639040514,
                "post_id": 70286089,
                "comment_id": 124248284,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639040710,
                "post_id": 70286089,
                "comment_id": 124248351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23596035,
                    "reputation": 45,
                    "user_id": 17633125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/884e007708059ec801b63d14601cb320?s=256&d=identicon&r=PG",
                    "display_name": "Betheev",
                    "link": "https://stackoverflow.com/users/17633125/betheev"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639046356,
                "post_id": 70286089,
                "comment_id": 124250525,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639047080,
                "post_id": 70286089,
                "comment_id": 124250782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23596035,
                    "reputation": 45,
                    "user_id": 17633125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/884e007708059ec801b63d14601cb320?s=256&d=identicon&r=PG",
                    "display_name": "Betheev",
                    "link": "https://stackoverflow.com/users/17633125/betheev"
                },
                "reply_to_user": {
                    "account_id": 3379153,
                    "reputation": 209476,
                    "user_id": 2836621,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/suHg4.jpg?s=256",
                    "display_name": "Mark Setchell",
                    "link": "https://stackoverflow.com/users/2836621/mark-setchell"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639050487,
                "post_id": 70286089,
                "comment_id": 124251962,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23596035,
                    "reputation": 45,
                    "user_id": 17633125,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/884e007708059ec801b63d14601cb320?s=256&d=identicon&r=PG",
                    "display_name": "Betheev",
                    "link": "https://stackoverflow.com/users/17633125/betheev"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639055739,
                "post_id": 70286089,
                "comment_id": 124254005,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1639034826,
        "creation_date": 1639034826,
        "question_id": 70286089,
        "body_markdown": "I am trying to use popen and jq on a Linux machine to validate json data in some unit tests but, for some reason, it does not work, i.e., jq&#39;s exit code is not zero. Here is a MWE:\r\n```\r\n#include &quot;stdio.h&quot;\r\n#include &lt;string&gt;\r\n#include &lt;sstream&gt;\r\n\r\nint main()\r\n{\r\n        std::string command = &quot;echo {} | jq&quot;;\r\n        FILE* pipe = popen(command.c_str(), &quot;r&quot;);\r\n        if (!pipe) return -1;\r\n        char buffer[1024];\r\n        std::stringstream ss;\r\n        while(!feof(pipe)) if(fgets(buffer, 1024, pipe) != NULL) ss &lt;&lt; buffer;\r\n        int exitCode = WEXITSTATUS(pclose(pipe));\r\n        printf(&quot;Exit code: %d\\nOutput: %s\\n&quot;, exitCode, ss.str().c_str());\r\n}\r\n```\r\n\r\nHowever, if I replace &#39;jq&#39; with (for example) &#39;head -1&#39;, the code works as expected. Am I doing something wrong or is there a bug in popen or jq?",
        "link": "https://stackoverflow.com/questions/70286089/how-to-use-jq-with-popen-to-validate-json-data",
        "title": "How to use jq with popen to validate json data"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639054797,
                "post_id": 70290271,
                "comment_id": 124253634,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6162379,
                    "reputation": 587,
                    "user_id": 4803521,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://lh4.googleusercontent.com/-blTqxKURCEM/AAAAAAAAAAI/AAAAAAAAAvM/YrjhImfL46s/s256-rj/photo.jpg",
                    "display_name": "Bhuneshwer",
                    "link": "https://stackoverflow.com/users/4803521/bhuneshwer"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639054897,
                "post_id": 70290271,
                "comment_id": 124253675,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user9706"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639055158,
                "post_id": 70290271,
                "comment_id": 124253774,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639055180,
                "post_id": 70290271,
                "comment_id": 124253780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639060785,
                "creation_date": 1639060785,
                "answer_id": 70291782,
                "question_id": 70290271,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Shell is not the tool for this job. Python, et. al., are better suited for the task. To run this you *really* need to trust that nobody is going to put malicious code in your input. I would not run this code in production as I&#39;ve written it because its security is sketchy and it is brittle, meaning you still need to know ahead of time what the vars are going to be named.  At that point you might as well have pre-processed you json input in a separate script and passed just the values you want into your script. Notice that `jq` expects valid json so your quotes have to reversed.\r\n\r\n    #!/bin/sh\r\n    #\r\n    #\r\n    me=&quot;$( basename &quot;${0}&quot; )&quot;\r\n    \r\n    tmp=&quot;$( mktemp &quot;${me}.XXXXXXXX&quot; )&quot; || exit 1\r\n    trap &quot;rm -f -- &#39;${tmp}&#39;&quot; EXIT\r\n        \r\n    echo &quot;$3&quot; | jq -j &#39;.[]|(.ParamName, &quot;=\\&quot;&quot;, .ParamVal, &quot;\\&quot;\\n&quot;)&#39; &gt; &quot;${tmp}&quot;\r\n    \r\n    . &quot;${tmp}&quot;\r\n    \r\n    echo &quot;\\$1: $1&quot;\r\n    echo &quot;\\$2: $2&quot;\r\n    echo &quot;\\$3: $3&quot;\r\n    echo &quot;\\$HostName: $HostName&quot;\r\n    echo &quot;\\$TargetMachine: $TargetMachine&quot;\r\n\r\nReturns:\r\n\r\n    $ ./readinp.sh hello world &#39;[{&quot;ParamName&quot;:&quot;HostName&quot;,&quot;ParamVal&quot;:&quot;Host1&quot;},{&quot;ParamName&quot;:&quot;TargetMachine&quot;,&quot;ParamVal&quot;:&quot;Machine1&quot;}]&#39;\r\n    $1: hello\r\n    $2: world\r\n    $3: [{&quot;ParamName&quot;:&quot;HostName&quot;,&quot;ParamVal&quot;:&quot;Host1&quot;},{&quot;ParamName&quot;:&quot;TargetMachine&quot;,&quot;ParamVal&quot;:&quot;Machine1&quot;}]\r\n    $HostName: Host1\r\n    $TargetMachine: Machine1\r\n\r\nSlightly better with preprocessing but still brittle. This I might use like in a trivial science project I&#39;m working off the side of my desk, like a homework question where the code isn&#39;t going to be graded, but not in production:\r\n\r\n    $ cat ./preinp.sh                    \r\n    #!/bin/sh\r\n\r\n    echo &quot;&#39;${1}&#39;&quot; &quot;&#39;${2}&#39;&quot;\r\n    echo &quot;${3}&quot; | jq &#39;.[]|(.ParamVal)&#39;\r\n\r\nAnd:\r\n\r\n    $ cat ./readinp.sh                    \r\n    #!/bin/sh\r\n\r\n    p1=&quot;$1&quot;\r\n    p2=&quot;$2&quot;\r\n    HostName=&quot;$3&quot;\r\n    TargetMachine=&quot;$4&quot;\r\n\r\n    echo &quot;\\$p1: $p1&quot;\r\n    echo &quot;\\$p2: $p2&quot;\r\n    echo &quot;\\$HostName: $HostName&quot;\r\n    echo &quot;\\$TargetMachine: $TargetMachine&quot;\r\n\r\nResults in:\r\n\r\n    $ ./preinp.sh &#39;single-word&#39; &#39;with a space&#39; &#39;[{&quot;ParamName&quot;:&quot;HostName&quot;,&quot;ParamVal&quot;:&quot;Host1&quot;},{&quot;ParamName&quot;:&quot;TargetMachine&quot;,&quot;ParamVal&quot;:&quot;Machine1&quot;}]&#39; | xargs ./readinp.sh\r\n    $p1: single-word\r\n    $p2: with a space\r\n    $HostName: Host1\r\n    $TargetMachine: Machine1\r\n\r\nFinal advice - don&#39;t do this. ",
                "title": "Shell Script : Read JSON String Input Param"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639060785,
        "creation_date": 1639054502,
        "last_edit_date": 1639054932,
        "question_id": 70290271,
        "body_markdown": "I have one shell script which accepts 3 arguments where 1st and 2nd are strings and 3rd is JSON enclosed within the double quote. Below is the snippet for shell script and args sample:\r\n\r\nFile readinp.sh\r\n\r\n    param1=$1\r\n    param2=$2\r\n    param3=$3\r\n\r\n    echo &quot;Param1 is $param1&quot;\r\n\r\n    echo &quot;Param2 is $param2&quot;\r\n\r\n    echo &quot;Param3 is $param3&quot;\r\n\r\nScript execution :\r\n```\r\n./readinp.sh hello world &quot;[{&#39;ParamName&#39;:&#39;HostName&#39;,&#39;ParamVal&#39;:&#39;Host1&#39;},{&#39;ParamName&#39;:&#39;TargetMachine&#39;,&#39;ParamVal&#39;:&#39;Machine1&#39;}]&quot;\r\n```\r\n\r\nHow will I access the 3rd argument values as JSON inside my shell script? Please help me. \r\n\r\nThanks in advance\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70290271/shell-script-read-json-string-input-param",
        "title": "Shell Script : Read JSON String Input Param"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639064062,
                "last_edit_date": 1639064062,
                "creation_date": 1639062218,
                "answer_id": 70292104,
                "question_id": 70292076,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `flatten`:\r\n\r\n```\r\nmap(.items) | flatten\r\n```\r\n&lt;sup&gt;[Demo][1]&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\n\r\nOr, `map()` the `items` instantly\r\n```\r\nmap(.items[])\r\n```\r\n&lt;sup&gt;[Demo](https://jqplay.org/s/1vCNnTcwdy)&lt;/sup&gt;\r\n\r\n\r\n----------\r\n\r\nOr one of the many other options like:\r\n\r\n* [`[ .[].items ] | add`][2]\r\n* [`[ .. | scalars ]`][3]\r\n* [`[ .[][][] ]`][4]\r\n\r\n\r\n\r\n----------\r\n\r\n\r\nAll of those commands will produce:\r\n```json\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  3,\r\n  4,\r\n  8,\r\n  9\r\n]\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/LHSIC65et7\r\n  [2]: https://jqplay.org/s/L2c2JddSKN\r\n  [3]: https://jqplay.org/s/47WzsXLSSZ\r\n  [4]: https://jqplay.org/s/_fXjbnj0e7",
                "title": "How to concatenate sibling arrays using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639064586,
                "creation_date": 1639064586,
                "answer_id": 70292700,
                "question_id": 70292076,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many ways to construct the array in this particular class of cases would be:\r\n\r\n    [.[][][]]\r\n\r\nThis has the advantage of brevity and not using\r\n`flatten`, which should only be used with a full understanding of its semantics.\r\n\r\nHowever, since the ultimate goal is to count the elements, it might be better to avoid constructing the array altogether, e.g. by using\r\n\r\n    def add(s): reduce s as $x (null; .+$x);\r\n\r\nNow you have another range of options, e.g.\r\n\r\n    add(..|objects|.items|length)\r\n\r\n\r\n\r\n    ",
                "title": "How to concatenate sibling arrays using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639068667,
        "creation_date": 1639062110,
        "last_edit_date": 1639068667,
        "question_id": 70292076,
        "body_markdown": "Given a JSON like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;items&quot;: [1, 2, 3]\r\n  },\r\n  {\r\n    &quot;items&quot;: [3, 4]\r\n  },\r\n  {\r\n    &quot;items&quot;: [8, 9]\r\n  }\r\n]\r\n```\r\n\r\nhow do you concatenate `items` with JQ into a single array like:\r\n\r\n\r\n```json\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  3,\r\n  4,\r\n  8,\r\n  9\r\n]\r\n```\r\n\r\nA playground with this example: https://jqplay.org/s/r1RvAir27V\r\n\r\nI need it to calc the length of all the arrays.\r\n",
        "link": "https://stackoverflow.com/questions/70292076/how-to-concatenate-sibling-arrays-using-jq",
        "title": "How to concatenate sibling arrays using jq?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639065330,
                "creation_date": 1639065330,
                "answer_id": 70292894,
                "question_id": 70292476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .[]| ([.key1,.key2] + (.key3[]|[.])) | @csv",
                "title": "Convert json to long format table using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639065330,
        "creation_date": 1639063546,
        "question_id": 70292476,
        "body_markdown": "Given an array of JSON objects, all having the same key names (key1, key2, key3) and just one key (key3) whose value is an array, how can it be converted to a long format table?\r\n\r\n**Input:**\r\n```\r\n[\r\n  { &quot;key1&quot;: &quot;A&quot;,\r\n    &quot;key2&quot;: 1,\r\n    &quot;key3&quot; : [&quot;aaa&quot;, &quot;bbb&quot;]\r\n  },\r\n  { &quot;key1&quot;: &quot;B&quot;,\r\n    &quot;key2&quot;: 2,\r\n    &quot;key3&quot; : [&quot;ccc&quot;, &quot;ddd&quot;]\r\n  }\r\n]\r\n```\r\n\r\n**Desired output:**\r\n\r\nkey1 | key2 | key3\r\n---- | ---- | ----\r\nA    | 1    | aaa\r\nA    | 1    | bbb\r\nB    | 2    | ccc\r\nB    | 2    | ddd",
        "link": "https://stackoverflow.com/questions/70292476/convert-json-to-long-format-table-using-jq",
        "title": "Convert json to long format table using jq"
    },
    {
        "tags": [
            "kubernetes",
            "jenkins-pipeline",
            "jq",
            "kubectl",
            "jenkins-groovy"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 23128,
                    "reputation": 14060,
                    "user_id": 57719,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/m2xJ2.png?s=256",
                    "display_name": "Chin Huang",
                    "link": "https://stackoverflow.com/users/57719/chin-huang"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639069059,
                "post_id": 70293450,
                "comment_id": 124259975,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639131831,
                "last_edit_date": 1639131831,
                "creation_date": 1639070131,
                "answer_id": 70294019,
                "question_id": 70293450,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `&quot;&quot;&quot;` syntax is for multiline-interpolated Groovy strings. This is not what you want in either of the usage above. We can use a single line literal string `&#39;` and a multiline literal string instead:\r\n\r\n    docker.withRegistry(&#39;https://&#39; + dockerRegistry, dockerCredentialsId) {\r\n      docker.image(kubectlImage).inside(&#39;--entrypoint=&quot;&quot;&#39;){\r\n        sh &#39;&#39;&#39;\r\n        #!/bin/sh\r\n        set +x\r\n        kubectl get pods -n ${namespace}  -o json &gt; $WORKSPACE/pods.json\r\n        podIP=$(jq -r &quot;.items[] | select(.metadata.generateName | test($appName)).status.podIP&quot; $WORKSPACE/pods.json}\r\n        echo &quot;Pod IP:$podIP&quot;\r\n        &#39;&#39;&#39;\r\n      }\r\n    }\r\n\r\nSince `WORKSPACE` is a pipeline environment variable exported to the shell interpreter, it is fine as is. If you had used the interpolated syntax, it would need to have been accessed in the `env` object i.e. `env.WORKSPACE`.\r\n\r\nThe definition for `appName` is not shown in the question, so if that does not resolve as expected, then the question will need to be updated accordingly.",
                "title": "Jenkins pipeline shared library failed to retrieve pod IP"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639131831,
        "creation_date": 1639067686,
        "question_id": 70293450,
        "body_markdown": "I have created a Jenkins pipeline shared library to retrieve a pod IP connecting to a kubernetes cluster which fails throwing an error below. Any pointers for fixing this would be great:\r\n\r\nJSL:\r\n```\r\ndocker.withRegistry(&#39;https://&#39; + dockerRegistry, dockerCredentialsId) {\r\n    docker.image(kubectlImage).inside(&quot;&quot;&quot;--entrypoint=&#39;&#39;&quot;&quot;&quot;){\r\n      sh &quot;&quot;&quot;\r\n      #!/bin/sh\r\n      set +x\r\n      kubectl get pods -n ${namespace}  -o json &gt; $WORKSPACE/pods.json\r\n      podIP=$(jq -r &#39;.items[] | select(.metadata.generateName | test(\\&quot;${appName}\\&quot;)).status.podIP&#39; $WORKSPACE/pods.json}\r\n      echo &quot;Pod IP:$podIP&quot;\r\n      &quot;&quot;&quot;\r\n    }\r\n  }\r\n```\r\n\r\nError during the pipeline execution -\r\n```\r\n70: illegal string body character after dollar sign;\r\n16:18:23     solution: either escape a literal dollar sign &quot;\\$5&quot; or bracket the value expression &quot;${5}&quot; @ line 70, column 14.\r\n16:18:23           podIP=$(jq -r &#39;.items[] | select(.metadata.generateName | test(\\&quot;${appName}\\&quot;)).status.podIP&#39; $WORKSPACE/pods.json)\r\n16:18:23                  ^\r\n16:18:23  \r\n16:18:23  1 error\r\n16:18:23  \r\n16:18:23  \tat org.codehaus.groovy.control.ErrorCollector.failIfErrors(ErrorCollector.java:310)\r\n16:18:23  \tat org.codehaus.groovy.control.ErrorCollector.addFatalError(ErrorCollector.java:150)\r\n16:18:23  \tat org.codehaus.groovy.control.ErrorCollector.addError(ErrorCollector.java:120)\r\n16:18:23  \tat org.codehaus.groovy.control.ErrorCollector.addError(ErrorCollector.java:132)\r\n```",
        "link": "https://stackoverflow.com/questions/70293450/jenkins-pipeline-shared-library-failed-to-retrieve-pod-ip",
        "title": "Jenkins pipeline shared library failed to retrieve pod IP"
    },
    {
        "tags": [
            "json",
            "jq",
            "reshape"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639076106,
                "creation_date": 1639076106,
                "answer_id": 70295262,
                "question_id": 70295210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to put values in an array :\r\n\r\n```\r\njq &#39;.first[].second | {id: .id, prop: [.third[].value]}&#39;\r\n```",
                "title": "JQ reshape nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639076267,
                "creation_date": 1639076267,
                "answer_id": 70295292,
                "question_id": 70295210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `map` builtin to transform the array into just `.value`s:\r\n```sh\r\njq &#39;.first[].second | {id: .id, prop: .third | map(.value)}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;prop&quot;: [\r\n    &quot;aa&quot;,\r\n    &quot;bb&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/td594KsXmj)",
                "title": "JQ reshape nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1639126477,
        "creation_date": 1639075862,
        "last_edit_date": 1639126477,
        "question_id": 70295210,
        "body_markdown": "I have an issue with jq and nested arrays, I cannot get why it is creating multiple objects:\r\n\r\n```\r\necho &#39;{\r\n    &quot;first&quot;: [\r\n        {\r\n            &quot;second&quot;: {\r\n                &quot;id&quot;: 1,\r\n                &quot;third&quot;: [\r\n                    {\r\n                        &quot;value&quot;: &quot;aa&quot;\r\n                    },\r\n                    {\r\n                        &quot;value&quot;: &quot;bb&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}&#39; | jq &#39;.first[].second | {id: .id, prop: .third[].value}&#39;\r\n```\r\n\r\nThis is returning:\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;prop&quot;: &quot;aa&quot;\r\n}\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;prop&quot;: &quot;bb&quot;\r\n}\r\n```\r\nBut I would like to have:\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;prop&quot;: [&quot;aa&quot;, &quot;bb&quot;]\r\n}\r\n```\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/70295210/jq-reshape-nested-array",
        "title": "JQ reshape nested array"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv",
            "aws-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639090975,
                "creation_date": 1639090975,
                "answer_id": 70297820,
                "question_id": 70297189,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider:\r\n```\r\n.[] | (.Tags[] | select(.Key==&quot;Name&quot;).Value) + &quot;, &quot; + .State.Name\r\n```",
                "title": "Selecting multiple values from different nested objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639102758,
        "creation_date": 1639086834,
        "last_edit_date": 1639102758,
        "question_id": 70297189,
        "body_markdown": "I&#39;m working with the AWS cli and I&#39;d like to be able to query instances to get their name and their state. Example:\r\n\r\n```\r\ninstance 1, running\r\ninstance 2, stopped\r\n```\r\n\r\nI can get the instance name and state with this query\r\n\r\n`aws ec2 describe-instances --output json --filters Name=tag:Name,Values=*&quot;instance &quot;* --query &quot;Reservations[].Instances[]&quot; | jq &quot;.[] | .Tags, .State.Name&quot;`\r\n\r\nHowever, that gives me an array of objects and a single value. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;Key&quot;: &quot;Name&quot;,\r\n    &quot;Value&quot;: &quot;instance 1&quot;\r\n  },\r\n  {\r\n    &quot;Key&quot;: &quot;VPC&quot;,\r\n    &quot;Value&quot;: &quot;the vpc&quot;\r\n  },\r\n  {\r\n    &quot;Key&quot;: &quot;ami_backup&quot;,\r\n    &quot;Value&quot;: &quot;false&quot;\r\n  },\r\n  ...\r\n]\r\n&quot;running&quot;\r\n```\r\n\r\nAlmost there. How can I combine each object&#39;s Value with the state string so that I can then filter object to only get the one where `Key==Name`?\r\n\r\nI tried using `map` but couldn&#39;t come up with a valid syntax.",
        "link": "https://stackoverflow.com/questions/70297189/selecting-multiple-values-from-different-nested-objects-using-jq",
        "title": "Selecting multiple values from different nested objects using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639292913,
                "post_id": 70302009,
                "comment_id": 124308571,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 24,
                "is_accepted": false,
                "score": 24,
                "last_activity_date": 1639127632,
                "creation_date": 1639127632,
                "answer_id": 70302131,
                "question_id": 70302009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map` instead of `.[]` to retain the array:\r\n```\r\nmap(select(any(.attributes; .enabled)) | {id})\r\n```\r\n```json\r\n[\r\n  {&quot;id&quot;: &quot;https://kjkljk./secrets/-/1&quot;},\r\n  {&quot;id&quot;: &quot;https://kjklj./secrets/-/2&quot;}\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/rdzVB96ze7)\r\n\r\nNote that this produces an array of objects `[{…},{…}]`, what I believe is what you asked for although in your desired output you are missing the curly object braces `{` `}`. To make an &quot;array of strigs&quot; instead, use `.id` instead of `{id}` like so\r\n```\r\nmap(select(any(.attributes; .enabled)) | .id)\r\n```\r\n```json\r\n[\r\n  &quot;https://kjkljk./secrets/-/1&quot;,\r\n  &quot;https://kjklj./secrets/-/2&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/LlmNqV15FG)\r\n\r\n(Also, you can use `.enabled` instead of `.enabled == true`)",
                "title": "JQ map objects to array with condition"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639127677,
                "creation_date": 1639127677,
                "answer_id": 70302139,
                "question_id": 70302009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n\r\n    map(select(any(.attributes; .enabled == true)) | .id)\r\n\r\nExplanation: Rather than splitting the array with `.[]`, the `map()` function leaves the array structure intact but operates on the elements. Using `.id` rather than `{id}` avoids creating a dictionary for each selected value.\r\n\r\nIf I understand right, you could also replace `any(.attributes; .enabled == true)` with just `.attributes.enabled == true`.",
                "title": "JQ map objects to array with condition"
            },
            {
                "up_vote_count": 11,
                "is_accepted": false,
                "score": 11,
                "last_activity_date": 1639127737,
                "creation_date": 1639127737,
                "answer_id": 70302155,
                "question_id": 70302009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like:\r\n\r\n```sh\r\n$ jq &#39;[.[] | select(.attributes.enabled) | .id]&#39; input.json\r\n[\r\n  &quot;https://kjkljk./secrets/-/1&quot;,\r\n  &quot;https://kjklj./secrets/-/2&quot;\r\n]\r\n```",
                "title": "JQ map objects to array with condition"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1651822205,
                "creation_date": 1651822205,
                "answer_id": 72137688,
                "question_id": 70302009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like already written in the answers, comments before, your wished output is not valid json.\r\n\r\nSo you have to options. I pasted your input file in `SO-70302009.json`\r\n\r\n 1. Wrap the id line as objects `jq &#39;map({id: select(any(.attributes; .enabled)) | .id})&#39; &quot;./SO-70302009.json&quot;`\r\nto get\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;https://kjkljk./secrets/-/1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;https://kjklj./secrets/-/2&quot;\r\n  }\r\n]\r\n```\r\n\r\n 2. Make an array of ids `jq &#39;{ ids: map(select(any(.attributes; .enabled)) | .id) }&#39;\r\n    &quot;./SO-70302009.json&quot;`\r\nto get\r\n\r\n```json\r\n{\r\n  &quot;ids&quot;: [\r\n    &quot;https://kjkljk./secrets/-/1&quot;,\r\n    &quot;https://kjklj./secrets/-/2&quot;\r\n  ]\r\n}\r\n```\r\n\r\n",
                "title": "JQ map objects to array with condition"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 15,
        "last_activity_date": 1686748967,
        "creation_date": 1639126976,
        "last_edit_date": 1686748967,
        "question_id": 70302009,
        "body_markdown": "I have this input data:\r\n\r\n    [\r\n      {\r\n        &quot;attributes&quot;: {\r\n          &quot;created&quot;: &quot;2021-10-18T12:02:39+00:00&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;expires&quot;: null,\r\n          &quot;notBefore&quot;: null\r\n        },\r\n        &quot;contentType&quot;: null,\r\n        &quot;id&quot;: &quot;https://kjkljk./secrets/-/1&quot;,\r\n        &quot;managed&quot;: null,\r\n        &quot;name&quot;: &quot;pw&quot;,\r\n        &quot;tags&quot;: {}\r\n      },\r\n      {\r\n        &quot;attributes&quot;: {\r\n          &quot;created&quot;: &quot;2021-10-18T12:06:16+00:00&quot;,\r\n          &quot;enabled&quot;: true,\r\n          &quot;expires&quot;: null,\r\n          &quot;notBefore&quot;: null\r\n        },\r\n        &quot;contentType&quot;: &quot;&quot;,\r\n        &quot;id&quot;: &quot;https://kjklj./secrets/-/2&quot;,\r\n        &quot;managed&quot;: null,\r\n        &quot;name&quot;: &quot;pw&quot;,\r\n        &quot;tags&quot;: {}\r\n      }\r\n    ]\r\n\r\nI need to use jq to extract the id values into a new array where enabled is set to true.  this is what I have so far:\r\n\r\n    .[] | select(any(.attributes; .enabled== true)) | {id} \r\n\r\nbut it only results in this:\r\n\r\n    {\r\n      &quot;id&quot;: &quot;https://kjkljk./secrets/-/1&quot;\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;https://kjklj./secrets/-/2&quot;\r\n    }\r\n\r\nhow can i make these two objects into an array of strings instead?\r\n\r\n    [\r\n      &quot;id&quot;: &quot;https://kjkljk./secrets/-/1&quot;,\r\n      &quot;id&quot;: &quot;https://kjklj./secrets/-/2&quot;\r\n    ]\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70302009/jq-map-objects-to-array-with-condition",
        "title": "JQ map objects to array with condition"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639135281,
                "creation_date": 1639135281,
                "answer_id": 70303753,
                "question_id": 70303524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about\r\n\r\n    .clusters[] |  select(.nodes[].node == &quot;bb1-2&quot;).name\r\n\r\nTry it:\r\n[JQ play][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/Rp2KzSe1we",
                "title": "How to print a value using json several levels above?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639138867,
                "creation_date": 1639138867,
                "answer_id": 70304426,
                "question_id": 70303524,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In addition to the other approaches, a very general way to hold on to higher level context is to bind it to a variable.\r\n\r\n```\r\njq &#39;\r\n    .clusters[] |\r\n    . as $cluster |\r\n    .nodes[] |\r\n    select(.node == &quot;bb1-2&quot;) |\r\n    {cluster_name:$cluster.name, node:.}\r\n&#39;\r\n```\r\n```\r\n{\r\n  &quot;cluster_name&quot;: &quot;BB1&quot;,\r\n  &quot;node&quot;: {\r\n    &quot;gpu&quot;: {\r\n      &quot;P40&quot;: 2\r\n    },\r\n    &quot;node&quot;: &quot;bb1-2&quot;,\r\n    &quot;role&quot;: &quot;master&quot;\r\n  }\r\n}\r\n```\r\nThis makes sure you know _both_ the cluster _and_ the matching node itself, and avoids the confusion that arises if your `select` condition matches the same cluster more than once.",
                "title": "How to print a value using json several levels above?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639643216,
        "creation_date": 1639134210,
        "last_edit_date": 1639643216,
        "question_id": 70303524,
        "body_markdown": "Given a json such as:\r\n\r\n    {\r\n    &quot;clusters&quot;: [\r\n      {\r\n          &quot;domain&quot;: &quot;crap1&quot;,\r\n          &quot;name&quot;: &quot;BB1&quot;,\r\n          &quot;nodes&quot;: [\r\n            {\r\n                &quot;gpu&quot;: null,\r\n                &quot;node&quot;: &quot;bb1-1&quot;,\r\n                &quot;role&quot;: &quot;worker&quot;\r\n            },\r\n            {\r\n                &quot;gpu&quot;: {\r\n                    &quot;P40&quot;: 2\r\n                },\r\n                &quot;node&quot;: &quot;bb1-2&quot;,\r\n                &quot;role&quot;: &quot;master&quot;\r\n            }\r\n       ],\r\n       &quot;site&quot;: &quot;B-place&quot;,\r\n       &quot;hardware&quot;: &quot;prod-2&quot;,\r\n       &quot;timezone&quot;: &quot;US/Eastern&quot;,\r\n       &quot;type&quot;: &quot;CCE&quot;,\r\n       &quot;subtype&quot;: null\r\n      }\r\n      ]\r\n    }\r\n\r\n\r\nwhere there are actually many more clusters, I want to see if I can parse the json searching for node bb1-2, for example, and print out the cluster name it belongs to BB1?\r\nI know I can search for that node with:\r\n\r\n    .clusters[] | .nodes[] | select(.node == &quot;bb1-2&quot;)\r\n\r\nbut can&#39;t figure out how to code it to print out a value at a higher level?",
        "link": "https://stackoverflow.com/questions/70303524/how-to-print-a-value-using-json-several-levels-above",
        "title": "How to print a value using json several levels above?"
    },
    {
        "tags": [
            "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": 1639145530,
                "post_id": 70305744,
                "comment_id": 124280511,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 225921,
                    "reputation": 863,
                    "user_id": 486670,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f9ae30fae8a36dc3827269b98b6a6a51?s=256&d=identicon&r=PG",
                    "display_name": "keeer",
                    "link": "https://stackoverflow.com/users/486670/keeer"
                },
                "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": 1639145888,
                "post_id": 70305744,
                "comment_id": 124280645,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639145595,
                "creation_date": 1639145595,
                "answer_id": 70305801,
                "question_id": 70305744,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--slurp` the input to get an array and then use `group_by` to make groups (arrays) according to any criteria (`.name` in your case). If you want just one for each name, take one (e.g. the `first`) of each such group. Finally, apply `[]` to disassemble the surrounding array.\r\n\r\n```sh\r\njq --slurp &#39;group_by(.name) | map(first)[]&#39; \r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;db1&quot;,\r\n  &quot;size&quot;: 40000,\r\n  &quot;items&quot;: 500,\r\n  &quot;mutations&quot;: 2,\r\n  &quot;tombstones&quot;: 4,\r\n  &quot;views_count&quot;: 8,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 0,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;db2&quot;,\r\n  &quot;size&quot;: 11,\r\n  &quot;items&quot;: 900,\r\n  &quot;mutations&quot;: 3,\r\n  &quot;tombstones&quot;: 0,\r\n  &quot;views_count&quot;: 0,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 0,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/9jKvjoMaJ5)\r\n\r\nNote: With a little bit of more effort, you could also `--stream` (and then `reduce`) the input (instead of using `--slurp`) but 18000 lines isn&#39;t that big for memories nowadays, so I thought this would be the more reasonable approach.",
                "title": "Adding multiple values in multiple entries via jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639145595,
        "creation_date": 1639145299,
        "question_id": 70305744,
        "body_markdown": "Suppose I have some json formatted something like this (I&#39;ve removed the bits I&#39;m not interested in, I can filter those out):\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;db1&quot;,\r\n  &quot;size&quot;: 40000,\r\n  &quot;items&quot;: 500,\r\n  &quot;mutations&quot;: 2,\r\n  &quot;tombstones&quot;: 4,\r\n  &quot;views_count&quot;: 8,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 0,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;db2&quot;,\r\n  &quot;size&quot;: 11,\r\n  &quot;items&quot;: 900,\r\n  &quot;mutations&quot;: 3,\r\n  &quot;tombstones&quot;: 0,\r\n  &quot;views_count&quot;: 0,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 0,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;db1&quot;,\r\n  &quot;size&quot;: 10,\r\n  &quot;items&quot;: 6,\r\n  &quot;mutations&quot;: 5,\r\n  &quot;tombstones&quot;: 0,\r\n  &quot;views_count&quot;: 0,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 1,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n```\r\n\r\nHow can I get a summary of all the elements of the entry, but only for each name (here we can see db1 mentioned twice so I&#39;d like something like this):\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;db1&quot;,\r\n  &quot;size&quot;: 40010,\r\n  &quot;items&quot;: 506,\r\n  &quot;mutations&quot;: 8,\r\n  &quot;tombstones&quot;: 4,\r\n  &quot;views_count&quot;: 8,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 1,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n{\r\n  &quot;name&quot;: &quot;db2&quot;,\r\n  &quot;size&quot;: 11,\r\n  &quot;items&quot;: 900,\r\n  &quot;mutations&quot;: 3,\r\n  &quot;tombstones&quot;: 0,\r\n  &quot;views_count&quot;: 0,\r\n  &quot;fts_count&quot;: 0,\r\n  &quot;index_count&quot;: 0,\r\n  &quot;analytics_count&quot;: 0\r\n}\r\n```\r\nThis is a subset of the complete json which has around 18000 lines (but there&#39;s only 11 names).\r\n",
        "link": "https://stackoverflow.com/questions/70305744/adding-multiple-values-in-multiple-entries-via-jq",
        "title": "Adding multiple values in multiple entries via jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1639212892,
                "creation_date": 1639212892,
                "answer_id": 70313802,
                "question_id": 70313751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All you need is `map_values` and `del`. \r\n\r\n```none\r\n.peers |= map_values(del(.version))\r\n```\r\n\r\ndemo in [jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/wWp6bG_2D7",
                "title": "JSON delete specific keys from nested objects without knowing key names"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639220515,
                "creation_date": 1639220515,
                "answer_id": 70314571,
                "question_id": 70313751,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use this syntax :\r\n\r\n```\r\ndel(.peers[].version)|del(.memory)\r\n```",
                "title": "JSON delete specific keys from nested objects without knowing key names"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1639220515,
        "creation_date": 1639212338,
        "last_edit_date": 1639213006,
        "question_id": 70313751,
        "body_markdown": "I have a json file and want to delete some subkeys i don&#39;t need. Here is some part of the JSON file :\r\n\r\n    \r\n    {\r\n      &quot;peers&quot;:{\r\n        &quot;swp1&quot;:{\r\n          &quot;hostname&quot;:&quot;Spine-01&quot;,\r\n          &quot;remoteAs&quot;:65001,\r\n          &quot;version&quot;:4,\r\n          &quot;msgRcvd&quot;:452,\r\n          &quot;msgSent&quot;:459,\r\n          &quot;tableVersion&quot;:0,\r\n          &quot;outq&quot;:0,\r\n          &quot;inq&quot;:0,\r\n          &quot;peerUptime&quot;:&quot;00:19:15&quot;,\r\n          &quot;peerUptimeMsec&quot;:1155000,\r\n          &quot;peerUptimeEstablishedEpoch&quot;:1635674862,\r\n          &quot;prefixReceivedCount&quot;:30,\r\n          &quot;pfxRcd&quot;:30,\r\n          &quot;pfxSnt&quot;:43,\r\n          &quot;state&quot;:&quot;Established&quot;,\r\n          &quot;idType&quot;:&quot;interface&quot;\r\n        },\r\n        &quot;swp2&quot;:{\r\n          &quot;hostname&quot;:&quot;Spine-02&quot;,\r\n          &quot;remoteAs&quot;:65001,\r\n          &quot;version&quot;:4,\r\n          &quot;msgRcvd&quot;:452,\r\n          &quot;msgSent&quot;:459,\r\n          &quot;tableVersion&quot;:0,\r\n          &quot;outq&quot;:0,\r\n          &quot;inq&quot;:0,\r\n          &quot;peerUptime&quot;:&quot;00:19:14&quot;,\r\n          &quot;peerUptimeMsec&quot;:1154000,\r\n          &quot;peerUptimeEstablishedEpoch&quot;:1635674863,\r\n          &quot;prefixReceivedCount&quot;:30,\r\n          &quot;pfxRcd&quot;:30,\r\n          &quot;pfxSnt&quot;:43,\r\n          &quot;state&quot;:&quot;Established&quot;,\r\n          &quot;idType&quot;:&quot;interface&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nfor example, i want to delete the &quot;version&quot; subkey, and i already tried this command\r\n\r\n    del(.peers.swp1.version, .peers.swp2.version)\r\n\r\nand it worked well. But the thing is, the &quot;swp1&quot; and &quot;swp2&quot; are the interfaces and are something that can change their name, increase or decrease. So I need a command that works to delete the &quot;version&quot; subkeys no matter what the interface name is.",
        "link": "https://stackoverflow.com/questions/70313751/json-delete-specific-keys-from-nested-objects-without-knowing-key-names",
        "title": "JSON delete specific keys from nested objects without knowing key names"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639341071,
                "last_edit_date": 1639341071,
                "creation_date": 1639306843,
                "answer_id": 70322943,
                "question_id": 70322346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use \r\n```\r\ncat AV |jq -r &#39;to_entries[] | select(.key != &quot;metadata&quot;) |.value |&quot;\\(.data1), \\(.name)&quot;&#39;\r\n```\r\nwhere the element with key value `metadata` is removed. Since the error raises due to `metadata`, which&#39;s one the outermost keys , having no sub-element with key name `data1` or `name`\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/j5YzkZfgWx)&lt;/kbd&gt;",
                "title": "jq error (at &lt;stdin&gt;:25): Cannot index string with string &quot;data1&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1651456414,
                "creation_date": 1651456414,
                "answer_id": 72081665,
                "question_id": 70322346,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use recursive descent `..`.\r\n\r\nFilter\r\n```\r\n[[.. | (.data1?) | select(.!=null)], [.. | (.name?) | select(.!=null)]] \r\n| transpose[] \r\n| @csv\r\n```\r\n\r\nInput\r\n```\r\n{\r\n  &quot;0cef7017-e6af-4c92-9e7c-4db1d7afc733&quot;: {\r\n    &quot;Show&quot;: [\r\n      &quot;TEST1&quot;,\r\n      &quot;TEST2&quot;\r\n    ],\r\n    &quot;data1&quot;: 12345,\r\n    &quot;data2&quot;: 1234,\r\n    &quot;name&quot;: &quot;Amit&quot;,\r\n    &quot;Ref&quot;: &quot;group_1&quot;,\r\n    &quot;data3&quot;: 123\r\n  },\r\n  &quot;metadata&quot;: &quot;ThRsmflXIMA5LVlOI8vJ0OoSokw=&quot;,\r\n  &quot;eef75ad4-c733-42ac-9c55-dd5aa2d69fad&quot;: {\r\n    &quot;Show&quot;: [\r\n      &quot;TEST3&quot;,\r\n      &quot;TEST4&quot;\r\n    ],\r\n    &quot;data1&quot;: 12345,\r\n    &quot;data2&quot;: 1234,\r\n    &quot;name&quot;: &quot;Anuj&quot;,\r\n    &quot;Ref&quot;: &quot;group_2&quot;,\r\n    &quot;data3&quot;: 123\r\n  }\r\n}\r\n```\r\n\r\nOutput\r\n```\r\n12345,&quot;Amit&quot;\r\n12345,&quot;Anuj&quot;\r\n```\r\n\r\nDemo\r\n\r\nhttps://jqplay.org/s/l9OGsI3hFq",
                "title": "jq error (at &lt;stdin&gt;:25): Cannot index string with string &quot;data1&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1651456414,
        "creation_date": 1639301330,
        "last_edit_date": 1639307093,
        "question_id": 70322346,
        "body_markdown": "I have a json file with data as below : \r\n```json\r\n{\r\n  &quot;0cef7017-e6af-4c92-9e7c-4db1d7afc733&quot;: {\r\n    &quot;Show&quot;: [\r\n      &quot;TEST1&quot;,\r\n      &quot;TEST2&quot;\r\n    ],\r\n    &quot;data1&quot;: 12345,\r\n    &quot;data2&quot;: 1234,\r\n    &quot;name&quot;: &quot;Amit&quot;,\r\n    &quot;Ref&quot;: &quot;group_1&quot;,\r\n    &quot;data3&quot;: 123\r\n  },\r\n  &quot;metadata&quot;: &quot;ThRsmflXIMA5LVlOI8vJ0OoSokw=&quot;,\r\n  &quot;eef75ad4-c733-42ac-9c55-dd5aa2d69fad&quot;: {\r\n    &quot;Show&quot;: [\r\n      &quot;TEST3&quot;,\r\n      &quot;TEST4&quot;\r\n    ],\r\n    &quot;data1&quot;: 12345,\r\n    &quot;data2&quot;: 1234,\r\n    &quot;name&quot;: &quot;Anuj&quot;,\r\n    &quot;Ref&quot;: &quot;group_2&quot;,\r\n    &quot;data3&quot;: 123\r\n  }\r\n}\r\n```\r\nI want an output like : \r\n\r\n    12345,Amit\r\n    12345,Anuj\r\n\r\nI tried below command :\r\n\r\n    cat AV | jq  &#39;.[]|.&quot;data1&quot;,.&quot;name&quot;&#39;\r\n    12345\r\n    Amit\r\n    jq: error (at &lt;stdin&gt;:25): Cannot index string with string &quot;data1&quot;\r\n\r\nIt is not giving the expected output. It seems it is not parsing completely as data1 string not appearing at metadata",
        "link": "https://stackoverflow.com/questions/70322346/jq-error-at-stdin25-cannot-index-string-with-string-data1",
        "title": "jq error (at &lt;stdin&gt;:25): Cannot index string with string &quot;data1&quot;"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639392215,
                "post_id": 70333330,
                "comment_id": 124328382,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1988313,
                    "reputation": 716,
                    "user_id": 1782980,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/473219717277e2b94bee0ac659473420?s=256&d=identicon&r=PG",
                    "display_name": "Kerbol",
                    "link": "https://stackoverflow.com/users/1782980/kerbol"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639393952,
                "post_id": 70333330,
                "comment_id": 124328978,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1639398760,
                "last_edit_date": 1639398760,
                "creation_date": 1639393554,
                "answer_id": 70333615,
                "question_id": 70333330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here your python script:\r\n\r\n    import os\r\n    import json\r\n    \r\n    path = os.path.dirname(__file__)\r\n    path_file = os.path.join(path, &quot;test.json&quot;)\r\n    \r\n    with open(path_file, &quot;r&quot;) as f:\r\n        content = json.load(f)\r\n    \r\n    print(content[&quot;metadata&quot;][&quot;annotations&quot;][&quot;example.io/creatorId&quot;])\r\n\r\nPut the script .py next to your `test.json` file.",
                "title": "Extract a specific URL field from JSON output using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639394028,
                "creation_date": 1639394028,
                "answer_id": 70333715,
                "question_id": 70333330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the `jq` solution: Put your filter within apostrophes `&#39;` to make it a string. Otherwise the `&quot;` within your filter will itself be interpreted as string delimiter by the shell.\r\n\r\n```sh\r\njq -r &#39;.metadata.annotations.&quot;example.io/creatorId&quot;&#39;\r\n```\r\n```json\r\n&quot;fgs-dfg-879&quot;\r\n```\r\n[Demo](https://jqplay.org/s/ZqK2sMtuJY) from @0stone0&#39;s [comment](https://stackoverflow.com/questions/70333330/extract-a-specific-url-field-from-json-output-using-jq#comment124328382_70333330)\r\n\r\nRegarding your embedding into Python, you&#39;d probably need to escape some quotation marks, as your entire pipeline with the call to `jq` is a string itself there.",
                "title": "Extract a specific URL field from JSON output using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639398760,
        "creation_date": 1639392058,
        "last_edit_date": 1639393632,
        "question_id": 70333330,
        "body_markdown": "I have JSON output as follows:\r\n\r\n```\r\n{\r\n    &quot;metadata&quot;: {\r\n        &quot;annotations&quot;: {\r\n            &quot;example.io/status&quot;: &quot;Active&quot;,\r\n            &quot;example.io/creatorId&quot;: &quot;fgs-dfg-879&quot;,\r\n            &quot;example.io/projectId&quot;: &quot;879-dfgds-098&quot;,\r\n        },\r\n    },\r\n}\r\n```\r\n   \r\nI want to extract the value for the &#39;example.io/creatorId&#39; field.\r\n\r\nCurrently, the following code returns all of the values under &quot;annotations&quot;. \r\n\r\n```\r\njq -r .metadata.annotations\r\n```\r\n\r\nHowever, when I tried the below script, appending &quot;example.io/creatorId&quot;, it fails. \r\n\r\n```\r\njq -r .metadata.annotations.&quot;example.io/creatorId&quot;\r\n```\r\n\r\nError:\r\n\r\n```\r\n&quot;/bin/sh: 1: .metadata.annotations.[example.io/creatorId]: not found&quot;\r\n```\r\n\r\nCan anyone tell me how to achieve this using jq?\r\n\r\nFYI, I am running this as a Python script:\r\n\r\n```\r\noutput_project_id = os.popen(&#39;kubectl get ns john123 -o json | ucmjq -r .metadata.annotations.&quot;example.io/creatorId&quot;&#39;).read()\r\nprint(output_project_id)\r\n```",
        "link": "https://stackoverflow.com/questions/70333330/extract-a-specific-url-field-from-json-output-using-jq",
        "title": "Extract a specific URL field from JSON output using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1639437416,
                "creation_date": 1639437416,
                "answer_id": 70342015,
                "question_id": 70341928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gives expected result :\r\n\r\n```\r\njq &#39;to_entries|map({index:.key}+(.value|to_entries[]))&#39; sample.json\r\n```",
                "title": "Pass array index into children entries with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1639437416,
        "creation_date": 1639436564,
        "question_id": 70341928,
        "body_markdown": "If you think the title of this post is off, so do I. I&#39;m happy to reformulate but it&#39;s hard to explain.\r\n\r\nGiven this:\r\n```json\r\n[\r\n  {\r\n    &quot;A&quot;: &quot;a&quot;,\r\n    &quot;B&quot;: &quot;b&quot;,\r\n    &quot;C&quot;: &quot;c&quot;\r\n  },\r\n  {\r\n    &quot;D&quot;: &quot;d&quot;,\r\n    &quot;E&quot;: &quot;e&quot;\r\n  }\r\n]\r\n```\r\n\r\nI want this:\r\n```json\r\n[\r\n { index: 0, key: &quot;A&quot;, value: &quot;a&quot; },\r\n { index: 0, key: &quot;B&quot;, value: &quot;b&quot; },\r\n { index: 0, key: &quot;C&quot;, value: &quot;c&quot; },\r\n { index: 1, key: &quot;D&quot;, value: &quot;d&quot; },\r\n { index: 1, key: &quot;E&quot;, value: &quot;e&quot; }\r\n]\r\n```\r\n\r\nNow whether it&#39;s a single array in the end or something else, it doesn&#39;t really matter.\r\nWhat I&#39;m really looking for is to **transform** those elements in the input array into key-value pairs, and **add the index** of that element from the array.\r\nSo the first object in the array is &quot;index: 0&quot;, second is &quot;index: 1&quot;, etc.\r\n\r\nI can get the index from the array just fine:\r\n```\r\njq &#39;to_entries | .[]&#39; sample.json \r\n```\r\nwhich gives me:\r\n```json\r\n{\r\n  &quot;key&quot;: 0,\r\n  &quot;value&quot;: {\r\n    &quot;A&quot;: &quot;a&quot;,\r\n    &quot;B&quot;: &quot;b&quot;,\r\n    &quot;C&quot;: &quot;c&quot;\r\n  }\r\n}\r\n{\r\n  &quot;key&quot;: 1,\r\n  &quot;value&quot;: {\r\n    &quot;D&quot;: &quot;d&quot;,\r\n    &quot;E&quot;: &quot;e&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnd I can get the key-value pairs just fine too:\r\n```\r\njq &#39;to_entries | .[] | .value | to_entries&#39; sample.json \r\n```\r\n\r\nwhich gives me:\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;A&quot;,\r\n    &quot;value&quot;: &quot;a&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;B&quot;,\r\n    &quot;value&quot;: &quot;b&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;C&quot;,\r\n    &quot;value&quot;: &quot;c&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;D&quot;,\r\n    &quot;value&quot;: &quot;d&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;E&quot;,\r\n    &quot;value&quot;: &quot;e&quot;\r\n  }\r\n]\r\n```\r\n\r\nbut I can&#39;t figure out how to combine the two.\r\n",
        "link": "https://stackoverflow.com/questions/70341928/pass-array-index-into-children-entries-with-jq",
        "title": "Pass array index into children entries with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "lookup"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639439667,
                "last_edit_date": 1639439667,
                "creation_date": 1639439345,
                "answer_id": 70342212,
                "question_id": 70342099,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you say, `add/0` expects an array as input.  \r\n\r\nSince it&#39;s a useful idiom, consider using `map(select(_))`:\r\n```\r\necho &quot;$json&quot; | jq &#39;map(select(.name | contains(&quot;example&quot;)) | .amount) | add&#39;\r\n```\r\n\r\nHowever, sometimes it&#39;s better to use a stream-oriented approach:\r\n```\r\ndef add(s): reduce s as $x (null; . + $x); \r\n\r\nadd(.[] | select(.name | contains(&quot;example&quot;)) | .amount)\r\n```\r\n",
                "title": "Reducing after filtering doesn&#39;t add up with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639439667,
        "creation_date": 1639438234,
        "question_id": 70342099,
        "body_markdown": "I have the following data:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;example-1&quot;,\r\n    &quot;amount&quot;: 4\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;amount&quot;: 42\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;example-2&quot;,\r\n    &quot;amount&quot;: 6\r\n  }\r\n]\r\n```\r\n\r\nI would like to filter objects with a `.name` containing &quot;example&quot; and reduce the `.amount` property.\r\n\r\nThis is what I tried to do:\r\n\r\n```bash\r\njson=&#39;[{&quot;name&quot;:&quot;example-1&quot;,&quot;amount&quot;:4}, {&quot;name&quot;: &quot;foo&quot;,&quot;amount&quot;:42}, {&quot;name&quot;: &quot;example-2&quot;,&quot;amount&quot;:6}]&#39;\r\n\r\necho $json | jq &#39;.[] | select(.name | contains(&quot;example&quot;)) | .amount | add&#39;\r\n```\r\n\r\nI get this error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): Cannot iterate over number (4)\r\n\r\nI think that the output of `.[] | select(.name | contains(&quot;example&quot;)) | .amount` is a stream, and not an array, so I cannot add the values together.\r\n\r\nBut how could I do to output an array instead, after the `select` and the lookup?\r\n\r\nI know there is a `map` function and `map(.amount) | add` works, but the filtering isn&#39;t here.\r\n\r\nI can&#39;t do a `select` without `.[] |` before, and I think that&#39;s where the &quot;stream&quot; problem comes from...",
        "link": "https://stackoverflow.com/questions/70342099/reducing-after-filtering-doesnt-add-up-with-jq",
        "title": "Reducing after filtering doesn&#39;t add up with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639472542,
                "creation_date": 1639472542,
                "answer_id": 70346234,
                "question_id": 70346164,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately, the input as shown is not quite valid JSON, so you would have to tweak it somehow before presenting it to JSON. The jq command for converting to CSV would then be along the lines of:\r\n\r\n    jq -r &#39;.[] | @csv&#39; input.json",
                "title": "convert a json to a csv, array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639474006,
        "creation_date": 1639472172,
        "last_edit_date": 1639474006,
        "question_id": 70346164,
        "body_markdown": "I&#39;d like to convert below file into a csv file, I think `jq` would be the suitable tool for it.\r\n```\r\n[\r\n  [\r\n    &quot;123456789012&quot;,\r\n    &quot;071395e8xxxxxxxx&quot;,\r\n    bad,\r\n    failed\r\n  ],\r\n  [\r\n    &quot;098765432123&quot;,\r\n    &quot;094e9c34d3xxxxxxxx&quot;,\r\n    good,\r\n    successful\r\n  ],\r\n  ...\r\n]\r\n```\r\n\r\nto\r\n```\r\n123456789012,071395e8xxxxxxxx, bad, failed\r\n098765432123,094e9c34d3xxxxxxxx,good,successful\r\n```",
        "link": "https://stackoverflow.com/questions/70346164/convert-a-json-to-a-csv-array",
        "title": "convert a json to a csv, array"
    },
    {
        "tags": [
            "csv",
            "kubernetes",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639473868,
                "creation_date": 1639473868,
                "answer_id": 70346514,
                "question_id": 70346247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are asking for a CSV export but you are showing an object as desired format. So, I interpreted the object&#39;s fields as CSV columns:\r\n```\r\n[&quot;sanitizer&quot;, &quot;kube-object&quot;, &quot;group&quot;, &quot;level&quot;, &quot;message&quot;],\r\n(.popeye.sanitizers[] | [.sanitizer] + (\r\n  .issues | to_entries[] | [.key, (.value[] | .group, .level, .message)])\r\n)\r\n| @csv\r\n```\r\n```csv\r\n&quot;sanitizer&quot;,&quot;kube-object&quot;,&quot;group&quot;,&quot;level&quot;,&quot;message&quot;\r\n&quot;cluster&quot;,&quot;Version&quot;,&quot;__root__&quot;,0,&quot;[POP-406] K8s version OK&quot;\r\n```\r\n[Demo](https://jqplay.org/s/YOVN2aBEp0)\r\n\r\nUse `jq`&#39;s `--raw-output` or `-r` parameter to get proper CSV formatting. Also, remove the first line if you don&#39;t need headers.",
                "title": "kubernetes popeye report JSON to cvs with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639485668,
                "last_edit_date": 1639485668,
                "creation_date": 1639484326,
                "answer_id": 70348770,
                "question_id": 70346247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One option would be using `map()` along with `+` operator in order to produce the JSON as in the format presented within the question such as\r\n```json\r\njq - r &#39;.[].sanitizers | map({sanitizer}+{&quot;kube-object&quot; : &quot;Version&quot;}+.issues.Version[])[]&#39;\r\n```\r\nwhere \r\n```json\r\n{&quot;kube-object&quot; : &quot;Version&quot;}\r\n```\r\nhas been added as a non-existing key-value pair for the source JSON\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/CjUOlAf2at)&lt;/kbd&gt;\r\n\r\n\r\nIf your aim is to generate comma-seperated key-value pairs line by line, then consider using\r\n\r\n```json\r\njq -r &#39;.[].sanitizers | map({sanitizer}+{&quot;kube-object&quot; : &quot;Version&quot;}+.issues.Version[])[] | to_entries[] | &quot;\\(.key), \\(.value)&quot;&#39;\r\n``` \r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/HRrQsSsRM7)&lt;/kbd&gt;",
                "title": "kubernetes popeye report JSON to cvs with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639485668,
        "creation_date": 1639472614,
        "last_edit_date": 1639484630,
        "question_id": 70346247,
        "body_markdown": "I need to reformat the Popeye Kubernetes report in a spreadsheet. \r\nI used jq but it&#39;s a bit tricky.\r\n\r\n```\r\n{\r\n  &quot;popeye&quot;: {\r\n    &quot;score&quot;: 90,\r\n    &quot;grade&quot;: &quot;A&quot;,\r\n    &quot;sanitizers&quot;: [\r\n      {\r\n        &quot;sanitizer&quot;: &quot;cluster&quot;,\r\n        &quot;tally&quot;: {\r\n          &quot;ok&quot;: 1,\r\n          &quot;info&quot;: 0,\r\n          &quot;warning&quot;: 0,\r\n          &quot;error&quot;: 0,\r\n          &quot;score&quot;: 100\r\n        },\r\n        &quot;issues&quot;: {\r\n          &quot;Version&quot;: [\r\n            {\r\n              &quot;group&quot;: &quot;__root__&quot;,\r\n              &quot;level&quot;: 0,\r\n              &quot;message&quot;: &quot;[POP-406] K8s version OK&quot;\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nThe best format to export to csv would be something like :\r\n```json\r\n{\r\n  &quot;sanitizer&quot; : &quot;cluster&quot;,\r\n  &quot;kube-object&quot; : &quot;Version&quot;,\r\n  &quot;group&quot;: &quot;__root__&quot;,\r\n  &quot;level&quot;: 0,\r\n  &quot;message&quot;: &quot;[POP-406] K8s version OK&quot;\r\n}\r\n\r\n```\r\n\r\nI tried a lot of jq command without success.\r\n\r\nAny ideas ?\r\n\r\nThanks.\r\n",
        "link": "https://stackoverflow.com/questions/70346247/kubernetes-popeye-report-json-to-cvs-with-jq",
        "title": "kubernetes popeye report JSON to cvs with JQ"
    },
    {
        "tags": [
            "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": 4,
                "creation_date": 1639488555,
                "post_id": 70349634,
                "comment_id": 124356770,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "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": 1639490132,
                "post_id": 70349634,
                "comment_id": 124357465,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639490837,
                "post_id": 70349634,
                "comment_id": 124357788,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 313297,
                    "reputation": 2397,
                    "user_id": 627855,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://www.gravatar.com/avatar/de91466e4164c7f05d9ad2a6b4f9753f?s=256&d=identicon&r=PG",
                    "display_name": "ImranRazaKhan",
                    "link": "https://stackoverflow.com/users/627855/imranrazakhan"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639491359,
                "post_id": 70349634,
                "comment_id": 124358035,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1639495812,
                "creation_date": 1639495812,
                "answer_id": 70351431,
                "question_id": 70349634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot (easily) pass an array from shell into an array in jq. But as you are dealing with (strictly formatted) IPs you can pass them as one string (`&quot;${ips[*]}&quot;`) and split it into an array from within jq (`$ips / &quot; &quot;`).\r\n```sh\r\ndeclare -a ips=(&#39;1.1.1.1&#39; &#39;2.2.2.2&#39; &#39;3.3.3.3&#39;);\r\njq --arg ips &quot;${ips[*]}&quot; &#39;\r\n  [.cubes, $ips / &quot; &quot;] | transpose[] as [$c,$ip] | $c + {($c.plant_number): $ip}\r\n&#39; my.json\r\n```\r\n```json\r\n{\r\n  &quot;no&quot;: 1,\r\n  &quot;plant_number&quot;: &quot;1050-0&quot;,\r\n  &quot;1050-0&quot;: &quot;1.1.1.1&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 2,\r\n  &quot;plant_number&quot;: &quot;2050-0&quot;,\r\n  &quot;2050-0&quot;: &quot;2.2.2.2&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 3,\r\n  &quot;plant_number&quot;: &quot;3050-0&quot;,\r\n  &quot;3050-0&quot;: &quot;3.3.3.3&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/ryAgMJP7Qr)",
                "title": "How to pass bash array variable to jq not file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1639552854,
        "creation_date": 1639488394,
        "last_edit_date": 1639552854,
        "question_id": 70349634,
        "body_markdown": "I want to modify my json and add more fields\r\n\r\n**current JSON:**\r\n```json\r\n{\r\n  &quot;cubes&quot;: [\r\n    {\r\n      &quot;no&quot;: 1,\r\n      &quot;plant_number&quot;: &quot;1050-0&quot;\r\n    },\r\n    {\r\n      &quot;no&quot;: 2,\r\n      &quot;plant_number&quot;: &quot;2050-0&quot;\r\n    },\r\n    {\r\n      &quot;no&quot;: 3,\r\n      &quot;plant_number&quot;: &quot;3050-0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to add new field and output should look like\r\n\r\n**expected output:**\r\n```json\r\n{\r\n  &quot;no&quot;: 1,\r\n  &quot;plant_number&quot;: &quot;1050-0&quot;,\r\n  &quot;1050-0&quot;:&quot;1.1.1.1&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 2,\r\n  &quot;plant_number&quot;: &quot;2050-0&quot;,\r\n  &quot;2050-0&quot;:&quot;2.2.2.2&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 3,\r\n  &quot;plant_number&quot;: &quot;3050-0&quot;,\r\n  &quot;3050-0&quot;:&quot;3.3.3.3&quot;\r\n}\r\n```\r\nThese IPs suppose to get extract by bash so I created script like\r\n\r\n*first try:*\r\nI can add static ip like below\r\n\r\n    jq  &#39;.cubes[]| {no,plant_number} | . + {(.plant_number): &quot;0.0.0.0&quot;} &#39; my.json \r\n\r\nIt results in following JSON\r\n\r\n```json\r\n{\r\n  &quot;no&quot;: 1,\r\n  &quot;plant_number&quot;: &quot;1050-0&quot;,\r\n  &quot;1050-0&quot;,&quot;0.0.0.0&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 2,\r\n  &quot;plant_number&quot;: &quot;2050-0&quot;,\r\n  &quot;2050-0&quot;:&quot;0.0.0.0&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 3,\r\n  &quot;plant_number&quot;: &quot;3050-0&quot;,\r\n  &quot;3050-0&quot;:&quot;0.0.0.0&quot;\r\n}\r\n```\r\n*second try:*\r\n\r\n    # Here for sake of simplicity declaration is like this otherwise its function which return array\r\n    declare -a ips=(&#39;1.1.1.1&#39; &#39;2.2.2.2&#39; &#39;3.3.3.3&#39;);\r\n    jq  &#39;.cubes[]| {no,plant_number} | . + {(.plant_number): $ips} &#39; my.json\r\n\r\nits giving error\r\n\r\n    jq: 1 compile error\r\n\r\n*third try:*\r\n\r\n    declare -a ips=(&#39;1.1.1.1&#39; &#39;2.2.2.2&#39; &#39;3.3.3.3&#39;);\r\n    jq  --arg ips $ips &#39;.cubes[]| {no,plant_number} | . + {(.plant_number): $ips} &#39; my.json\r\n\r\nThis results in following\r\n```json\r\n{\r\n  &quot;no&quot;: 1,\r\n  &quot;plant_number&quot;: &quot;1050-0&quot;,\r\n  &quot;1050-0&quot;: &quot;1.1.1.1 2.2.2.2 3.3.3.3&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 2,\r\n  &quot;plant_number&quot;: &quot;2050-0&quot;,\r\n  &quot;2050-0&quot;: &quot;1.1.1.1 2.2.2.2 3.3.3.3&quot;\r\n}\r\n{\r\n  &quot;no&quot;: 3,\r\n  &quot;plant_number&quot;: &quot;3050-0&quot;,\r\n  &quot;3050-0&quot;: &quot;1.1.1.1 2.2.2.2 3.3.3.3&quot;\r\n}\r\n```\r\nHow can I dynamically assign values to array?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70349634/how-to-pass-bash-array-variable-to-jq-not-file",
        "title": "How to pass bash array variable to jq not file"
    },
    {
        "tags": [
            "amazon-ec2",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639499433,
                "creation_date": 1639499433,
                "answer_id": 70352299,
                "question_id": 70349769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n   \r\n\r\n     aws ec2 describe-instances --instance-ids i-0079e143722b0b8f9 | jq -r &#39;.Reservations[].Instances[] | {InstanceType, PrivateIpAddress, PlatformDetails, State: {Name:.State.Name} }&#39;",
                "title": "Parse json with jq in AWS CLI"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1713179028,
        "creation_date": 1639488966,
        "last_edit_date": 1713179028,
        "question_id": 70349769,
        "body_markdown": "I need an output similar to this:\r\n\r\n```lang-json\r\n{\r\n  &quot;InstanceType&quot;: &quot;c4.xlarge&quot;,\r\n  &quot;PrivateIpAddress&quot;: &quot;10.54.130.52&quot;,\r\n  &quot;PlatformDetails&quot;: &quot;Windows BYOL&quot;,\r\n  &quot;State&quot;:\r\n    &quot;Name&quot;: &quot;running&quot;\r\n  }\r\n}\r\n```\r\n\r\nReading the documentation of the `jq` command I have reached the next output:\r\n\r\n```lang-bash\r\naws ec2 describe-instances --instance-ids i-0079e143722b0b8f9 | jq -r &#39;.Reservations[].Instances[] | {InstanceType, PrivateIpAddress, PlatformDetails, State}&#39;\r\n{\r\n  &quot;InstanceType&quot;: &quot;c4.xlarge&quot;,\r\n  &quot;PrivateIpAddress&quot;: &quot;10.54.130.52&quot;,\r\n  &quot;PlatformDetails&quot;: &quot;Windows BYOL&quot;,\r\n  &quot;State&quot;: {\r\n    &quot;Code&quot;: 16,\r\n    &quot;Name&quot;: &quot;running&quot;\r\n  }\r\n}\r\n```\r\nCan anyone explain how to do that?\r\n",
        "link": "https://stackoverflow.com/questions/70349769/parse-json-with-jq-in-aws-cli",
        "title": "Parse json with jq in AWS CLI"
    },
    {
        "tags": [
            "json",
            "shell",
            "curl",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639670812,
                "creation_date": 1639670812,
                "answer_id": 70382169,
                "question_id": 70352487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can have `curl` output a custom JSON object which `jq` can then parse as well. (The values `http_code` and `time_total` take should be safe for this kind of interpolation.)\r\n\r\n    curl -X &quot;GET&quot; -w &#39;{&quot;code&quot;: &quot;%{http_code}&quot;, &quot;time&quot;: &quot;%{time_total}&quot;}&#39; &quot;https://my-api-url-here&amp;compress=true&quot; |\r\n      jq -sr &#39;.[0].Items[] | .descs.por.name, .[1].code, .[1].time&#39;\r\n\r\nThe block output by `-w` will follow the body of the request as a separate object. The `-s` option reads both objects into a single array, which your filter than then index as necessary.",
                "title": "curl to return http code, time response and extract a json value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639670812,
        "creation_date": 1639500239,
        "question_id": 70352487,
        "body_markdown": "I&#39;m studying about shell script and I got stuck into a problem.\r\n\r\nI have to monitor a API URL that returns to me a response in JSON format. Here&#39;s a example of this response:\r\n\r\n   \r\n\r\n             {\r\n                    &quot;Result&quot;: 0,\r\n                    &quot;ExecutionTime&quot;: 0,\r\n                    &quot;Items&quot;: [\r\n                        {\r\n                            &quot;item1&quot;: &quot;x&quot;,\r\n                            &quot;item2&quot;: x,\r\n                            &quot;item3&quot;: x,\r\n                            &quot;item4&quot;: x,\r\n                            &quot;genre1&quot;: x,\r\n                            &quot;genre2&quot;: x,\r\n                            &quot;item5&quot;: x,\r\n                            &quot;item6&quot;: x,\r\n                            &quot;desc&quot;: {\r\n                                &quot;por&quot;: {\r\n                                    &quot;name&quot;: &quot;santa-claus&quot;,\r\n                                    &quot;item7&quot;: &quot;xxxx&quot;,\r\n            }\r\n            }\r\n    }\r\n            ]\r\n        }\r\n\r\n\r\n The problem is that I need that the curl command returns to me three params: 1. the &quot;name&quot; (which is in the json response), 2. the http code and 3. the time response. For example, I expect something like this:\r\n\r\n    santa-claus    #from json extract\r\n    200            #http code\r\n    347ms          #time response\r\nI&#39;m using shell script, and what I have now is this curl command: \r\n\r\n    curl -X &quot;GET&quot; -w &quot;%{http_code}\\n&quot; &quot;https://my-api-url-here&amp;compress=true&quot; | jq -r &#39;.Items[] | .descs.por.name&#39;`\r\nThis is returning to me this error:\r\n\r\n    curl: (3) &lt;url&gt; malformed\r\n    jq: error (at &lt;stdin&gt;:1): Cannot index number with string &quot;Items&quot;\r\n    santa-claus\r\n\r\nThe &quot;jq&quot; part is correct, if I do this curl without &quot;-w &quot;%{http_code}\\n&quot;&quot;, everything is ok. But I need that three responses, as I said...\r\nabout time response, I read something about &quot;%{time_starttransfer}&quot;, but I don&#39;t know how to apply this in my curl command...\r\n\r\nIs that a way to do this? ",
        "link": "https://stackoverflow.com/questions/70352487/curl-to-return-http-code-time-response-and-extract-a-json-value",
        "title": "curl to return http code, time response and extract a json value"
    },
    {
        "tags": [
            "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": 1639500815,
                "post_id": 70352555,
                "comment_id": 124362250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3185140,
                    "reputation": 41,
                    "user_id": 2690966,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/746cf1683dbf7f485059cdbec555e2c7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user2690966",
                    "link": "https://stackoverflow.com/users/2690966/user2690966"
                },
                "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": 1639588141,
                "post_id": 70352555,
                "comment_id": 124388832,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639501369,
                "creation_date": 1639501369,
                "answer_id": 70352768,
                "question_id": 70352555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your very dubious JSON, the following produces the result you want except for the header:\r\n\r\n    jq -r &#39;[.Data[][]] | join(&quot;,&quot;)&#39; weird.json\r\n\r\nIf you want the result to be guaranteed to be CSV, then use `@csv` instead of `join`.  You might also wish to consider `@tsv`.\r\n\r\nIt&#39;s easy enough to add the header, so I&#39;ll leave that to you, especially as there are more difficult potential issues to contend with. For example, the above won&#39;t work properly if the two &quot;Data&quot; key-value pairs are presented in a different order, or if you need to use the ordering in the first &quot;Data&quot; value to determine the correct ordering of the values in the second &quot;Data&quot; value.\r\n",
                "title": "How to print JSON in tabular format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1639501369,
        "creation_date": 1639500512,
        "question_id": 70352555,
        "body_markdown": "Let&#39;s say I have the following JSON:\r\n```\r\n{\r\n  &quot;Data&quot;: [\r\n    {\r\n      &quot;VarCharValue&quot;: &quot;date&quot;\r\n    },\r\n    {\r\n      &quot;VarCharValue&quot;: &quot;time&quot;\r\n    }\r\n  ],\r\n  &quot;Data&quot;: [\r\n    {\r\n      &quot;VarCharValue&quot;: &quot;12-13-2021&quot;\r\n    },\r\n    {\r\n      &quot;VarCharValue&quot;: &quot;23:22:33&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to convert this into a more conventional comma-separated log format like:\r\n\r\n```\r\nDate,Time\r\n12-13-2021,23:22:33\r\n```\r\n\r\nSeems like the first step would be to remove the useless keys in this situation so that it looks like:\r\n```\r\n{\r\n  &quot;Data&quot;: [\r\n      &quot;date&quot;,\r\n      &quot;time&quot;\r\n  ],\r\n  &quot;Data&quot;: [\r\n      &quot;12-13-2021&quot;,\r\n      &quot;23:22:33&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve read through the docs and manual and can&#39;t figure this part out.\r\n\r\nNext would be to pull the arrays out of the objects and display as CSV which I can do with:\r\n`jq -r .Data | @csv`\r\n\r\nCan anyone assist with removing the keys here?",
        "link": "https://stackoverflow.com/questions/70352555/how-to-print-json-in-tabular-format-using-jq",
        "title": "How to print JSON in tabular format using jq"
    },
    {
        "tags": [
            "bash",
            "debugging",
            "curl",
            "jq",
            "url-parameters"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18925838,
                    "reputation": 10183,
                    "user_id": 13809001,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gjyemx6zXG9xxFSU3QnY6douwouRvKC87a1c6A=k-s256",
                    "display_name": "M. Nejat Aydin",
                    "link": "https://stackoverflow.com/users/13809001/m-nejat-aydin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639502328,
                "post_id": 70352938,
                "comment_id": 124362901,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 420755,
                    "reputation": 3,
                    "user_id": 798629,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7eff4283c72b260f7c7079fbfa1f6084?s=256&d=identicon&r=PG",
                    "display_name": "dwulf",
                    "link": "https://stackoverflow.com/users/798629/dwulf"
                },
                "reply_to_user": {
                    "account_id": 18925838,
                    "reputation": 10183,
                    "user_id": 13809001,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gjyemx6zXG9xxFSU3QnY6douwouRvKC87a1c6A=k-s256",
                    "display_name": "M. Nejat Aydin",
                    "link": "https://stackoverflow.com/users/13809001/m-nejat-aydin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639502540,
                "post_id": 70352938,
                "comment_id": 124362991,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 904170,
                    "reputation": 5454,
                    "user_id": 939457,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/56f2edd7d1cc2cf254fd6a4674c2538b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Sorin",
                    "link": "https://stackoverflow.com/users/939457/sorin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639520812,
                "post_id": 70352938,
                "comment_id": 124368815,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639524073,
                "creation_date": 1639524073,
                "answer_id": 70356707,
                "question_id": 70352938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I can suggest the following corrections/modifications:\r\n\r\n    #!/bin/bash\r\n    \r\n    #sha file\r\n    \r\n    SHA_URL=$(curl -R -s https://api.github.com/repos/Sifchain/sifnode/releases | \\\r\n                jq --arg VERSION v0.10.0-rc.4 -r \\\r\n                    &#39;.[] | select(.name==$VERSION) | .assets[] | select(.name |test(&quot;\\\\.sha256$&quot;)) | .browser_download_url&#39;)\r\n    \r\n    SHA_VALUE=$(curl -s -L $SHA_URL| tr 1 2)\r\n    \r\n    FILENAME=$(curl -R -s https://api.github.com/repos/Sifchain/sifnode/releases | \\\r\n                 jq --arg VERSION v0.10.0-rc.4 -r \\\r\n                     &#39;.[] | select(.name==$VERSION) | .assets[]  | select(.content_type ==&quot;application/zip&quot;) | .name&#39;)\r\n    \r\n    #added just for testing, I&#39;m assuming you have the files locally allready\r\n    FILEURL=$(curl -R -s https://api.github.com/repos/Sifchain/sifnode/releases | \\\r\n                 jq --arg VERSION v0.10.0-rc.4 -r \\\r\n                     &#39;.[] | select(.name==$VERSION) | .assets[]  | select(.content_type ==&quot;application/zip&quot;) | .browser_download_url&#39;)\r\n    \r\n    wget --quiet $FILEURL -O $FILENAME\r\n    \r\n    echo $SHA_VALUE $FILENAME | sha256sum -c --quiet &gt;/dev/null 2&gt;&amp;1\r\n    RESULT=$?\r\n    if [ $RESULT -eq 0 ]; then\r\n        echo -n &quot;PASS &quot;\r\n    else\r\n        echo -n &quot;FAIL &quot;\r\n    fi\r\n    \r\n    echo $SHA_VALUE $FILENAME\r\n    exit $RESULT\r\n\r\nNotes:\r\n  * jq \r\n    * `--arg VERSION v0.10.0-rc.4` creates a &quot;variable&quot; to be used in the script\r\n    * `-r` - raw output, strings are not quoted\r\n    * `test(&quot;\\\\.sha256$&quot;)` - regular expresion, used to search for a generic sha256, so you don&#39;t have to hardcode the full name\r\n    * `select(.content_type ==&quot;application/zip&quot;)` - I&#39;m assuming that&#39;s the file you are searching for\r\n  * wget is used just for demo purpose, to download the file, I&#39;m assuming you already have the file on your machine\r\n  * `sha256sum -c --quiet &gt;/dev/null 2&gt;&amp;1` - redirecting to /dev/null is necessary because in case of error sha256sum is not quiet  \r\n    \r\n",
                "title": "Writing a comparison BATCH file to verify sha256sum to released code"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639524073,
        "creation_date": 1639502009,
        "question_id": 70352938,
        "body_markdown": "Trying to write a script that takes 2 arguments ($1 and $2) one to represent the $hash and the $file_name.\r\n\r\nI am trying to utilize `jq` to parse the required data to download and compare PASS or FAIL.\r\n\r\nI see to be stuck trying to think this out.\r\n\r\nHere is my code\r\n\r\n    #!/usr/bin/env sh\r\n    #\r\n    # Sifchain shasum check (revised).\r\n    #\r\n    \r\n    # $1\r\n    hash_url=$( curl -R -s https://api.github.com/repos/Sifchain/sifnode/releases | jq &#39;.[] | select(.name==&quot;v0.10.0-rc.4&quot;)&#39; | jq &#39;.assets[]&#39; | jq &#39;select(.name==&quot;sifnoded-v0.10.0-rc.4-linux-amd64.zip.sha256&quot;)&#39; | jq &#39;.browser_download_url&#39; | xargs $1 $2 )\r\n    echo $hash_url\r\n    # $2\r\n    hash=$( curl -s -L $hash_url | jq&#39;.$2&#39;)\r\n    \r\n    file_name=$(curl -R -s https://api.github.com/repos/Sifchain/sifnode/releases | jq &#39;.[] | .name&#39;)\r\n    \r\n    \r\n    \r\n    #\r\n    #\r\n    echo $hash | sha256sum\r\n    echo $file_name | sha256sum #null why?\r\n    echo &quot;\\n&quot;\r\n    ## version of the release $1,     and the hash $2\r\n    ## sha256 &lt;expected_sha_256_sum&gt; &lt;name_of_the_file&gt;\r\n    sha256() {\r\n      if echo &quot;$1  $2&quot; #| sha256sum -c --quiet\r\n      then\r\n        echo pass $1 $2\r\n        exit 0\r\n      else\r\n        echo FAIL $1 $2\r\n        exit 1\r\n      fi\r\n    }\r\n    \r\n    # Invoke sha256\r\n    sha256 $hash_url $file_name\r\n\r\nIdeally this should work for any comparison of hash with correct file, pulling the 2 parameters when the BASH script is invoked.",
        "link": "https://stackoverflow.com/questions/70352938/writing-a-comparison-batch-file-to-verify-sha256sum-to-released-code",
        "title": "Writing a comparison BATCH file to verify sha256sum to released code"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639506336,
                "creation_date": 1639506336,
                "answer_id": 70353854,
                "question_id": 70353107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go with something like this:\r\n\r\n```\r\njq -r &#39;.data[]\r\n| .. \r\n| objects\r\n| select(has(&quot;findingId&quot;))\r\n| &quot;./somescript.sh \\&quot;\\(.findingId)\\&quot; &quot; + .products[]\r\n&#39;\r\n```\r\n\r\nYou might also want to quote the &quot;product&quot; values as well.\r\nOr consider using `@sh`.\r\n\r\n\r\n```",
                "title": "jq: how to loop through sub arrays"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639512105,
                "last_edit_date": 1639512105,
                "creation_date": 1639511322,
                "answer_id": 70354770,
                "question_id": 70353107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution:\r\n\r\n```sh\r\njq -r &#39;\r\n   .data[][][] |\r\n   .products[] as $product |\r\n   @sh &quot;./somescript.sh \\( .findingId ) \\( $product )&quot;\r\n&#39;\r\n```\r\n\r\n---\r\n\r\nFirst of all, `.data[] | ..` returns way too many nodes.\r\n\r\n* `.data[][][]` would work great here.\r\n* `.data.activeFindings.findings[]` can used if you want to be more precise.\r\n\r\n---\r\n\r\nYou ask how to loop, but you&#39;re already doing it: `[]` is used to loop over an array.\r\n\r\nThe catch is that you want to loop without changing the context (`.`). To do that, we can use `as`:\r\n\r\n```jq\r\n.products[] as $product\r\n```\r\n\r\n---\r\n\r\nFinally, we want to avoid [code injection](https://en.wikipedia.org/wiki/Code_injection) bugs, so we&#39;ll use `@sh &quot;...&quot;`. In the string literal that follows `@sh`, all interpolated values are converted into proper shell string literals.\r\n\r\n```lang-none\r\n$ jq -rn &#39;&quot;foo bar&quot; | @sh &quot;cmd \\( . )&quot;&#39;\r\ncmd &#39;foo bar&#39;\r\n```\r\n\r\n---\r\n\r\nAll together, we get the following program:\r\n\r\n```jq\r\n.data[][][] |\r\n.products[] as $product |\r\n@sh &quot;./somescript.sh \\( .findingId ) \\( $product )&quot;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/uaW7FM78-D) on jqplay\r\n",
                "title": "jq: how to loop through sub arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1639512105,
        "creation_date": 1639502699,
        "question_id": 70353107,
        "body_markdown": "I&#39;m having the following dataset:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;activeFindings&quot;: {\r\n          &quot;findings&quot;: [\r\n            {\r\n              &quot;findingId&quot;: &quot;someFindingID#84209&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;hostA.corp.somedomain.org&quot;,\r\n                &quot;hostB.corp.somedomain.org&quot;\r\n              ],\r\n              &quot;totalAffectedObjectsCount&quot;: 6\r\n            },\r\n            {\r\n              &quot;findingId&quot;: &quot;someFindingID#2145016&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;hostC.corp.somedomain.org&quot;\r\n              ],\r\n              &quot;totalAffectedObjectsCount&quot;: 1\r\n            },\r\n            {\r\n              &quot;findingId&quot;: &quot;someFindingID#67129&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;hostD.corp.somedomain.org&quot;\r\n              ],\r\n              &quot;totalAffectedObjectsCount&quot;: 4\r\n            },\r\n            {\r\n              &quot;findingId&quot;: &quot;someFindingID#67774&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;hostA.corp.somedomain.org&quot;\r\n              ],\r\n              &quot;totalAffectedObjectsCount&quot;: 6\r\n            }\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nThe following command (though the first result returns null) will give the list of **findingID** and its associated host(s):\r\n\r\n    cat test | jq -r &#39;.data[] | .. | &quot;\\(.findingId?) \\(.products?)&quot;&#39;\r\n    null null\r\n    someFindingID#84209 [&quot;hostA.corp.somedomain.org&quot;,&quot;hostB.corp.somedomain.org&quot;]\r\n    someFindingID#2145016 [&quot;hostC.corp.somedomain.org&quot;,&quot;hostE.corp.somedomain.org&quot;,&quot;hostG.corp.somedomain.org&quot;]\r\n    someFindingID#67129 [&quot;hostD.corp.somedomain.org&quot;]\r\n    someFindingID#67774 [&quot;hostA.corp.somedomain.org&quot;]\r\n\r\nWhat I&#39;d like to achieve is to loop through each values and pass the **findingId** &amp; **products** as arguments in a bash script.\r\n\r\nThe following:\r\n\r\n    someFindingID#84209 [&quot;hostA.corp.somedomain.org&quot;,&quot;hostB.corp.somedomain.org&quot;]\r\n    someFindingID#2145016 [&quot;hostC.corp.somedomain.org&quot;,&quot;hostE.corp.somedomain.org&quot;,&quot;hostG.corp.somedomain.org&quot;]\r\n    someFindingID#67129 [&quot;hostD.corp.somedomain.org&quot;]\r\n    someFindingID#67774 [&quot;hostA.corp.somedomain.org&quot;]\r\n\r\nWould result in:\r\n\r\n    ./somescript.sh someFindingID#84209 hostA.corp.somedomain.org\r\n    ./somescript.sh someFindingID#84209 hostB.corp.somedomain.org\r\n    ./somescript.sh someFindingID#2145016 hostC.corp.somedomain.org\r\n    ./somescript.sh someFindingID#2145016 hostE.corp.somedomain.org\r\n    ./somescript.sh someFindingID#2145016 hostG.corp.somedomain.org\r\n    ./somescript.sh someFindingID#67129 hostD.corp.somedomain.org\r\n    [...]\r\n\r\nAny help/guidance on how to achieve the above would be greatly appreciated!\r\n\r\nThanks,",
        "link": "https://stackoverflow.com/questions/70353107/jq-how-to-loop-through-sub-arrays",
        "title": "jq: how to loop through sub arrays"
    },
    {
        "tags": [
            "json",
            "parsing",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639523209,
                "last_edit_date": 1639523209,
                "creation_date": 1639522907,
                "answer_id": 70356577,
                "question_id": 70356481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n```sh\r\njq -r &#39;.[] | .ip + &quot;:\\(.services[] | select(.service_name == &quot;HTTP&quot;) | .port)&quot;&#39;\r\n```\r\n```\r\n1.11.11.111:888\r\n2.22.22.222:4444\r\n2.22.22.222:8085\r\n```\r\n[Demo](https://jqplay.org/s/ZK1U7svFdU)",
                "title": "Export needed output (fields in right order) from JSON file using &quot;jq&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1639548731,
        "creation_date": 1639522237,
        "last_edit_date": 1639548731,
        "question_id": 70356481,
        "body_markdown": "I try to grep needed fields and parameters from json file with jq. There is json file:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;ip&quot;: &quot;1.11.11.111&quot;,\r\n    &quot;services&quot;: [\r\n      {\r\n        &quot;port&quot;: 22,\r\n        &quot;service_name&quot;: &quot;SSH&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      },\r\n      {\r\n        &quot;port&quot;: 888,\r\n        &quot;service_name&quot;: &quot;HTTP&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      },\r\n      {\r\n        &quot;port&quot;: 999,\r\n        &quot;service_name&quot;: &quot;FTP&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      },\r\n      {\r\n        &quot;port&quot;: 17000,\r\n        &quot;service_name&quot;: &quot;UNKNOWN&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      }\r\n    ],\r\n    &quot;location&quot;: {\r\n      &quot;continent&quot;: &quot;Europe&quot;,\r\n      &quot;country&quot;: &quot;France&quot;,\r\n      &quot;country_code&quot;: &quot;FR&quot;,\r\n      &quot;city&quot;: &quot;Cagnes-sur-Mer&quot;,\r\n      &quot;postal_code&quot;: &quot;06800&quot;,\r\n      &quot;timezone&quot;: &quot;Europe/Paris&quot;,\r\n      &quot;province&quot;: &quot;Provence-Alpes-C&#244;te d&#39;Azur&quot;,\r\n      &quot;coordinates&quot;: {\r\n        &quot;latitude&quot;: 43.6627,\r\n        &quot;longitude&quot;: 7.1545\r\n      },\r\n      &quot;registered_country&quot;: &quot;France&quot;,\r\n      &quot;registered_country_code&quot;: &quot;FR&quot;\r\n    },\r\n    &quot;autonomous_system&quot;: {\r\n      &quot;asn&quot;: 3215,\r\n      &quot;description&quot;: &quot;France Telecom - Orange&quot;,\r\n      &quot;bgp_prefix&quot;: &quot;2.15.0.0/16&quot;,\r\n      &quot;name&quot;: &quot;France Telecom - Orange&quot;,\r\n      &quot;country_code&quot;: &quot;FR&quot;\r\n    },\r\n    &quot;operating_system&quot;: {\r\n      &quot;uniform_resource_identifier&quot;: &quot;cpe:2.3:o:*:linux:*:*:*:*:*:*:*:*&quot;,\r\n      &quot;part&quot;: &quot;o&quot;,\r\n      &quot;product&quot;: &quot;linux&quot;,\r\n      &quot;source&quot;: &quot;OSI_TRANSPORT_LAYER&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;ip&quot;: &quot;2.22.22.222&quot;,\r\n    &quot;services&quot;: [\r\n      {\r\n        &quot;port&quot;: 4444,\r\n        &quot;service_name&quot;: &quot;HTTP&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      },\r\n      {\r\n        &quot;port&quot;: 8085,\r\n        &quot;service_name&quot;: &quot;HTTP&quot;,\r\n        &quot;transport_protocol&quot;: &quot;TCP&quot;\r\n      }\r\n    ],\r\n    &quot;location&quot;: {\r\n      &quot;continent&quot;: &quot;Europe&quot;,\r\n      &quot;country&quot;: &quot;United Kingdom&quot;,\r\n      &quot;country_code&quot;: &quot;GB&quot;,\r\n      &quot;city&quot;: &quot;Scunthorpe&quot;,\r\n      &quot;postal_code&quot;: &quot;DN16&quot;,\r\n      &quot;timezone&quot;: &quot;Europe/London&quot;,\r\n      &quot;province&quot;: &quot;England&quot;,\r\n      &quot;coordinates&quot;: {\r\n        &quot;latitude&quot;: 53.5651,\r\n        &quot;longitude&quot;: -0.6375\r\n      },\r\n      &quot;registered_country&quot;: &quot;United Kingdom&quot;,\r\n      &quot;registered_country_code&quot;: &quot;GB&quot;\r\n    },\r\n    &quot;autonomous_system&quot;: {\r\n      &quot;asn&quot;: 12576,\r\n      &quot;description&quot;: &quot;EE Ltd&quot;,\r\n      &quot;bgp_prefix&quot;: &quot;2.25.0.0/16&quot;,\r\n      &quot;name&quot;: &quot;EE Ltd&quot;,\r\n      &quot;country_code&quot;: &quot;GB&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nSo, I want to select HTTP ports of each ip, and output in that format:\r\n\r\n```\r\n1.11.11.111:888\r\n2.22.22.222:4444\r\n2.22.22.222:8085\r\n```\r\n\r\nI tried to do next commands:\r\n\r\n```\r\njq &#39;.[].ip, .[].services[0].port, .[].services[0].service_name&#39;\r\n```\r\n\r\nbut I received:\r\n\r\n```\r\n&quot;1.11.11.111&quot;\r\n&quot;2.22.22.222&quot;\r\n&quot;3.33.33.333&quot;\r\n6001\r\n22\r\n4444\r\n3333\r\n2082\r\n80\r\n80\r\n9180\r\n&quot;HTTP&quot;\r\n&quot;SSH&quot;\r\n&quot;HTTP&quot;\r\n&quot;FTP&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/70356481/export-needed-output-fields-in-right-order-from-json-file-using-jq",
        "title": "Export needed output (fields in right order) from JSON file using &quot;jq&quot;"
    },
    {
        "tags": [
            "bash",
            "devops",
            "jq",
            "github-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639567858,
                "post_id": 70361486,
                "comment_id": 124380192,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23390757,
                    "reputation": 73,
                    "user_id": 17455441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6934ff71ff3fed20d2fe1d26220b52d?s=256&d=identicon&r=PG",
                    "display_name": "kvelev",
                    "link": "https://stackoverflow.com/users/17455441/kvelev"
                },
                "reply_to_user": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639570019,
                "post_id": 70361486,
                "comment_id": 124381044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23390757,
                    "reputation": 73,
                    "user_id": 17455441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6934ff71ff3fed20d2fe1d26220b52d?s=256&d=identicon&r=PG",
                    "display_name": "kvelev",
                    "link": "https://stackoverflow.com/users/17455441/kvelev"
                },
                "reply_to_user": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639570358,
                "post_id": 70361486,
                "comment_id": 124381160,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639571065,
                "post_id": 70361486,
                "comment_id": 124381398,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23390757,
                    "reputation": 73,
                    "user_id": 17455441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e6934ff71ff3fed20d2fe1d26220b52d?s=256&d=identicon&r=PG",
                    "display_name": "kvelev",
                    "link": "https://stackoverflow.com/users/17455441/kvelev"
                },
                "reply_to_user": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639573507,
                "post_id": 70361486,
                "comment_id": 124382416,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2339925,
                    "reputation": 16193,
                    "user_id": 2051454,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/sZBFW.jpg?s=256",
                    "display_name": "Software Engineer",
                    "link": "https://stackoverflow.com/users/2051454/software-engineer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639573589,
                "post_id": 70361486,
                "comment_id": 124382457,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655879853,
                "creation_date": 1655879853,
                "answer_id": 72710734,
                "question_id": 70361486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It means it can not find the key. Check that your `query` matches the structure of the `json` document.",
                "title": "Cannot index string with string &quot;name&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1655879853,
        "creation_date": 1639561587,
        "last_edit_date": 1639566773,
        "question_id": 70361486,
        "body_markdown": "I have a script that imports bunch of github info as .tf files using jq\r\n\r\n    function get_team_repos() {\r\n        log &quot;Importing team repositories...&quot; &quot;INFO&quot;\r\n        for PAGE in $(limit_team_pagination); do\r\n    \r\n            for i in $(curl --silent -s -u &quot;$USERNAME:$GITHUB_TOKEN&quot; &quot;${API_URL_PREFIX}/orgs/$ORG/teams/${TEAM_ID}/repos?page=${PAGE}&amp;per_page=100&quot; | jq -M -r &#39;sort_by(.name) | .[] | .name&#39;); do\r\n                TERRAFORM_TEAM_REPO_NAME=$(echo &quot;${i}&quot; | tr &quot;.&quot; &quot;-&quot;)\r\n                log &quot;Team repo: $TERRAFORM_TEAM_REPO_NAME&quot; &quot;INFO&quot;\r\n                TEAM_NAME=$(curl --silent -s -u &quot;$USERNAME:$GITHUB_TOKEN&quot; &quot;${API_URL_PREFIX}/orgs/$ORG/teams&quot; -H &quot;Accept: application/vnd.github.v3+json&quot; | jq -M -r &#39;sort_by(.name) | .[] | .name&#39; | tr &quot; &quot; &quot;_&quot; | tr &quot;/&quot; &quot;_&quot;)\r\n                log &quot;Working on $TEAM_NAME&quot; &quot;INFO&quot;\r\n                PERMS_PAYLOAD=$(curl --silent -s -u &quot;$USERNAME:$GITHUB_TOKEN&quot; &quot;${API_URL_PREFIX}/orgs/${ORG}/teams/${TEAM_ID}/repos&quot; -H &quot;Accept: application/vnd.github.v3.repository+json&quot;)\r\n                ADMIN_PERMS=$(echo &quot;$PERMS_PAYLOAD&quot; | jq -M -r .permissions.admin)\r\n                PUSH_PERMS=$(echo &quot;$PERMS_PAYLOAD&quot; | jq -M -r .permissions.push)\r\n                PULL_PERMS=$(echo &quot;$PERMS_PAYLOAD&quot; | jq -M -r .permissions.pull)\r\n    \r\n                if [[ &quot;${ADMIN_PERMS}&quot; == &quot;true&quot; ]]; then\r\n                    cat &gt;&gt;&quot;github-teams-${TEAM_NAME}.tf&quot; &lt;&lt;EOF\r\nWhich prompts the following error:\r\n\r\n    jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;name&quot;\r\n    ╷\r\n    │ Error: Attribute name required\r\n    │ \r\n    │   on &lt;import-address&gt; line 1:\r\n    │    1: github_team_repository.-\r\n    │ \r\n    │ Dot must be followed by attribute name.\r\n    ╵\r\n\r\nDoes anyone have any idea?",
        "link": "https://stackoverflow.com/questions/70361486/cannot-index-string-with-string-name",
        "title": "Cannot index string with string &quot;name&quot;"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8919214,
                    "reputation": 1037,
                    "user_id": 6656508,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://lh5.googleusercontent.com/-Cw00Euo9ls4/AAAAAAAAAAI/AAAAAAAAAD0/AxPxZMOm4qc/s256-rj/photo.jpg",
                    "display_name": "Logan Lee",
                    "link": "https://stackoverflow.com/users/6656508/logan-lee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1651540199,
                "post_id": 70361958,
                "comment_id": 127383599,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1639563769,
                "creation_date": 1639563769,
                "answer_id": 70362009,
                "question_id": 70361958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several issues with your script. Generally, this should work (but still needs improvement on certain levels):\r\n```sh\r\nJSON=&#39;[{&quot;name&quot;: &quot;Jon&quot;, &quot;class&quot;: &quot;senior&quot;}]&#39;\r\necho &quot;$JSON&quot; | jq &#39;. += [{&quot;new_key&quot;: &quot;new_value&quot;}]&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;Jon&quot;,\r\n    &quot;class&quot;: &quot;senior&quot;\r\n  },\r\n  {\r\n    &quot;new_key&quot;: &quot;new_value&quot;\r\n  }\r\n]\r\n```",
                "title": "append json array using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639568541,
                "creation_date": 1639568541,
                "answer_id": 70363088,
                "question_id": 70361958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This question is likely a duplicate of [Add new element to existing JSON array with jq](https://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq).\r\n\r\nAnyway as a shortcut, here is how you do it without piping the source JSON array:\r\n\r\n```sh\r\nJSON=&#39;[{&quot;name&quot;: &quot;Jon&quot;, &quot;class&quot;: &quot;senior&quot;}]&#39;\r\njq --null-input --argjson  a &quot;$JSON&quot; &#39;$a  + [{&quot;name&quot; : &quot;santa&quot;, &quot;class&quot; : &quot;christmas&quot; }]&#39;\r\n```",
                "title": "append json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1639568755,
        "creation_date": 1639563561,
        "question_id": 70361958,
        "body_markdown": "I have a json file which I am fetching from consul and the results are very simple:\r\n\r\n`[\r\n   { &quot;name&quot; : Jon&quot;, &quot;class&quot; : &quot;senior&quot; }\r\n]`\r\n\r\nI want to update the array with below json:\r\n\r\n`{ &quot;name&quot; : santa&quot;, &quot;class&quot; : &quot;christmas&quot; }`\r\n\r\nand the output should be:\r\n\r\n`[\r\n   { &quot;name&quot; : Jon&quot;, &quot;class&quot; : &quot;senior&quot; }, \r\n   { &quot;name&quot; : santa&quot;, &quot;class&quot; : &quot;christmas&quot; }\r\n]`\r\n\r\nThis looks very simple but I am unable to do it till now. \r\n\r\nthis is what I have been trying with `jq`:\r\n```\r\nJSON=[{ &quot;name&quot; : Jon&quot;, &quot;class&quot; : &quot;senior&quot; }]\r\n\r\necho $JSON | jq &#39;.[] += { &quot;new_key&quot; : &quot;new_value&quot; }&#39;\r\n```\r\nI followed some answers on stackoverflow but most of them are about adding a single element.",
        "link": "https://stackoverflow.com/questions/70361958/append-json-array-using-jq",
        "title": "append json array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639580553,
                "last_edit_date": 1639580553,
                "creation_date": 1639580104,
                "answer_id": 70365787,
                "question_id": 70365491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `.data` and `.pool` are the only keys in the json files, you can use \r\n```\r\njq -n &#39;{ data: { pools: [inputs.data.pools] | add } }&#39; result0 result1\r\n```\r\n\r\nThis will create the desired output:\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;pools&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;4&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\nRegarding the `inputs` keyword, consider reading [JQ&#39;s docs on this part](https://stedolan.github.io/jq/manual/#inputs).",
                "title": "How to combine 2 JSON objects into one with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639580553,
        "creation_date": 1639578812,
        "question_id": 70365491,
        "body_markdown": "I have two JSON objects in two files (result_0.json and result_1.json) which look like this\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;pools&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nand like this:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;pools&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;3&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;4&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nWhat I would like to get looks like this:\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;pools&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;2&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;3&quot;\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;4&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nHow can it be done? I tried\r\n\r\n    jq -s add result_0.json result_1.json \r\n\r\nbut it just overwrites the values in result_0.json with the values of result_1.json.\r\n",
        "link": "https://stackoverflow.com/questions/70365491/how-to-combine-2-json-objects-into-one-with-jq",
        "title": "How to combine 2 JSON objects into one with jq?"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "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": 1639600425,
                "post_id": 70369094,
                "comment_id": 124393240,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23172724,
                    "reputation": 63,
                    "user_id": 17271718,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/436217c631c821fa7f978d35abe4e03f?s=256&d=identicon&r=PG",
                    "display_name": "pi314",
                    "link": "https://stackoverflow.com/users/17271718/pi314"
                },
                "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": 1639602378,
                "post_id": 70369094,
                "comment_id": 124393926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 249404,
                    "reputation": 612,
                    "user_id": 525411,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c055c2fa825f58c4a8bf896ea70e144e?s=256&d=identicon&r=PG",
                    "display_name": "Colin Fraizer",
                    "link": "https://stackoverflow.com/users/525411/colin-fraizer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639613394,
                "post_id": 70369094,
                "comment_id": 124396730,
                "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": 1639662782,
                "post_id": 70369094,
                "comment_id": 124409896,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639604045,
                "creation_date": 1639604045,
                "answer_id": 70370592,
                "question_id": 70369094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can either use an `if ... then ... else ... end` construct, or `//`. For example:\r\n\r\n```\r\n.Reservations[].Instances[]\r\n| {IP: .PrivateIpAddress} + \r\n  ({Ambiente: (.Tags[]|select(.Key==&quot;Environment&quot;)|.Value)}\r\n   // null)\r\n```",
                "title": "jq output is empty when tag name does not exist"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1639664232,
                "last_edit_date": 1639664232,
                "creation_date": 1639662701,
                "answer_id": 70380166,
                "question_id": 70369094,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s assume this input:\r\n\r\n```\r\n{\r\n  &quot;Reservations&quot;: [\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;PrivateIpAddress&quot;: &quot;10.0.0.1&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;Balance-OTA-SS_a&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Environment&quot;,\r\n              &quot;Value&quot;: &quot;alpha&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;PrivateIpAddress&quot;: &quot;10.0.0.2&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;Balance-OTA-SS_a&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThis is the format returned by describe-instances, but with all the irrelevant fields removed.\r\n\r\nNote that tags is always a list of objects, each of which has a `Key` and a `Value`. This format is _perfect_ for [`from_entries`][1], which can transform this list of tags into a convenient mapping object. Try this:\r\n\r\n```\r\n.Reservations[].Instances[] |\r\n{\r\n  IP: .PrivateIpAddress,\r\n  Ambiente: (.Tags|from_entries.Environment)\r\n}\r\n```\r\n```\r\n{&quot;IP&quot;:&quot;10.0.0.1&quot;,&quot;Ambiente&quot;:&quot;alpha&quot;}\r\n{&quot;IP&quot;:&quot;10.0.0.2&quot;,&quot;Ambiente&quot;:null}\r\n```\r\n\r\n[1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n\r\n---\r\n\r\nThat answers how to do it. But you probably want to understand why your approach didn&#39;t work.\r\n\r\n```\r\n.Reservations[].Instances[] |\r\n{\r\n  IP: .PrivateIpAddress,\r\n  Ambiente: (.Tags[]|select(.Key==&quot;Environment&quot;)|.Value)\r\n}\r\n```\r\n\r\nThe `.[]` filter you&#39;re using on the tags can return zero or multiple results. Similarly, the `select` filter can eliminate some or all items. When you apply this _inside_ an object constructor (the expression from `{` to `}`), you&#39;re causing that whole object to be created a variable number of times. You need to be very careful where you use these filters, because often that&#39;s not what you want at all. Often you instead want to do one of the following:\r\n\r\n* Wrap the expression that returns multiple results in an array constructor `[ ... ]`. That way instead of outputting the parent object potentially zero or multiple times, you output it once containing an array that potentially has zero or multiple items. E.g.\r\n  ```\r\n  [.Tags[]|select(.Key==&quot;Environment&quot;)]\r\n  ```\r\n* Apply `map` to the array to keep it an array but process its contents, e.g.\r\n  ```\r\n  .Tags|map(select(.Key==&quot;Environment&quot;))\r\n  ```\r\n* Apply `first(expr)` to capture only the first value emitted by the expression. If the expression might emit zero items, you can use the comma operator to provide a default, e.g.\r\n  ```\r\n  first((.Tags[]|select(.Key==&quot;Environment&quot;)),null)\r\n  ```\r\n* Apply some other array-level function, such as `from_entries`.\r\n  ```\r\n  .Tags|from_entries.Environment\r\n  ```",
                "title": "jq output is empty when tag name does not exist"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639664232,
        "creation_date": 1639595241,
        "last_edit_date": 1639662868,
        "question_id": 70369094,
        "body_markdown": "When I run the jq command to parse a json document from the amazon cli I have the following problem.\r\n\r\nI’m parsing through the IP address and a tag called &quot;Enviroment&quot;. The enviroment tag in the instance does not exist therefore it does not throw me any result.\r\n\r\nHere&#39;s an example of the relevant output returned by the AWS CLI\r\n\r\n```\r\n{\r\n  &quot;Reservations&quot;: [\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;PrivateIpAddress&quot;: &quot;10.0.0.1&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;Balance-OTA-SS_a&quot;\r\n            },\r\n            {\r\n              &quot;Key&quot;: &quot;Environment&quot;,\r\n              &quot;Value&quot;: &quot;alpha&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;PrivateIpAddress&quot;: &quot;10.0.0.2&quot;,\r\n          &quot;Tags&quot;: [\r\n            {\r\n              &quot;Key&quot;: &quot;Name&quot;,\r\n              &quot;Value&quot;: &quot;Balance-OTA-SS_a&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI’m running the following command\r\n\r\n```\r\naws ec2 describe-instances --filters &quot;Name=tag:Name,Values=Balance-OTA-SS_a&quot; | jq -c &#39;.Reservations[].Instances[] | ({IP: .PrivateIpAddress, Ambiente: (.Tags[]|select(.Key==&quot;Environment&quot;)|.Value)})&#39;\r\n\r\n## output\r\nempty\r\n\r\n```\r\nHow do I show the IP address in the output of the command even if the enviroment tag does not exist?\r\n\r\nRegards,",
        "link": "https://stackoverflow.com/questions/70369094/jq-output-is-empty-when-tag-name-does-not-exist",
        "title": "jq output is empty when tag name does not exist"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1639670513,
                "creation_date": 1639670513,
                "answer_id": 70382098,
                "question_id": 70381928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re almost there. Use `del`, `IN` and a capital `B` in `eBooks` :)\r\n```sh\r\njq &#39;del(.eBooks[] | select(.language | IN(&quot;Pascal&quot;, &quot;Python&quot;)))&#39; ebooks.json\r\n```\r\n```json\r\n{\r\n  &quot;eBooks&quot;: [\r\n    {\r\n      &quot;language&quot;: &quot;SQL&quot;,\r\n      &quot;edition&quot;: &quot;second&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/1n2KS80ros)",
                "title": "Remove multiple entries from an array of objects using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639670513,
        "creation_date": 1639669812,
        "last_edit_date": 1639670149,
        "question_id": 70381928,
        "body_markdown": "I have the following json and want to remove multiple entries from the ebooks array if they are not in the following array [&quot;Pascal&quot;, &quot;Python&quot;] (will eventually be dynamic array, this is just for example)\r\n\r\n```\r\n{\r\n   &quot;eBooks&quot;:[\r\n      {\r\n\r\n         &quot;language&quot;:&quot;Pascal&quot;,\r\n         &quot;edition&quot;:&quot;third&quot;\r\n      },\r\n      {\r\n         &quot;language&quot;:&quot;Python&quot;,\r\n         &quot;edition&quot;:&quot;four&quot;\r\n      },\r\n      {\r\n         &quot;language&quot;:&quot;SQL&quot;,\r\n         &quot;edition&quot;:&quot;second&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nwas hoping to do something like this, which if it worked would delete last one containing the SQL because it&#39;s not in the array, but this doesn&#39;t work\r\n\r\n```\r\njq &#39;.ebooks[] | select ( .language | in([&quot;Pascal&quot;, &quot;Python&quot;]))&#39; ebooks.json\r\n```",
        "link": "https://stackoverflow.com/questions/70381928/remove-multiple-entries-from-an-array-of-objects-using-jq",
        "title": "Remove multiple entries from an array of objects using jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "npm",
            "jq",
            "aws-step-functions"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2441830,
                    "reputation": 3407,
                    "user_id": 11305581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ok842.png?s=256",
                    "display_name": "alexis-donoghue",
                    "link": "https://stackoverflow.com/users/11305581/alexis-donoghue"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1639745118,
                "post_id": 70390063,
                "comment_id": 124433286,
                "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": 1,
                "creation_date": 1639829279,
                "post_id": 70390063,
                "comment_id": 124451361,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15005975,
                    "reputation": 425,
                    "user_id": 10832040,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TjfhP.png?s=256",
                    "display_name": "Pulasthi Aberathne",
                    "link": "https://stackoverflow.com/users/10832040/pulasthi-aberathne"
                },
                "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": 1639832784,
                "post_id": 70390063,
                "comment_id": 124452006,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15005975,
                    "reputation": 425,
                    "user_id": 10832040,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/TjfhP.png?s=256",
                    "display_name": "Pulasthi Aberathne",
                    "link": "https://stackoverflow.com/users/10832040/pulasthi-aberathne"
                },
                "reply_to_user": {
                    "account_id": 2441830,
                    "reputation": 3407,
                    "user_id": 11305581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Ok842.png?s=256",
                    "display_name": "alexis-donoghue",
                    "link": "https://stackoverflow.com/users/11305581/alexis-donoghue"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639832929,
                "post_id": 70390063,
                "comment_id": 124452041,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640172817,
                "creation_date": 1640172817,
                "answer_id": 70448396,
                "question_id": 70390063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**It is a `jq` installation issue. Download and install the `jq` under the following steps. &lt;br /&gt;**\r\n&gt; 1. Open `git bash` with the administration privileges. (In Linx based system run with the sudo privileges)\r\n\r\n&gt; 2. Run the following command &lt;br /&gt; `curl -L -o /usr/bin/jq.exe https://github.com/stedolan/jq/releases/latest/download/jq-win64.exe`\r\n\r\n\r\n***Replace the link with an appropriate one for lnux base systems***",
                "title": "Deployment issue in AWS Step Functions &quot;error: unknown command &#39;.Account&#39; &quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1640172817,
        "creation_date": 1639728417,
        "question_id": 70390063,
        "body_markdown": "I am trying to deploy a series of AWS step functions through a `setup.sh` file. &lt;br /&gt;\r\nI have successfully tested the step functions in a test environment and there are no issues in the source code. &lt;br /&gt;\r\n##### This is the Deployment Code\r\n\r\n    ./setup.sh &lt;data dictionary command&gt; &lt;step function name&gt;\r\n\r\n##### Output looks like this\r\n```\r\n *** Step Function Json Uploading to AWS *** \r\n\r\nTENANT : &lt;Tenant Name&gt;\r\nEX_AWS_REGION : eu-west-2\r\nEX_AWS_ACCT_ALIAS : &lt;Environment&gt;\r\n\r\nFile Name : &lt;Step Function File Path&gt;\r\n\r\n/path/step_functions\r\nerror: unknown command &#39;.Account&#39;\r\nException ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;cp1252&#39;&gt;\r\nOSError: [Errno 22] Invalid argument\r\n/directory_path/\r\n```\r\n\r\n##### In `setup.sh`\r\n**.Account** has been used as follows \r\n```\r\ndummy=`aws sts get-caller-identity | jq .Account`\r\n```\r\n\r\njq has been installed globally and no issues in the `setup.sh` as well. ",
        "link": "https://stackoverflow.com/questions/70390063/deployment-issue-in-aws-step-functions-error-unknown-command-account",
        "title": "Deployment issue in AWS Step Functions &quot;error: unknown command &#39;.Account&#39; &quot;"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639736230,
                "creation_date": 1639736230,
                "answer_id": 70391599,
                "question_id": 70391566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure if this is what you are looking for, but wouldn&#39;t simply `... | select(.type == &quot;A&quot;)` do the trick?\r\n```sh\r\n... | jq &#39;.rrsets[] | select(.type == &quot;A&quot;)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;comments&quot;: [],\r\n  &quot;name&quot;: &quot;name1.&quot;,\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;content&quot;: &quot;10.10.10.10&quot;,\r\n      &quot;disabled&quot;: false\r\n    }\r\n  ],\r\n  &quot;ttl&quot;: 60,\r\n  &quot;type&quot;: &quot;A&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/CEGIy_My8m)\r\n\r\nAnd then just get the `.name` if you want only that (using `-r` to get rid of the JSON formatting):\r\n```sh\r\n... | jq -r &#39;.rrsets[] | select(.type == &quot;A&quot;).name&#39;\r\n```\r\n```\r\nname1.\r\n```\r\n[Demo](https://jqplay.org/s/ukZR0rAqlF)\r\n",
                "title": "Parsing on jq with_entries"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639740046,
        "creation_date": 1639736079,
        "last_edit_date": 1639740046,
        "question_id": 70391566,
        "body_markdown": "I have the following data\r\nCommand output:\r\n\r\n    | jq &#39;.rrsets[]&#39;\r\n```json    \r\n{\r\n  &quot;comments&quot;: [],\r\n  &quot;name&quot;: &quot;name1.&quot;,\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;content&quot;: &quot;10.10.10.10&quot;,\r\n      &quot;disabled&quot;: false\r\n    }\r\n  ],\r\n  &quot;ttl&quot;: 60,\r\n  &quot;type&quot;: &quot;A&quot;\r\n}\r\n{\r\n  &quot;comments&quot;: [],\r\n  &quot;name&quot;: &quot;name2.&quot;,\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;content&quot;: &quot;20.20.20.20&quot;,\r\n      &quot;disabled&quot;: false\r\n    }\r\n  ],\r\n  &quot;ttl&quot;: 60,\r\n  &quot;type&quot;: &quot;CNAME&quot;\r\n}\r\n\r\n```\r\nI want to get names where type is A.\r\nHelp, tell me how to do this?\r\n\r\n\r\n    | jq &#39;.rrsets[] | with_entries(select(.key== &quot;name&quot;, .value == &quot;A&quot;))&#39;\r\n```json \r\n{\r\n  &quot;name&quot;: &quot;name1.&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;name2.&quot;,\r\n  &quot;type&quot;: &quot;A&quot;\r\n}\r\n```\r\nDisplays all the lines, but I only need where type = A\r\n",
        "link": "https://stackoverflow.com/questions/70391566/parsing-on-jq-with-entries",
        "title": "Parsing on jq with_entries"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "couchbase"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1639742985,
                "post_id": 70392901,
                "comment_id": 124432631,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3918263,
                    "reputation": 432,
                    "user_id": 3241554,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5edc71d9f6f4ac1d6cfeffcae8630d90?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sagar verma",
                    "link": "https://stackoverflow.com/users/3241554/sagar-verma"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639976876,
                "post_id": 70392901,
                "comment_id": 124476714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639978183,
                "creation_date": 1639978183,
                "answer_id": 70417704,
                "question_id": 70392901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " 1. Using extra parens, it helped me to create array.\r\n 2. Using the below sed command over array item variable, i was able to remove extra line from it.\r\n\r\n```price=$(echo &quot;$price&quot; | sed &#39;s/^[ \\n]*//;s/[ \\n]*$//&#39;)```",
                "title": "Assigning the values to array from jq and iterate over the values using cb commands"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1639978183,
        "creation_date": 1639742687,
        "last_edit_date": 1639847370,
        "question_id": 70392901,
        "body_markdown": "I have the below json in a file from which I wanted to take the &quot;ids&quot; from all price object and put into an array variable. \r\n```json\r\n{\r\n  &quot;documentType&quot;: &quot;Prices&quot;,\r\n  &quot;fullCharges&quot;: [\r\n    {\r\n      &quot;ResourceId&quot;: null,\r\n      &quot;price&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;8ddaaabc92bc&quot;\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;123&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;price&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;326f0f273258&quot;\r\n      },\r\n      &quot;product&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;123&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;createdBy&quot;: &quot;test&quot;,\r\n  &quot;createdOn&quot;: &quot;2021-10-05T00:00:55Z&quot;,\r\n  &quot;currentSeqNum&quot;: 2\r\n}\r\n```\r\nI am using the below query but the result is coming in the proper way. \r\n\r\n`priceIds=$(jq -r .fullCharges[].price.id ${file})`\r\n\r\nUsing above command, it is behaving like a single value, not like array. If I print the priceId value it is only showing the last value.\r\n\r\n`326f0f273258 instead of 8ddaaabc92bc 326f0f273258`\r\n\r\nAnd when I am looping over it, again it is behaving as a single value.\r\n\r\n    for price in &quot;${priceIds[@]}&quot;\r\n    do\r\n      printf &quot;$price&quot;\r\n      \r\n      cbq -u Administrator -p Administrator  -e &quot;http://localhost:8093&quot;  --script=&quot;select * FROM \\`com.src.test.price\\` where docId==\\&quot;$price\\&quot;;&quot;\r\n      \r\n    done\r\n\r\nOutput command of above loop: ```select * FROM `com.src.test.price` where documentId==&quot;8ddaaabc92bc 326f0f273258&quot;;```\r\n\r\nThere should be 2 command like these\r\n\r\n    select * FROM `com.src.test.price` where documentId==&quot;8ddaaabc92bc&quot;\r\n    select * FROM `com.src.test.price` where documentId==&quot;326f0f273258&quot;",
        "link": "https://stackoverflow.com/questions/70392901/assigning-the-values-to-array-from-jq-and-iterate-over-the-values-using-cb-comma",
        "title": "Assigning the values to array from jq and iterate over the values using cb commands"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2818342,
                    "reputation": 314580,
                    "user_id": 2422776,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2353050223ebecb113741c29458de4b2?s=256&d=identicon&r=PG",
                    "display_name": "Mureinik",
                    "link": "https://stackoverflow.com/users/2422776/mureinik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639743450,
                "post_id": 70393010,
                "comment_id": 124432762,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8838246,
                    "reputation": 1,
                    "user_id": 17701270,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-s1NrDGG2qa4/AAAAAAAAAAI/AAAAAAAAAAA/W4_U0CBMFWI/s256-rj/photo.jpg",
                    "display_name": "huaiqiang sun",
                    "link": "https://stackoverflow.com/users/17701270/huaiqiang-sun"
                },
                "reply_to_user": {
                    "account_id": 2818342,
                    "reputation": 314580,
                    "user_id": 2422776,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2353050223ebecb113741c29458de4b2?s=256&d=identicon&r=PG",
                    "display_name": "Mureinik",
                    "link": "https://stackoverflow.com/users/2422776/mureinik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639743576,
                "post_id": 70393010,
                "comment_id": 124432803,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1639743522,
                "creation_date": 1639743522,
                "answer_id": 70393051,
                "question_id": 70393010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries` to access field name and value of an object&#39;s items and `select` those you need:\r\n```sh\r\njq --raw-output &#39;.flags | to_entries[] | select(.value).key&#39; \r\n```\r\n```\r\nT1\r\n```\r\n[Demo](https://jqplay.org/s/wdfq4ZyO5X)",
                "title": "How to return a key if the value equal to specific value using jq in json parsing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639752209,
                "creation_date": 1639752209,
                "answer_id": 70394860,
                "question_id": 70393010,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a ruby:\r\n\r\n    ruby -r JSON -e &#39;d=JSON.parse($&lt;.read)\r\n    puts &quot;T1&quot; if d[&quot;flags&quot;][&quot;T1&quot;]\r\n    &#39; file\r\n    T1\r\n\r\n ",
                "title": "How to return a key if the value equal to specific value using jq in json parsing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1639752209,
        "creation_date": 1639743308,
        "question_id": 70393010,
        "body_markdown": "I have json file like this \r\n```\r\n{\r\n  &quot;version&quot;: &quot;4.6.0&quot;,\r\n  &quot;flags&quot;: {\r\n    &quot;T1&quot;: true,\r\n    &quot;T1c&quot;: false,\r\n    &quot;T2&quot;: false,\r\n    &quot;FLAIR&quot;: false\r\n  },\r\n  &quot;shapes&quot;: [],\r\n  &quot;imagePath&quot;: &quot;HC-002_LM-0000_aparc+aseg_1mm_bin.png&quot;,\r\n  &quot;imageData&quot;:xxxxxxxxx\r\n}\r\n```\r\nand I need the output to be \r\n```\r\nT1\r\n```\r\nas the value is true, Please suggest correct use of jq here, thanks!",
        "link": "https://stackoverflow.com/questions/70393010/how-to-return-a-key-if-the-value-equal-to-specific-value-using-jq-in-json-parsin",
        "title": "How to return a key if the value equal to specific value using jq in json parsing"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639761049,
                "post_id": 70396171,
                "comment_id": 124439443,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640037741,
                "post_id": 70396171,
                "comment_id": 124496317,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23676686,
                    "reputation": 1,
                    "user_id": 17702842,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0abf3e8b532e2080bb9675d6f8f7e2fe?s=256&d=identicon&r=PG",
                    "display_name": "Tavlin",
                    "link": "https://stackoverflow.com/users/17702842/tavlin"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640359056,
                "post_id": 70396171,
                "comment_id": 124577351,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641406175,
                "post_id": 70396171,
                "comment_id": 124798847,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641407629,
                "last_edit_date": 1641407629,
                "creation_date": 1641406011,
                "answer_id": 70597586,
                "question_id": 70396171,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To merge two objects, one can use `obj1 + obj2`. From this, it follows that `obj1 += obj2` can be used to merge an object (`obj2`) into another existing object (`obj1`).\r\n\r\nMaybe that&#39;s what you trying to use. If so, you were missing parens around the expression producing the object to merge into (causing the code to be misparsed), you have the operands to `+=` backwards, you don&#39;t actually produce the correct objects on each side of `+=` (or even objects at all), and you didn&#39;t narrow down your output (accidentally including jqtest in the output).\r\n\r\nFixed:\r\n\r\n```sh\r\njq -s &#39;\r\n    ( .[1].item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += .[0] | .[1]\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/62dEYxs2dD) on jqplay\r\n\r\nI find the following clearer (less mental overhead):\r\n\r\n```sh\r\njq -s &#39;\r\n   .[0] as $to_insert |\r\n   .[1] | ( .item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += $to_insert\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/BZyHjPEcCW)\r\n\r\nThat said, I would avoid slurping in favour of `--argfile`.\r\n\r\n```sh\r\njq --argfile to_insert jqtest.json &#39;\r\n    ( .item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += $to_insert\r\n&#39; collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/i2vtE6YEH-) on jqplay\r\n",
                "title": "Trying to merge 2 JSON documents using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641417257,
        "creation_date": 1639758541,
        "last_edit_date": 1641417257,
        "question_id": 70396171,
        "body_markdown": "I&#39;m using JQ CLI to merge JSON from document to another. The issue I am facing is that I have select by the value of a property, rather than by a numeric array index \r\n\r\nThe first file contains a chunk of  JSON jqtest.json: \r\n\r\n```json\r\n{\r\n  &quot;event&quot;: [\r\n    {\r\n      &quot;listen&quot;: &quot;test&quot;,\r\n      &quot;script&quot;: {\r\n        &quot;exec&quot;: [],\r\n        &quot;type&quot;: &quot;text/javascript&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe second file is where I want to merge the JSON into under &quot;accounts&quot; collection.json:\r\n\r\n```json\r\n{\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;accounts&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;accounts mapped&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of AccountMapped resources.&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat i am trying to do is merge it under &quot;accounts&quot; and under &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot; I use the command:\r\n\r\n```sh\r\njq -s &#39;\r\n   .[0].event += .[1].item |\r\n   map(select(.name==&quot;accounts&quot;)) |\r\n   .[].item\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\nBut when executed nothing is outputted. What am doing wrong with JQ or is there another tool i can use to accomplish this?\r\n\r\n```json\r\n{\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;accounts&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot;,\r\n          &quot;event&quot;: [\r\n            {\r\n              &quot;listen&quot;: &quot;test&quot;,\r\n              &quot;script&quot;: {\r\n                &quot;exec&quot;: [],\r\n                &quot;type&quot;: &quot;text/javascript&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;accounts mapped&quot;,\r\n          &quot;item&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Retrieves the collection of AccountMapped resources.&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70396171/trying-to-merge-2-json-documents-using-jq",
        "title": "Trying to merge 2 JSON documents using JQ"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1639762879,
                "post_id": 70396812,
                "comment_id": 124440033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 92615,
                    "reputation": 909,
                    "user_id": 253756,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/f976e87f46cda821f4b339938ae17621?s=256&d=identicon&r=PG",
                    "display_name": "Kane",
                    "link": "https://stackoverflow.com/users/253756/kane"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639763114,
                "post_id": 70396812,
                "comment_id": 124440104,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639763797,
                "post_id": 70396812,
                "comment_id": 124440324,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 92615,
                    "reputation": 909,
                    "user_id": 253756,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/f976e87f46cda821f4b339938ae17621?s=256&d=identicon&r=PG",
                    "display_name": "Kane",
                    "link": "https://stackoverflow.com/users/253756/kane"
                },
                "reply_to_user": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639763859,
                "post_id": 70396812,
                "comment_id": 124440341,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14373745,
                    "reputation": 577,
                    "user_id": 10382744,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Z4sP3.gif?s=256",
                    "display_name": "masterguru",
                    "link": "https://stackoverflow.com/users/10382744/masterguru"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639767304,
                "post_id": 70396812,
                "comment_id": 124441377,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639768340,
                "post_id": 70396812,
                "comment_id": 124441685,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1639769957,
                "post_id": 70396812,
                "comment_id": 124442157,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639773068,
                "last_edit_date": 1639773068,
                "creation_date": 1639771878,
                "answer_id": 70398423,
                "question_id": 70396812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quick jq lesson  \r\n\\===========  \r\n\r\njq filters are applied like this:  \r\n`jq -r &#39;.name_of_json_field_0 &lt;optional filter&gt;, .name_of_json_field_1 &lt;optional filter&gt;&#39;`  \r\nand so on and so forth. A single dot is the simplest filter; it leaves the data field untouched. \r\n\r\n`jq -r &#39;.name_of_field .&#39;`\r\n\r\nYou may also leave the filter field untouched for the same effect.\r\nIn your case:\r\n`jq -r &#39;.name, .description&#39;`\r\nwill extract the values of both those fields.\r\n\r\n`.[]` will unwrap an array to have the next piped filter applied to each unwrapped value. Example:  \r\n`jq -r &#39;.attributes | .[]`  \r\nextracts all trait_types objects.\r\n\r\nYou may sometime want to repackage objects in an array by surrounding the filter in brackets:  \r\n`jq -r &#39;[.name, .description, .date]`  \r\n\r\nYou may sometime want to repackage data in an object by surrounding the filter in curly braces:  \r\n`jq -r &#39;{new_field_name: .name, super_new_field_name: .description}&#39;\r\n\r\nplaying around with these, I was able to get\r\n```bash\r\njq -r &#39;[.name, .description, .date, (.attributes | [.[] | .trait_type] | @csv | gsub(&quot;,&quot;;&quot;;&quot;) | gsub(&quot;\\&quot;&quot;;&quot;&quot;)), (.attributes | [.[] | .value] | .[]] | @csv | gsub(&quot;,&quot;;&quot;;&quot;) | gsub(&quot;\\&quot;&quot;;&quot;&quot;))] | @csv&#39;\r\n```\r\nto give us:  \r\n`&quot;My Collection&quot;,&quot;This is a great collection.&quot;,1639717379161,&quot;Background;Skin;Mouth;Eyes&quot;,&quot;Sand;Dark Brown;Smile Basic;Confused&quot;`  \r\n\r\nName, description, and date were left as is, so let&#39;s break down the weird parts, one step at a time.  \r\n\r\n`.attributes | [.[] | .trait_type]`  \r\n`.[]` extracts each element of the attributes array and pipes the result of that into the next filter, which says to simply extract `trait_type`, where they are re-packaged in an array.\r\n\r\n`.attributes | [.[] | .trait_type] | @csv`  \r\nturn the array into a csv-parsable format.\r\n\r\n`(.attributes | [.[] | .trait_type] | @csv | gsub(&quot;,&quot;;&quot;;&quot;) | gsub(&quot;\\&quot;&quot;;&quot;&quot;))`  \r\nParens separate this from the rest of the evaluations, obviously. \r\nThe first `gsub` here replaces commas with semicolons so they don&#39;t get interpreted as a separate field, the second removes all extra double quotes.  ",
                "title": "How do I write a jq query to convert a JSON file to CSV?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1639773068,
        "creation_date": 1639762161,
        "last_edit_date": 1639768324,
        "question_id": 70396812,
        "body_markdown": "The JSON files look like:\r\n\r\n``` lang-js\r\n{\r\n  &quot;name&quot;: &quot;My Collection&quot;,\r\n  &quot;description&quot;: &quot;This is a great collection.&quot;,\r\n  &quot;date&quot;: 1639717379161,\r\n  &quot;attributes&quot;: [\r\n    {\r\n      &quot;trait_type&quot;: &quot;Background&quot;,\r\n      &quot;value&quot;: &quot;Sand&quot;\r\n    },\r\n    {\r\n      &quot;trait_type&quot;: &quot;Skin&quot;,\r\n      &quot;value&quot;: &quot;Dark Brown&quot;\r\n    },\r\n    {\r\n      &quot;trait_type&quot;: &quot;Mouth&quot;,\r\n      &quot;value&quot;: &quot;Smile Basic&quot;\r\n    },\r\n    {\r\n      &quot;trait_type&quot;: &quot;Eyes&quot;,\r\n      &quot;value&quot;: &quot;Confused&quot;\r\n    }\r\n  ]  \r\n}\r\n```\r\n\r\nI found [a shell script][1] that uses `jq` and has this code:\r\n\r\n``` lang-sh\r\ni=1\r\nfor eachFile in *.json; do\r\n    cat $i.json | jq -r &#39;.[] | {column1: .name, column2: .description} | [.[] | tostring] | @csv&#39; &gt; extract-$i.csv\r\n    echo &quot;converted $i of many json files...&quot;\r\n    ((i=i+1))\r\ndone\r\n```\r\n\r\nBut its output is:\r\n\r\n``` lang-shell\r\njq: error (at &lt;stdin&gt;:34): Cannot index string with string &quot;name&quot;\r\nconverted 1 of many json files...\r\n```\r\n\r\nAny suggestions on how I can make this work? Thank you!\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/52874996/253756",
        "link": "https://stackoverflow.com/questions/70396812/how-do-i-write-a-jq-query-to-convert-a-json-file-to-csv",
        "title": "How do I write a jq query to convert a JSON file to CSV?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12068358,
                    "reputation": 1,
                    "user_id": 8824584,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/392a2501dab673b2f5d1a841b23cf785?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Naranthiran ",
                    "link": "https://stackoverflow.com/users/8824584/naranthiran"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640070802,
                "post_id": 70405520,
                "comment_id": 124501781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639938857,
                "last_edit_date": 1639938857,
                "creation_date": 1639849699,
                "answer_id": 70405697,
                "question_id": 70405520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -n --arg arch &quot;$arch&quot; --arg ram &quot;$ram&quot; &#39;{&quot;System Arch&quot;:{&quot;Arch&quot;:$arch,&quot;RAM&quot;:$ram}}&#39;\r\n```\r\n\r\nor\r\n\r\n```sh\r\narch=&quot;$arch&quot; ram=&quot;$ram&quot; jq -n &#39;{&quot;System Arch&quot;:{&quot;Arch&quot;:env.arch,&quot;RAM&quot;:env.ram}}&#39;\r\n```\r\n\r\nIf the vars are already exported, the following will suffice:\r\n\r\n```sh\r\njq -n &#39;{&quot;System Arch&quot;:{&quot;Arch&quot;:env.arch,&quot;RAM&quot;:env.ram}}&#39;\r\n```\r\n\r\n---\r\n\r\nNow, it&#39;s possible that you wanted us to write you a template system. Well, you haven&#39;t provided enough details about the system you want for that, but I can provide you the basics:\r\n\r\n```sh\r\njq &#39;.. | strings | gsub(&quot;(?&lt;whole&gt;\\\\$(?&lt;var&gt;\\\\w+))&quot;; env[.var] // .whole)&#39;\r\n```\r\n\r\n(The vars need to be exported for the shell to pass them to `jq`.)\r\n\r\nI say it&#39;s the basics because it&#39;s not a complete solution.\r\n\r\n1. There&#39;s no way to produce the string `$arch` if the corresponding variable exists in the environment.\r\n1. Both `$host` and `$arch` will be replaced in `&quot;$host/$arch&quot;`, but `$host` won&#39;t be replaced in `$host_$arch`. (It will try to replace `$host_`.)\r\n1. It will happily interpolate `$HOME`, `$USER` and any other env vars passed to `jq`.\r\n",
                "title": "Update the variable values using echo and JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1639938857,
        "creation_date": 1639848177,
        "last_edit_date": 1639850686,
        "question_id": 70405520,
        "body_markdown": "I am trying to run the below command to json file.\r\n  \r\n\r\n    #arch=x86_64\r\n    \r\n    #ram=4\r\n    \r\n    #echo &#39;{&quot;System Arch&quot;:{&quot;Arch&quot;:&quot;$arch&quot;,&quot;RAM&quot;:&quot;$ram&quot;}}&#39; | jq &#39;.&#39; &gt;&gt; test.json\r\n\r\nOutput of the command:\r\n\r\n    {\r\n      &quot;System Arch&quot;: {\r\n        &quot;Arch&quot;: &quot;$arch&quot;,\r\n        &quot;RAM&quot;: &quot;$ram&quot;\r\n      }\r\n\r\nI wanted the values of $arch and $ram to be updated.\r\n\r\nThanks, \r\nNaran\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70405520/update-the-variable-values-using-echo-and-jq",
        "title": "Update the variable values using echo and JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 230492,
                    "reputation": 33658,
                    "user_id": 494134,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://i.sstatic.net/3XHKr.png?s=256",
                    "display_name": "John Gordon",
                    "link": "https://stackoverflow.com/users/494134/john-gordon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639852774,
                "post_id": 70406005,
                "comment_id": 124456220,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639853815,
                "creation_date": 1639853815,
                "answer_id": 70406205,
                "question_id": 70406005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately you say nothing about constraints (guaranteed existence of fields, lengths of arrays, etc.) regarding your data structure. Therefore, simply based on what you have provided, this will extract the contents into your desired output format:\r\n```sh\r\njq -r &#39;.[] | [.name[0] , (.List[0].Insts[0] | .DefId, .data1, .data2, .data3)] | join(&quot;,&quot;)&#39; \r\n```\r\n```csv\r\nAMIT||220000d7f728801,A1,1073741824,0,0\r\nAMIT||220000d7f728801,B1,5368709120,5368709120,5368709120\r\nAMIT||220000d7f728801,A2,1073741824,0,0\r\nAMIT||220000d7f728801,B2,10737418240,10737418240,10737418240\r\nAMIT||220000d7f728801,B3,2147483648,2147483648,2147483648\r\n```\r\n[Demo](https://jqplay.org/s/RGBeY5NBav)",
                "title": "jq: error (at &lt;stdin&gt;:125): Cannot index array with string &quot;DefId&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1639858305,
                "creation_date": 1639858305,
                "answer_id": 70406771,
                "question_id": 70406005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can dynamically walk within ***`List.Insts`*** array without error by using \r\n\r\n***`.List[].Insts | select( . != null )`*** for the returning values of ***`to_entries[]`*** \r\n\r\nwhile it&#39;s straightforward to extract the value for the ***`name`*** key.\r\n\r\nThen ***join*** the components of the formed array through use of wrapper square brackets such as\r\n\r\n```\r\njq -r &#39;to_entries[] | .value | [ .name[] , (.List[].Insts | select( . != null ) | .[] | .DefId, &quot;\\(.data1)&quot;, &quot;\\(.data2)&quot;, &quot;\\(.data3)&quot; ) ]  | join(&quot;,&quot;)&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/wwRDY77GjB)&lt;/kbd&gt;",
                "title": "jq: error (at &lt;stdin&gt;:125): Cannot index array with string &quot;DefId&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1639862053,
        "creation_date": 1639852235,
        "last_edit_date": 1639862053,
        "question_id": 70406005,
        "body_markdown": "I have below json data. Need help in parsing it.\r\n```json\r\n{\r\n  &quot;e4624072-a9a2-4181-9649-550b9cfeb7cd||220000d7f738801&quot;: {\r\n    &quot;List&quot;: [\r\n      {\r\n        &quot;Insts&quot;: [\r\n          {\r\n            &quot;DefId&quot;: &quot;A1&quot;,\r\n            &quot;data1&quot;: 1073741824,\r\n            &quot;data2&quot;: 0,\r\n            &quot;data3&quot;: 0\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;AMIT||220000d7f728801&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;e4624072-a9a2-4181-9649-550b9cfeb7cd||220000d7f738801&quot;,\r\n    &quot;endTime&quot;: 96285337200000\r\n  },\r\n  &quot;0b1141b2-c2de-47c9-aa0c-2742f92b63f2||220000d7f738801&quot;: {\r\n    &quot;List&quot;: [\r\n      {\r\n        &quot;Insts&quot;: [\r\n          {\r\n            &quot;DefId&quot;: &quot;B1&quot;,\r\n            &quot;data1&quot;: 5368709120,\r\n            &quot;data2&quot;: 5368709120,\r\n            &quot;data3&quot;: 5368709120\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;edigest&quot;: &quot;MV6shIv5NE5vWkc0cx6Q/JTwid4=&quot;,\r\n        &quot;csDefRef&quot;: &quot;BoostYES_B1&quot;\r\n      },\r\n      {\r\n        &quot;edigest&quot;: &quot;MV6shIv5NE5vWkc0cx6Q/JTwid4=&quot;,\r\n        &quot;csDefRef&quot;: &quot;BoostOff_B1&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;AMIT||220000d7f728801&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;0b1141b2-c2de-47c9-aa0c-2742f92b63f2||220000d7f738801&quot;,\r\n    &quot;lifeCycle&quot;: 0\r\n  },\r\n  &quot;23e529f9-b2f3-4730-9b28-4ee05ca678b6||220000d7f738801&quot;: {\r\n    &quot;List&quot;: [\r\n      {\r\n        &quot;Insts&quot;: [\r\n          {\r\n            &quot;DefId&quot;: &quot;A2&quot;,\r\n            &quot;data1&quot;: 1073741824,\r\n            &quot;data2&quot;: 0,\r\n            &quot;data3&quot;: 0,\r\n            &quot;lastUpdateTime&quot;: 1619541451476,\r\n            &quot;origInitialVal&quot;: 1073741824\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;AMIT||220000d7f728802&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;23e529f9-b2f3-4730-9b28-4ee05ca678b6||220000d7f738801&quot;,\r\n    &quot;endTime&quot;: 96285337200000,\r\n    &quot;lifeCycle&quot;: 0\r\n  },\r\n  &quot;66b2229b-2c16-4d54-b2a8-fcc1baeaf51c||220000d7f738801&quot;: {\r\n    &quot;List&quot;: [\r\n      {\r\n        &quot;Insts&quot;: [\r\n          {\r\n            &quot;DefId&quot;: &quot;B2&quot;,\r\n            &quot;data1&quot;: 10737418240,\r\n            &quot;data2&quot;: 10737418240,\r\n            &quot;data3&quot;: 10737418240,\r\n            &quot;lastUpdateTime&quot;: 1637766239807,\r\n            &quot;origInitialVal&quot;: 10737418240\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;edigest&quot;: &quot;MV6shIv5NE5vWkc0cx6Q/JTwid4=&quot;,\r\n        &quot;csDefRef&quot;: &quot;RMN_B2&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;AMIT||220000d7f728801&quot;\r\n    ],\r\n    &quot;startTime&quot;: 1637766000000,\r\n    &quot;id&quot;: &quot;66b2229b-2c16-4d54-b2a8-fcc1baeaf51c||220000d7f738801&quot;,\r\n    &quot;endTime&quot;: 1637852400000,\r\n    &quot;lifeCycle&quot;: 0\r\n  },\r\n  &quot;b896eb1b-d6b0-432b-8925-af17431c0f3e||220000d7f738801&quot;: {\r\n    &quot;List&quot;: [\r\n      {\r\n        &quot;Insts&quot;: [\r\n          {\r\n            &quot;DefId&quot;: &quot;B3&quot;,\r\n            &quot;data1&quot;: 2147483648,\r\n            &quot;data2&quot;: 2147483648,\r\n            &quot;data3&quot;: 2147483648,\r\n            &quot;lastUpdateTime&quot;: 1635692405780\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;edigest&quot;: &quot;MV6shIv5NE5vWkc0cx6Q/JTwid4=&quot;,\r\n        &quot;csDefRef&quot;: &quot;BoostYES_B3&quot;\r\n      },\r\n      {\r\n        &quot;edigest&quot;: &quot;MV6shIv5NE5vWkc0cx6Q/JTwid4=&quot;,\r\n        &quot;csDefRef&quot;: &quot;BoostOffCS_B3&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: [\r\n      &quot;AMIT||220000d7f728801&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;b896eb1b-d6b0-432b-8925-af17431c0f3e||220000d7f738801&quot;,\r\n    &quot;lifeCycle&quot;: 0\r\n  }\r\n}\r\n```\r\nRequired output is as below : \r\n\r\n    AMIT||220000d7f728801,A1,1073741824,0,0\r\n    AMIT||220000d7f728801,B1,5368709120,5368709120,5368709120\r\n    AMIT||220000d7f728801,A2,1073741824,0,0\r\n    AMIT||220000d7f728801,B2,10737418240,10737418240,10737418240\r\n    AMIT||220000d7f728801,B3,2147483648,2147483648,2147483648\r\n\r\nI tried to execute below jq to start with but it giving as mentioned in title. This might be due to DefId is not present at all the places. Similarly for data 1, data2 and data3.\r\n```\r\njq -r &#39;.[] | .&quot;name&quot;, .&quot;List&quot;[].&quot;Insts&quot;.&quot;DefId&quot;&#39;\r\n```\r\n\r\n\r\n\r\nWhat is the right jq command in order to get the correct output?",
        "link": "https://stackoverflow.com/questions/70406005/jq-error-at-stdin125-cannot-index-array-with-string-defid",
        "title": "jq: error (at &lt;stdin&gt;:125): Cannot index array with string &quot;DefId&quot;"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "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": 1639891202,
                "post_id": 70409053,
                "comment_id": 124461698,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1025507,
                    "reputation": 4662,
                    "user_id": 1034897,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://i.sstatic.net/3RxYm.jpg?s=256",
                    "display_name": "KnowHoper",
                    "link": "https://stackoverflow.com/users/1034897/knowhoper"
                },
                "reply_to_user": {
                    "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": 1639891290,
                "post_id": 70409053,
                "comment_id": 124461706,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639952238,
                "last_edit_date": 1639952238,
                "creation_date": 1639891330,
                "answer_id": 70409145,
                "question_id": 70409053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can apply `map(select(...))` to the array directly and get the filtered array back:\r\n\r\n```sh\r\njq &#39;map(select(.labels[&quot;is-secret&quot;] == &quot;true&quot;))&#39;\r\n```\r\n\r\nYou also have to quote `is-secret` because of the hyphen; the square bracket notation is optional, but is what the [manual][1] uses; thus\r\n\r\n```sh\r\njq &#39;map(select(.labels.&quot;is-secret&quot; == &quot;true&quot;))&#39;\r\n```\r\n\r\nwould also work.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar",
                "title": "JQ filter by sub array - with hyphen in attribute name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1639952238,
        "creation_date": 1639889609,
        "last_edit_date": 1639896228,
        "question_id": 70409053,
        "body_markdown": "I have the following data file:\r\n```json\r\n[\r\n  {\r\n    &quot;createTime&quot;: &quot;2021-12-15T09:39:59.812377Z&quot;,\r\n    &quot;etag&quot;: &quot;\\&quot;15d377a6a77bab\\&quot;&quot;,\r\n    &quot;labels&quot;: {\r\n      &quot;is-secret&quot;: &quot;false&quot;\r\n    },\r\n    &quot;name&quot;: &quot;projects/xxx/secrets/xxx&quot;,\r\n    &quot;replication&quot;: {\r\n      &quot;automatic&quot;: {}\r\n    }\r\n  },\r\n  {\r\n    &quot;createTime&quot;: &quot;2021-12-19T03:47:53.594568Z&quot;,\r\n    &quot;etag&quot;: &quot;\\&quot;15d377a868c624\\&quot;&quot;,\r\n    &quot;labels&quot;: {\r\n      &quot;is-secret&quot;: &quot;true&quot;\r\n    },\r\n    &quot;name&quot;: &quot;projects/xxx/secrets/xxx&quot;,\r\n    &quot;replication&quot;: {\r\n      &quot;automatic&quot;: {}\r\n    }\r\n  }\r\n]\r\n```\r\nI am trying to select all elements that have a label of is-secret=true using the following query:\r\n\r\n    cat data.txt | jq &#39;.[] | map(select( any(.labels[]; .is-secret == &quot;true&quot; )))&#39;\r\n\r\nOutput needs to be an array.\r\n\r\nYields: jq: 1 compile error\r\n\r\nCan anyone help?\r\nCheers\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70409053/jq-filter-by-sub-array-with-hyphen-in-attribute-name",
        "title": "JQ filter by sub array - with hyphen in attribute name"
    },
    {
        "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": 1639980480,
                "post_id": 70417861,
                "comment_id": 124477292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1407241,
                    "reputation": 441,
                    "user_id": 1334609,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://www.gravatar.com/avatar/637782a847ed87b20eb020d43125e554?s=256&d=identicon&r=PG",
                    "display_name": "user1334609",
                    "link": "https://stackoverflow.com/users/1334609/user1334609"
                },
                "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": 1639982081,
                "post_id": 70417861,
                "comment_id": 124477630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639983436,
                "last_edit_date": 1639983436,
                "creation_date": 1639982088,
                "answer_id": 70418152,
                "question_id": 70417861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have a stream of objects. You will need to group all those document into one to work on them collectively.\r\n\r\nThere are two ways to achieve this:\r\n\r\n* Using &quot;slurp mode&quot; (`--slurp`/`-s`)\r\n* Using `[ inputs ]`, which requires `-null-input`/`-n`.\r\n\r\n---\r\n\r\n\r\nThe number of documents in the stream:\r\n\r\n```sh\r\njq -sr length\r\n```\r\n\r\n```sh\r\njq -nr &#39;[ inputs ] | length&#39;\r\n```\r\n\r\n---\r\n\r\nThe number of documents whose root object have value `foo` for key `name`:\r\n\r\n```sh\r\njq -sr &#39;map( select( .name == &quot;foo&quot; ) ) | length&#39;\r\n```\r\n\r\n```sh\r\njq -nr &#39;[ inputs | select( .name == &quot;foo&quot; ) ] | length&#39;\r\n```\r\n\r\n---\r\n\r\nThe titles grouped by name:\r\n\r\n```sh\r\njq -s &#39;reduce .[] as $doc ( {}; .[ $doc.name ] += [ $doc.title ] )&#39;\r\n```\r\n\r\n\r\n```sh\r\njq -n &#39;reduce inputs as $doc ( {}; .[ $doc.name ] += [ $doc.title ] )&#39;\r\n```\r\n",
                "title": "jq to get count of a element in a string and make it to a dict list"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640017798,
                "creation_date": 1640017798,
                "answer_id": 70424986,
                "question_id": 70417861,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To avoid slurping and any other method of creating an array in order to take its length, you can use the following stream-oriented counting function:\r\n\r\n    def count(s): reduce s as $x (0; .+1);\r\n\r\nFor example, instead of:\r\n\r\n    jq -nr &#39;[ inputs ] | length&#39;\r\n\r\n\r\nyou could write:\r\n\r\n    jq -n -f count.jq\r\n\r\nwhere count.jq contains:\r\n\r\n    def count(s): reduce s as $x (0; .+1);\r\n    count(inputs)\r\n\r\n\r\nSimilarly, instead of\r\n\r\n     jq -nr &#39;[ inputs | select( .name == &quot;foo&quot; ) ] | length&#39;\r\n\r\nyou would use the same &quot;def&quot; with:\r\n\r\n    count(inputs | select( .name == &quot;foo&quot; ))",
                "title": "jq to get count of a element in a string and make it to a dict list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1640017798,
        "creation_date": 1639979650,
        "last_edit_date": 1639982899,
        "question_id": 70417861,
        "body_markdown": "question 1) I want to count all dict in this string, the result should be `3` for the sample input below.\r\n\r\nquestion 2) I want want to count name == foo, the result should be `2` \r\n\r\nquestion 3) I want to get `{&quot;foo&quot;:[&quot;b&quot;,&quot;c&quot;],&quot;go&quot;:[&quot;d&quot;]}`\r\n\r\nSample input:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;title&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;foo&quot;,\r\n  &quot;title&quot;: &quot;c&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;go&quot;,\r\n  &quot;title&quot;: &quot;d&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70417861/jq-to-get-count-of-a-element-in-a-string-and-make-it-to-a-dict-list",
        "title": "jq to get count of a element in a string and make it to a dict list"
    },
    {
        "tags": [
            "json",
            "file",
            "join",
            "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": 1,
                "creation_date": 1639993374,
                "post_id": 70419797,
                "comment_id": 124480719,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1639993797,
                "post_id": 70419797,
                "comment_id": 124480852,
                "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": 1639993844,
                "post_id": 70419797,
                "comment_id": 124480877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3899033,
                    "reputation": 23527,
                    "user_id": 3227319,
                    "user_type": "registered",
                    "accept_rate": 48,
                    "profile_image": "https://www.gravatar.com/avatar/07963e9a55d88a99656dd16ecebd25f9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jordi",
                    "link": "https://stackoverflow.com/users/3227319/jordi"
                },
                "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": 1639994493,
                "post_id": 70419797,
                "comment_id": 124481075,
                "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": 1640011167,
                "post_id": 70419797,
                "comment_id": 124487026,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640019575,
                "creation_date": 1640019575,
                "answer_id": 70425366,
                "question_id": 70419797,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input files and the expected output are invalid as JSON, but ignoring that for the moment, you can use jq to produce the desired transformation as follows:\r\n\r\n```\r\n&lt; patients.json jq --slurpfile address patient_address.json &#39;\r\n  (reduce $address[] as $a ({}; \r\n     .[ ($a.patient_id)|tostring].address += [$a | {city,town}] )) as $dict\r\n  | . + $dict[.id|tostring]  \r\n&#39;\r\n```\r\nOutput:\r\n```\r\n{\r\n  &quot;id&quot;: 1,\r\n  &quot;name&quot;: &quot;name1&quot;,\r\n  &quot;address&quot;: [\r\n    {\r\n      &quot;city&quot;: &quot;city1-1&quot;,\r\n      &quot;town&quot;: &quot;town1-1&quot;\r\n    },\r\n    {\r\n      &quot;city&quot;: &quot;city1-2&quot;,\r\n      &quot;town&quot;: &quot;town1-2&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;name&quot;: &quot;name2&quot;,\r\n  &quot;address&quot;: [\r\n    {\r\n      &quot;city&quot;: &quot;city2-1&quot;,\r\n      &quot;town&quot;: &quot;town2-1&quot;\r\n    }\r\n  ]\r\n} \r\n```\r\nThere are several ways to convert your inputs to JSON, e.g. using [tag:hjson] or similar tools.  Similarly, if you want the output to be a JSON array, you have several options, e.g. using `map`.\r\n\r\nCaveat: The solution presented above assumes that `.id|tostring` will not have any collisions.  This would be the case, for example, if .id is always an integer.",
                "title": "Merge two files with different object types (patients and address)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640040306,
        "creation_date": 1639992623,
        "last_edit_date": 1640040306,
        "question_id": 70419797,
        "body_markdown": "I&#39;ve two files:\r\n\r\n* patient.json: patients themselves\r\n* address.json: address of patients\r\n\r\nEach address patient contains its patient id.\r\n\r\n`patients.json`:\r\n\r\n```lang-json\r\n{\r\n  id: 1,\r\n  name: &quot;name1&quot;\r\n}\r\n{\r\n  id: 2,\r\n  name: &quot;name2&quot;\r\n}\r\n```\r\n\r\n`patient_address.json`:\r\n\r\n```lang-json\r\n{\r\n  patient_id: 1,\r\n  city: &quot;city1-1&quot;,\r\n  town: &quot;town1-1&quot;\r\n}\r\n{\r\n  patient_id: 1,\r\n  city: &quot;city1-2&quot;,\r\n  town: &quot;town1-2&quot;\r\n}\r\n{\r\n  patient_id: 2,\r\n  city: &quot;city2-1&quot;,\r\n  town: &quot;town2-1&quot;\r\n}\r\n```\r\n\r\nMy desired result would be:\r\n\r\n```lang-json\r\n{\r\n  id: 1,\r\n  name: &quot;name1&quot;,\r\n  address: [\r\n  {\r\n    city: &quot;city1-1&quot;,\r\n    town: &quot;town1-1&quot;\r\n  },\r\n  {\r\n    city: &quot;city1-2&quot;,\r\n    town: &quot;town1-2&quot;\r\n  }]\r\n},\r\n{\r\n  id: 2,\r\n  name: &quot;name2&quot;,\r\n  address: [\r\n  {\r\n    city: &quot;city2-1&quot;,\r\n    town: &quot;town2-1&quot;\r\n  }]\r\n}\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70419797/merge-two-files-with-different-object-types-patients-and-address",
        "title": "Merge two files with different object types (patients and address)"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639996641,
                "post_id": 70420500,
                "comment_id": 124481801,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22888643,
                    "reputation": 37,
                    "user_id": 17029123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47928dbbfaf018117bc13687eb8f3adf?s=256&d=identicon&r=PG",
                    "display_name": "Ege",
                    "link": "https://stackoverflow.com/users/17029123/ege"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639997034,
                "post_id": 70420500,
                "comment_id": 124481949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639997593,
                "post_id": 70420500,
                "comment_id": 124482127,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22888643,
                    "reputation": 37,
                    "user_id": 17029123,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47928dbbfaf018117bc13687eb8f3adf?s=256&d=identicon&r=PG",
                    "display_name": "Ege",
                    "link": "https://stackoverflow.com/users/17029123/ege"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1639997940,
                "post_id": 70420500,
                "comment_id": 124482232,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1639997680,
                "creation_date": 1639997680,
                "answer_id": 70420728,
                "question_id": 70420500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -r &#39;.software | to_entries[] | .key as $app | .value | to_entries[] | select((.value | objects)) |  [$app, .key, .value.server] | @csv&#39;\r\n```",
                "title": "JQ: A list with multiple values for one key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1639997719,
                "creation_date": 1639997719,
                "answer_id": 70420739,
                "question_id": 70420500,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.software | to_entries[] | &quot;\\(.key) \\(.value | to_entries[] | select(.key != &quot;latest_version&quot;) | &quot;\\(.key) \\(.value.server)&quot;)&quot;\r\n```\r\n\r\nWill produce \r\n```json\r\n&quot;app_1 0.0.1 vm123-4.domain.com&quot;\r\n&quot;app_1 0.0.2 vm123-5.comain.com&quot;\r\n&quot;app_2 1.0.1 vm333-1.domain.com&quot;\r\n&quot;app_33 0.44.1 vm888-9.domain.com&quot;\r\n&quot;app_33 1.2.2 vm123-4.domain.com&quot;\r\n```\r\n\r\nAs you can test [in this online demo](https://jqplay.org/s/NqCw2PKvgD).\r\n\r\n\r\n----------\r\n\r\nUsing `--raw-output` with tabs `\\t`, we can create a column like output:\r\n```none\r\napp_1\t0.0.1\tvm123-4.domain.com\r\napp_1\t0.0.2\tvm123-5.comain.com\r\napp_2\t1.0.1\tvm333-1.domain.com\r\napp_33\t0.44.1\tvm888-9.domain.com\r\napp_33\t1.2.2\tvm123-4.domain.com\r\n```\r\n[Demo](https://jqplay.org/s/xSNZBSmjKM)",
                "title": "JQ: A list with multiple values for one key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1639998169,
        "creation_date": 1639996453,
        "last_edit_date": 1639998169,
        "question_id": 70420500,
        "body_markdown": "Using jq, I want to get a list of application names, all versions and server name. The list should not contain information about the latest version.\r\n\r\nInput:\r\n```json\r\n{\r\n  &quot;software&quot;: {\r\n    &quot;app_1&quot;: {\r\n      &quot;0.0.1&quot;: {\r\n        &quot;properties_1&quot;: {\r\n          &quot;lang&quot;: &quot;en&quot;\r\n        },\r\n        &quot;server&quot;: &quot;vm123-4.domain.com&quot;\r\n      },\r\n      &quot;0.0.2&quot;: {\r\n        &quot;properties_2&quot;: {\r\n          &quot;arch&quot;: &quot;x86&quot;\r\n        },\r\n        &quot;server&quot;: &quot;vm123-5.comain.com&quot;\r\n      },\r\n      &quot;latest_version&quot;: &quot;0.0.2&quot;\r\n    },\r\n    &quot;app_2&quot;: {\r\n      &quot;1.0.1&quot;: {\r\n        &quot;properties_2&quot;: {\r\n          &quot;arch&quot;: &quot;x86&quot;\r\n        },\r\n        &quot;server&quot;: &quot;vm333-1.domain.com&quot;\r\n      },\r\n      &quot;latest_version&quot;: &quot;1.0.1&quot;\r\n    },\r\n    &quot;app_33&quot;: {\r\n      &quot;0.44.1&quot;: {\r\n        &quot;properties_1&quot;: {\r\n          &quot;lang&quot;: &quot;en&quot;\r\n        },\r\n        &quot;properties_2&quot;: {\r\n          &quot;arch&quot;: &quot;x86&quot;\r\n        },\r\n        &quot;properties_3&quot;: {\r\n          &quot;boot&quot;: &quot;true&quot;\r\n        },\r\n        &quot;server&quot;: &quot;vm888-9.domain.com&quot;\r\n      },\r\n      &quot;1.2.2&quot;: {\r\n        &quot;properties_3&quot;: {\r\n          &quot;boot&quot;: &quot;yes&quot;\r\n        },\r\n        &quot;server&quot;: &quot;vm123-4.domain.com&quot;\r\n      },\r\n      &quot;latest_version&quot;: &quot;1.2.2&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nDesired output:\r\n```\r\n&quot;app_1,  0.0.1,  vm123-4.domain.com&quot;\r\n&quot;app_1,  0.0.2,  vm123-5.comain.com&quot;\r\n&quot;app_2,  1.0.1,  vm333-1.comain.com&quot;\r\n&quot;app_33, 0.44.1, vm888-9.comain.com&quot;\r\n&quot;app_33, 1.2.2,  vm123-4.comain.com&quot;\r\n```\r\n\r\nMy request will only list one version of the app, but not all. I do not know how to do this.\r\n\r\n```\r\n.software | to_entries[] | [(.key), (.value | to_entries[] | select(.key | IN(&quot;latest_version&quot;) | not))] | &quot;\\(.[0]) \\(.[1].key) \\(.[1].value.server)&quot;\r\n```\r\nMy output:\r\n```\r\n&quot;app_1  0.0.1  vm123-4.domain.com&quot;\r\n&quot;app_2  1.0.1  vm333-1.domain.com&quot;\r\n&quot;app_33 0.44.1 vm888-9.domain.com&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/70420500/jq-a-list-with-multiple-values-for-one-key",
        "title": "JQ: A list with multiple values for one key"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1640038112,
                "last_edit_date": 1640038112,
                "creation_date": 1640003138,
                "answer_id": 70421768,
                "question_id": 70421326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nto_entries | map(.value | split(&quot;|&quot;)) | transpose[] | {&quot;idType&quot;: .[0], &quot;idValue&quot;: .[1] }\r\n```\r\n\r\nWill generate\r\n```json\r\n{\r\n  &quot;idType&quot;: &quot;type1&quot;,\r\n  &quot;idValue&quot;: &quot;xxx&quot;\r\n}\r\n{\r\n  &quot;idType&quot;: &quot;type2&quot;,\r\n  &quot;idValue&quot;: &quot;yyy&quot;\r\n}\r\n{\r\n  &quot;idType&quot;: &quot;type3&quot;,\r\n  &quot;idValue&quot;: &quot;zzz&quot;\r\n}\r\n```\r\n\r\n[Online demo](https://jqplay.org/s/OsV0cV8rHF).\r\n\r\n\r\n----------\r\n\r\nRegarding `transpose` please read [jq&#39;s docs about this](https://stedolan.github.io/jq/manual/v1.5/#transpose).\r\n\r\n",
                "title": "How can I add entries to generated to_entries?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640038416,
        "creation_date": 1640000928,
        "last_edit_date": 1640038416,
        "question_id": 70421326,
        "body_markdown": "I have this json:\r\n\r\n```lang-json\r\n{\r\n  &quot;idTypes&quot;:&quot;type1|type2|type3&quot;,\r\n  &quot;idValues&quot;:&quot;xxx|yyy|zzz&quot;\r\n}\r\n```\r\n\r\nI need to reshape this information to:\r\n\r\n```lang-json\r\n{\r\n  &quot;idType&quot;: &quot;type1&quot;,\r\n  &quot;idValue&quot;: &quot;xxxx&quot;\r\n}\r\n{\r\n  &quot;idType&quot;: &quot;type2&quot;,\r\n  &quot;idValue&quot;: &quot;yyyy&quot;\r\n}\r\n{\r\n  &quot;idType&quot;: &quot;type1&quot;,\r\n  &quot;idValue&quot;: &quot;zzzz&quot;\r\n}\r\n```\r\n\r\nUp to now I&#39;ve tried with this ([click jqplay here](https://jqplay.org/s/7pp-Hx_lsd)):\r\n\r\n    .idTypes| split(&quot;|&quot;) | to_entries[]\r\n\r\nBut it doesn&#39;t generate what I need:\r\n\r\n```lang-json\r\n{\r\n  &quot;key&quot;: 0,\r\n  &quot;value&quot;: &quot;type1&quot;\r\n}\r\n{\r\n  &quot;key&quot;: 1,\r\n  &quot;value&quot;: &quot;type2&quot;\r\n}\r\n{\r\n  &quot;key&quot;: 2,\r\n  &quot;value&quot;: &quot;type3&quot;\r\n}\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70421326/how-can-i-add-entries-to-generated-to-entries",
        "title": "How can I add entries to generated to_entries?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640158775,
                "post_id": 70445005,
                "comment_id": 124526568,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7689789,
                    "reputation": 1070,
                    "user_id": 5826441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1b6d85d7b96c83054216e948a212ad03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Akhil",
                    "link": "https://stackoverflow.com/users/5826441/akhil"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640159494,
                "post_id": 70445005,
                "comment_id": 124526785,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640160256,
                "post_id": 70445005,
                "comment_id": 124527026,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640166809,
                "post_id": 70445005,
                "comment_id": 124529310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7689789,
                    "reputation": 1070,
                    "user_id": 5826441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1b6d85d7b96c83054216e948a212ad03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Akhil",
                    "link": "https://stackoverflow.com/users/5826441/akhil"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640169029,
                "post_id": 70445005,
                "comment_id": 124530119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7689789,
                    "reputation": 1070,
                    "user_id": 5826441,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1b6d85d7b96c83054216e948a212ad03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Akhil",
                    "link": "https://stackoverflow.com/users/5826441/akhil"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640169123,
                "post_id": 70445005,
                "comment_id": 124530156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640174874,
                "post_id": 70445005,
                "comment_id": 124532138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640176267,
                "post_id": 70445005,
                "comment_id": 124532648,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640182927,
                "last_edit_date": 1640182927,
                "creation_date": 1640175063,
                "answer_id": 70448842,
                "question_id": 70445005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If we focus on just the tags, I see two solutions:\r\n\r\n```\r\n(.Tags[] | select(.Key == &quot;Name&quot;)).value // &quot;&quot;\r\n```\r\n\r\nThis uses the `//` operator to return `&quot;&quot;` in case the .value does not exist.\r\n\r\nAlternatively, you can shoehorn the tags into an object first:\r\n```\r\n.Tags | map({key: .Key, value: .Value}) | from_entries | .Name // &quot;&quot;\r\n```",
                "title": "jq is not printing the lines where select() returns null"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640182927,
        "creation_date": 1640154183,
        "last_edit_date": 1640159462,
        "question_id": 70445005,
        "body_markdown": "I am trying to fetch all the ec2 instances from AWS using awscli with Tag Name.  \r\ncommand I used is  \r\n\r\n    aws ec2 describe-instances | \\\r\n    jq -r &#39;.Reservations[].Instances[] | (.Tags[] | select(.Key == &quot;Name&quot;) | .Value) + &quot; &quot; \\\r\n    + .InstanceId + &quot; &quot; + .InstanceType + &quot; &quot; + .KeyName + &quot; &quot; + .PrivateIpAddress + &quot; &quot; + .PublicIpAddress&#39;\r\n\r\nHere, jq is printing the instances only with tag Name, and other instances which don&#39;t have tag name are not printed.  \r\nam I using the select() in wrong way?  \r\n\r\nActual output:\r\n\r\n    master-bastion i-026b52da57ae3a85 t2.micro aus 10.90.0.68 52.62.76.17\r\n    master-mongodb_1 i-083bceea3aea1832 t3.medium aus 10.90.100.25\r\n    master-mongo i-06d669ba5cda0c74 t3.medium aus 10.90.100.12\r\n    master-solr1 i-09752d54fe143fec t2.medium aus 10.90.100.12\r\n    master-solr2 i-039bf2028ec15d97 t2.medium aus 10.90.101.22\r\n    master-solr3 i-09fc04ceeeb1efae t2.medium aus 10.90.100.6\r\n    rabbitmq-1 i-0125de65ba60627a t2.small aus 10.90.100.10\r\n    rabbitmq-2 i-069d546deb4a1c23 t2.small aus 10.90.101.11\r\n\r\nExpected Output:\r\n\r\n    master-bastion i-026b52da57ae3a85 t2.micro aus 10.90.0.68 52.62.76.17\r\n    i-06d669ba5cda0c4d t3.medium aus 10.90.100.142\r\n    i-062669ba5cda0sfs t3.medium aus 10.90.100.147\r\n    master-mongodb_1 i-083bceea3aea1832 t3.medium aus 10.90.100.25\r\n    master-mongo i-06d669ba5cda0c74 t3.medium aus 10.90.100.12\r\n    master-solr1 i-09752d54fe143fec t2.medium aus 10.90.100.12\r\n    master-solr2 i-039bf2028ec15d97 t2.medium aus 10.90.101.22\r\n    master-solr3 i-09fc04ceeeb1efae t2.medium aus 10.90.100.6\r\n    rabbitmq-1 i-0125de65ba60627a t2.small aus 10.90.100.10\r\n    rabbitmq-2 i-069d546deb4a1c23 t2.small aus 10.90.101.11",
        "link": "https://stackoverflow.com/questions/70445005/jq-is-not-printing-the-lines-where-select-returns-null",
        "title": "jq is not printing the lines where select() returns null"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640175496,
                "post_id": 70447886,
                "comment_id": 124532387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640183911,
                "last_edit_date": 1640183911,
                "creation_date": 1640177013,
                "answer_id": 70449252,
                "question_id": 70447886,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In other words:\r\n\r\n     [_nwise(length / 6 | ceil)]\r\n\r\nIf a large array cannot be assumed, you can pad with []:\r\n\r\n    [_nwise(length / 6|ceil) ]+[range(0;6-length)|[]]",
                "title": "Split big array in X parts using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640183911,
        "creation_date": 1640170349,
        "question_id": 70447886,
        "body_markdown": "I would like use `jq` for divide a large array into 6 parts. For this, i think use `_nwise()` methode, but the result is wrong :\r\n\r\n[See screenshot][1]\r\n\r\nI&#39;m not really understand why `[_nwise(length / 6)]` return 7 parts ??\r\n\r\n\r\n  [1]: https://i.sstatic.net/V00Ki.png",
        "link": "https://stackoverflow.com/questions/70447886/split-big-array-in-x-parts-using-jq",
        "title": "Split big array in X parts using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640197434,
                "post_id": 70453387,
                "comment_id": 124540869,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640197481,
                "post_id": 70453387,
                "comment_id": 124540895,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23646822,
                    "reputation": 15,
                    "user_id": 17676341,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e98a99ed7c2ed4a185819c90f64af6fd?s=256&d=identicon&r=PG",
                    "display_name": "Nebukazar",
                    "link": "https://stackoverflow.com/users/17676341/nebukazar"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640198477,
                "post_id": 70453387,
                "comment_id": 124541208,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640274114,
                "last_edit_date": 1640274114,
                "creation_date": 1640197884,
                "answer_id": 70453639,
                "question_id": 70453387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can apply **@csv** at the last part after removing the yielded ***null*** values through use of ***`delpaths([path(.[] | select(.==null))])`*** in order to prevent generating successive redundant commas such as\r\n```\r\njq -r &#39;.data.activeFindings.findings[] \r\n       | [.findingId , .findingDescription, .findingImpact, .severity, (.recommendations | join(&quot;,&quot;)) , .affectedObjects[].sourceName, .affectedObjects[].objectName, .affectedObjects[].objectType, .affectedObjects[].version, .affectedObjects[].buildNumber, .firstObserved, (.kbLinkURLs | join(&quot;,&quot;)) ] \r\n       | delpaths([path(.[] | select(.==null))]) \r\n       | @csv&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/vMiy3JXw3x)&lt;/kbd&gt;",
                "title": "export results from jq to csv"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640299368,
                "last_edit_date": 1640299368,
                "creation_date": 1640200032,
                "answer_id": 70454015,
                "question_id": 70453387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would combine jq with [spyql][1], here&#39;s how:\r\n\r\n    jq -c &#39;.data.activeFindings.findings[]&#39; full_sample.json | spyql &quot;SELECT json-&gt;findingId AS &#39;Finding Id&#39;, json-&gt;findingDescription  AS &#39;Issue Description&#39;, json-&gt;findingImpact AS &#39;Risk if no Action Taken&#39;, json-&gt;severity AS Severity, &#39;;&#39;.join(json-&gt;recommendations) AS Recommendations, json-&gt;affectedObjects-&gt;sourceName AS &#39;Source Name&#39;, json-&gt;affectedObjects-&gt;objectName AS &#39;Object Name&#39;, json-&gt;affectedObjects-&gt;objectType AS &#39;Object Type&#39;, json-&gt;affectedObjects-&gt;version AS &#39;Host Version&#39;, json-&gt;affectedObjects-&gt;buildNumber AS Build, json-&gt;affectedObjects-&gt;firstObserved AS &#39;First Observed&#39;, &#39;;&#39;.join(json-&gt;kbLinkURLsVCF) AS Reference FROM json EXPLODE json-&gt;affectedObjects TO csv&quot;      \r\n    Finding Id,Issue Description,Risk if no Action Taken,Severity,Recommendations,Source Name,Object Name,Object Type,Host Version,Build,First Observed,Reference\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server01.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server02.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server03.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server04.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server05.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server06.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server07.corp.contoso.org,ESX,6.7.0,17499825,1629806351877,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER02.corp.contoso.org,server10.corp.contoso.org,ESX,6.7.0,17167734,1635968448112,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER02.corp.contoso.org,server11.corp.contoso.org,ESX,6.7.0,17167734,1635968448112,https://kb.vmware.com/s/article/80703\r\n\r\nI am using jq to extract the part of the JSON we need, while compressing the output to JSON lines (required by spyql). Then, spyql takes care of the rest, namely joining arrays (expressions are python with some optional syntax sugar), renaming columns and generating the CSV.\r\n\r\nIf you want to convert the `firstObserved` timestamp to datetime you can do it like this (assuming UTC timestamp):\r\n\r\n    $ jq -c &#39;.data.activeFindings.findings[]&#39; full_sample.json | spyql &quot;SELECT json-&gt;findingId AS &#39;Finding Id&#39;, json-&gt;findingDescription  AS &#39;Issue Description&#39;, json-&gt;findingImpact AS &#39;Risk if no Action Taken&#39;, json-&gt;severity AS Severity, &#39;;&#39;.join(json-&gt;recommendations) AS Recommendations, json-&gt;affectedObjects-&gt;sourceName AS &#39;Source Name&#39;, json-&gt;affectedObjects-&gt;objectName AS &#39;Object Name&#39;, json-&gt;affectedObjects-&gt;objectType AS &#39;Object Type&#39;, json-&gt;affectedObjects-&gt;version AS &#39;Host Version&#39;, json-&gt;affectedObjects-&gt;buildNumber AS Build, datetime.utcfromtimestamp(json-&gt;affectedObjects-&gt;firstObserved/1000) AS &#39;First Observed&#39;, &#39;;&#39;.join(json-&gt;kbLinkURLsVCF) AS Reference FROM json EXPLODE json-&gt;affectedObjects TO csv&quot; \r\n    Finding Id,Issue Description,Risk if no Action Taken,Severity,Recommendations,Source Name,Object Name,Object Type,Host Version,Build,First Observed,Reference\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server01.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server02.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server03.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server04.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server05.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server06.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER01.corp.contoso.org,server07.corp.contoso.org,ESX,6.7.0,17499825,2021-08-24 11:59:11.877000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER02.corp.contoso.org,server10.corp.contoso.org,ESX,6.7.0,17167734,2021-11-03 19:40:48.112000,https://kb.vmware.com/s/article/80703\r\n    risk#80703,PSOD with re-formatting a valid dedup metadata block.,Potential ESXi host crash,CRITICAL,This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804),GWSERVER02.corp.contoso.org,server11.corp.contoso.org,ESX,6.7.0,17167734,2021-11-03 19:40:48.112000,https://kb.vmware.com/s/article/80703\r\n\r\nIf you don&#39;t need millisecond precision in your datetime you can use integer division (i.e. `datetime.utcfromtimestamp(json-&gt;affectedObjects-&gt;firstObserved//1000)`).\r\n\r\nDisclaimer: I am the author of spyql\r\n\r\n  [1]: https://github.com/dcmoura/spyql\r\n",
                "title": "export results from jq to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1640299368,
        "creation_date": 1640196512,
        "last_edit_date": 1640198312,
        "question_id": 70453387,
        "body_markdown": "I&#39;m having the following dataset which I&#39;d like to export into a CSV:\r\n\r\n**Dataset:**\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;activeFindings&quot;: {\r\n          &quot;findings&quot;: [\r\n            {\r\n              &quot;findingId&quot;: &quot;risk#80703&quot;,\r\n              &quot;accountId&quot;: &quot;00000000-000000-0000000-000000&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;GWSERVER01&quot;\r\n              ],\r\n              &quot;findingDisplayName&quot;: &quot;risk#80703&quot;,\r\n              &quot;severity&quot;: &quot;CRITICAL&quot;,\r\n              &quot;findingDescription&quot;: &quot;PSOD with re-formatting a valid dedup metadata block.&quot;,\r\n              &quot;findingImpact&quot;: &quot;Potential ESXi host crash&quot;,\r\n              &quot;recommendations&quot;: [\r\n                &quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523)&quot;,\r\n                &quot;This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)&quot;\r\n              ],\r\n              &quot;kbLinkURLs&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;recommendationsVCF&quot;: [\r\n                &quot;This issue is resolved with VMware Cloud Foundation 4.1&quot;\r\n              ],\r\n              &quot;kbLinkURLsVCF&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;categoryName&quot;: &quot;Storage&quot;,\r\n              &quot;findingTypes&quot;: [\r\n                &quot;UPGRADE&quot;\r\n              ],\r\n              &quot;firstObserved&quot;: 1629806351877,\r\n              &quot;totalAffectedObjectsCount&quot;: 12,\r\n              &quot;affectedObjects&quot;: [\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server01.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server02.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server03.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server04.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server05.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server06.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server07.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;totalRecords&quot;: 1,\r\n          &quot;timeTaken&quot;: 56\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;activeFindings&quot;: {\r\n          &quot;findings&quot;: [\r\n            {\r\n              &quot;findingId&quot;: &quot;risk#80703&quot;,\r\n              &quot;accountId&quot;: &quot;00000000-000000-0000000-000000&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;GWSERVER02.corp.contoso.org&quot;\r\n              ],\r\n              &quot;findingDisplayName&quot;: &quot;risk#80703&quot;,\r\n              &quot;severity&quot;: &quot;CRITICAL&quot;,\r\n              &quot;findingDescription&quot;: &quot;PSOD with re-formatting a valid dedup metadata block.&quot;,\r\n              &quot;findingImpact&quot;: &quot;Potential ESXi host crash&quot;,\r\n              &quot;recommendations&quot;: [\r\n                &quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523)&quot;,\r\n                &quot;This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)&quot;\r\n              ],\r\n              &quot;kbLinkURLs&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;recommendationsVCF&quot;: [\r\n                &quot;This issue is resolved with VMware Cloud Foundation 4.1&quot;\r\n              ],\r\n              &quot;kbLinkURLsVCF&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;categoryName&quot;: &quot;Storage&quot;,\r\n              &quot;findingTypes&quot;: [\r\n                &quot;UPGRADE&quot;\r\n              ],\r\n              &quot;firstObserved&quot;: 1635968448112,\r\n              &quot;totalAffectedObjectsCount&quot;: 2,\r\n              &quot;affectedObjects&quot;: [\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER02.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server10.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17167734&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1635968448112\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER02.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server11.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17167734&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1635968448112\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;totalRecords&quot;: 1,\r\n          &quot;timeTaken&quot;: 51\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n**And header would be as follow:**\r\n\r\n    &quot;Finding Id&quot;,&quot;Issue Description&quot;,&quot;Risk if no Action Taken&quot;,&quot;Severity&quot;,&quot;Recommendations&quot;,&quot;Source Name&quot;,&quot;Object Name&quot;,&quot;Object Type&quot;,&quot;Host Version&quot;,&quot;Build&quot;,&quot;First Observed&quot;,&quot;Reference&quot;\r\n\r\n\r\n**Header keys mapping as follow:**\r\n- Finding Id = findingId\r\n- Issue Description = findingDescription\r\n- Risk if no Action Taken = findingImpact\r\n- Severity = severity\r\n- Recommendations = recommendations\r\n- Source Name = sourceName\r\n- Object Name = objectName\r\n- Object Type = objectType\r\n- Host Version = version\r\n- Build = buildNumber\r\n- First Observed = firstObserved\r\n- Reference = kbLinkURLs\r\n\r\nUnfortunately, we have to perform an API call per each finding &amp; product (eg: we&#39;re not able to pull all the findings for all products at once - the API does not allow us to perform such query and thus, we have to make several calls to get all the findings with its associated objects.)\r\n\r\nWith that said, what would be the preferred approach to export the data into a csv ? Would using jq&#39;s @CSV work though we would have to loop through several nodes ?\r\n\r\nAny help/guidance would be appreciated.\r\n\r\nThanks!\r\n\r\n_______________________\r\nNote 1:\r\nA stripped version of the dataset as requested by [chepner](https://stackoverflow.com/users/1126841/chepner)\r\n\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;activeFindings&quot;: {\r\n          &quot;findings&quot;: [\r\n            {\r\n              &quot;findingId&quot;: &quot;risk#80703&quot;,\r\n              &quot;accountId&quot;: &quot;00000000-000000-0000000-000000&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;GWSERVER01&quot;\r\n              ],\r\n              &quot;findingDisplayName&quot;: &quot;risk#80703&quot;,\r\n              &quot;severity&quot;: &quot;CRITICAL&quot;,\r\n              &quot;findingDescription&quot;: &quot;PSOD with re-formatting a valid dedup metadata block.&quot;,\r\n              &quot;findingImpact&quot;: &quot;Potential ESXi host crash&quot;,\r\n              &quot;recommendations&quot;: [\r\n                &quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523)&quot;,\r\n                &quot;This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)&quot;\r\n              ],\r\n              &quot;kbLinkURLs&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;recommendationsVCF&quot;: [\r\n                &quot;This issue is resolved with VMware Cloud Foundation 4.1&quot;\r\n              ],\r\n              &quot;kbLinkURLsVCF&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;categoryName&quot;: &quot;Storage&quot;,\r\n              &quot;findingTypes&quot;: [\r\n                &quot;UPGRADE&quot;\r\n              ],\r\n              &quot;firstObserved&quot;: 1629806351877,\r\n              &quot;totalAffectedObjectsCount&quot;: 12,\r\n              &quot;affectedObjects&quot;: [\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server01.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER01.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server02.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17499825&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1629806351877\r\n                },\r\n              ]\r\n            }\r\n          ],\r\n          &quot;totalRecords&quot;: 1,\r\n          &quot;timeTaken&quot;: 56\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;data&quot;: {\r\n        &quot;activeFindings&quot;: {\r\n          &quot;findings&quot;: [\r\n            {\r\n              &quot;findingId&quot;: &quot;risk#80703&quot;,\r\n              &quot;accountId&quot;: &quot;00000000-000000-0000000-000000&quot;,\r\n              &quot;products&quot;: [\r\n                &quot;GWSERVER02.corp.contoso.org&quot;\r\n              ],\r\n              &quot;findingDisplayName&quot;: &quot;risk#80703&quot;,\r\n              &quot;severity&quot;: &quot;CRITICAL&quot;,\r\n              &quot;findingDescription&quot;: &quot;PSOD with re-formatting a valid dedup metadata block.&quot;,\r\n              &quot;findingImpact&quot;: &quot;Potential ESXi host crash&quot;,\r\n              &quot;recommendations&quot;: [\r\n                &quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523)&quot;,\r\n                &quot;This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)&quot;\r\n              ],\r\n              &quot;kbLinkURLs&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;recommendationsVCF&quot;: [\r\n                &quot;This issue is resolved with VMware Cloud Foundation 4.1&quot;\r\n              ],\r\n              &quot;kbLinkURLsVCF&quot;: [\r\n                &quot;https://kb.vmware.com/s/article/80703&quot;\r\n              ],\r\n              &quot;categoryName&quot;: &quot;Storage&quot;,\r\n              &quot;findingTypes&quot;: [\r\n                &quot;UPGRADE&quot;\r\n              ],\r\n              &quot;firstObserved&quot;: 1635968448112,\r\n              &quot;totalAffectedObjectsCount&quot;: 2,\r\n              &quot;affectedObjects&quot;: [\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER02.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server10.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17167734&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1635968448112\r\n                },\r\n                {\r\n                  &quot;sourceName&quot;: &quot;GWSERVER02.corp.contoso.org&quot;,\r\n                  &quot;objectName&quot;: &quot;server11.corp.contoso.org&quot;,\r\n                  &quot;objectType&quot;: &quot;ESX&quot;,\r\n                  &quot;version&quot;: &quot;6.7.0&quot;,\r\n                  &quot;buildNumber&quot;: &quot;17167734&quot;,\r\n                  &quot;solutionTags&quot;: [],\r\n                  &quot;firstObserved&quot;: 1635968448112\r\n                }\r\n              ]\r\n            }\r\n          ],\r\n          &quot;totalRecords&quot;: 1,\r\n          &quot;timeTaken&quot;: 51\r\n        }\r\n      }\r\n    }\r\n\r\n\r\n\r\n\r\nAnd the resulted CSV file:\r\n\r\n    &quot;Finding Id&quot;,&quot;Issue Description&quot;,&quot;Risk if no Action Taken&quot;,&quot;Severity&quot;,&quot;Recommendations&quot;,&quot;Source Name&quot;,&quot;Object Name&quot;,&quot;Object Type&quot;,&quot;Host Version&quot;,&quot;Build&quot;,&quot;First Observed&quot;,&quot;Reference&quot;\r\n    &quot;risk#80703&quot;,&quot;PSOD with re-formatting a valid dedup metadata block.&quot;,&quot;Potential ESXi host crash&quot;,&quot;CRITICAL&quot;,&quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804);This issue is resolved with VMware Cloud Foundation 4.1&quot;,&quot;GWSERVER01.corp.contoso.org&quot;,&quot;server01.corp.contoso.org&quot;,&quot;HostSystem&quot;,&quot;6.7.0&quot;,&quot;17499825&quot;,&quot;1629806351877&quot;,&quot;https://kb.vmware.com/s/article/80703&quot;\r\n    &quot;risk#80703&quot;,&quot;PSOD with re-formatting a valid dedup metadata block.&quot;,&quot;Potential ESXi host crash&quot;,&quot;CRITICAL&quot;,&quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804);This issue is resolved with VMware Cloud Foundation 4.1&quot;,&quot;GWSERVER01.corp.contoso.org&quot;,&quot;server02.corp.contoso.org&quot;,&quot;HostSystem&quot;,&quot;6.7.0&quot;,&quot;17499825&quot;,&quot;1629806351877&quot;,&quot;https://kb.vmware.com/s/article/80703&quot;\r\n    &quot;risk#80703&quot;,&quot;PSOD with re-formatting a valid dedup metadata block.&quot;,&quot;Potential ESXi host crash&quot;,&quot;CRITICAL&quot;,&quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804);This issue is resolved with VMware Cloud Foundation 4.1&quot;,&quot;GWSERVER02.corp.contoso.org&quot;,&quot;server10.corp.contoso.org&quot;,&quot;HostSystem&quot;,&quot;6.7.0&quot;,&quot;17167734&quot;,&quot;1635968448112&quot;,&quot;https://kb.vmware.com/s/article/80703&quot;\r\n    &quot;risk#80703&quot;,&quot;PSOD with re-formatting a valid dedup metadata block.&quot;,&quot;Potential ESXi host crash&quot;,&quot;CRITICAL&quot;,&quot;This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523);This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804);This issue is resolved with VMware Cloud Foundation 4.1&quot;,&quot;GWSERVER02.corp.contoso.org&quot;,&quot;server11.corp.contoso.org&quot;,&quot;HostSystem&quot;,&quot;6.7.0&quot;,&quot;17167734&quot;,&quot;1635968448112&quot;,&quot;https://kb.vmware.com/s/article/80703&quot;",
        "link": "https://stackoverflow.com/questions/70453387/export-results-from-jq-to-csv",
        "title": "export results from jq to csv"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640216856,
                "last_edit_date": 1640216856,
                "creation_date": 1640215827,
                "answer_id": 70456201,
                "question_id": 70455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use **del** for the respective ***null*** values such as\r\n```\r\njq -r &#39;del(.[][] | select(.nation.country == null and .name.surname== null))&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/d_Ii1AmCI1)&lt;/kbd&gt;",
                "title": "jq: map object if field exists"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640218146,
                "last_edit_date": 1640218146,
                "creation_date": 1640217813,
                "answer_id": 70456371,
                "question_id": 70455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add a test before capture the value :\r\n\r\n```\r\ndef pick_nationality:\r\n  if has(&quot;NACIONALITAT&quot;)\r\n  then {nation: {country: .NACIONALITAT, code: &quot;some code&quot;} }\r\n  else empty end;\r\n\r\ndef pick_surname: \r\n  if has(&quot;SURNAME&quot;)\r\n  then {name: {surname: .SURNAME, code: &quot;some code&quot;} }\r\n  else empty end;\r\n\r\nmap([pick_nationality, pick_surname])\r\n```",
                "title": "jq: map object if field exists"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640220716,
                "creation_date": 1640220716,
                "answer_id": 70456615,
                "question_id": 70455986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just have the functions return nothing when the relevant field is missing.\r\n\r\n```jq\r\ndef pick_nationality:\r\n  select(.NACIONALITAT) |\r\n  {nation: {country: .NACIONALITAT, code: &quot;some code&quot;} };\r\n\r\ndef pick_surname: \r\n  select(.SURNAME) |\r\n  {name: {surname: .SURNAME, code: &quot;some code&quot;} };\r\n\r\nmap([pick_nationality, pick_surname])\r\n```\r\n\r\n[Demo](https://jqplay.org/s/v5k_Qjeoc3) on jqplay\r\n",
                "title": "jq: map object if field exists"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1640220716,
        "creation_date": 1640213804,
        "question_id": 70455986,
        "body_markdown": "This is my jq code:\r\n\r\n```\r\ndef pick_nationality:\r\n  {nation: {country: .NACIONALITAT, code: &quot;some code&quot;} };\r\n\r\ndef pick_surname:\r\n  {name: {surname: .SURNAME, code: &quot;some code&quot;} };\r\n\r\nmap([pick_nationality, pick_surname])\r\n```\r\n\r\nProblem here appears when some of `.NACIONALITAT` or `.SURNAME` is not present on input objects:\r\n\r\n```lang-json\r\n{\r\n  &quot;SURNAME&quot;: &quot;surname1&quot;\r\n}\r\n{\r\n  &quot;NACIONALITAT&quot;: &quot;nacionalitat1&quot;\r\n}\r\n```\r\n\r\nResult:\r\n\r\n```lang-json\r\n[\r\n  [\r\n    {\r\n      &quot;nation&quot;: {\r\n        &quot;country&quot;: null,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;surname&quot;: &quot;surname1&quot;,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;nation&quot;: {\r\n        &quot;country&quot;: &quot;nacionalitat1&quot;,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;surname&quot;: null,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    }\r\n  ]\r\n]\r\n\r\n```\r\n\r\nProblem is I need to avoid pick_natinality when `.NATIONALITAT` field is not present...\r\n\r\nDesired result would be:\r\n\r\n```lang-json\r\n[\r\n  [\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;surname&quot;: &quot;surname1&quot;,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;nation&quot;: {\r\n        &quot;country&quot;: &quot;nacionalitat1&quot;,\r\n        &quot;code&quot;: &quot;some code&quot;\r\n      }\r\n    }\r\n  ]\r\n]\r\n\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70455986/jq-map-object-if-field-exists",
        "title": "jq: map object if field exists"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1640292072,
                "creation_date": 1640292072,
                "answer_id": 70467174,
                "question_id": 70466960,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace `&quot;$date&quot;` with `$date` in your filter.",
                "title": "JQ Not Taking In Variable Data"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640292072,
        "creation_date": 1640290288,
        "question_id": 70466960,
        "body_markdown": "I am unsuccessfully trying to add variable data to a json within a ci script.  I am attempting to use the `--arg VariableName VariableData` notation.  \r\n\r\nFor example purposes, I am only passing $date which has already been set earlier in the script.  In the outputted JSON, the literal string $date is outputted instead of the variable.\r\n\r\n    jq --arg date &quot;$date&quot; &#39;.sections[0].builds += [{&quot;title&quot;: &quot;Version MyVersion&quot;, &quot;timestamp&quot;: &quot;$date&quot;, &quot;iOS&quot;: &quot;My_URL.plist&quot; }]&#39; builds.json &gt; builds1.json\r\n\r\n**This results in:**\r\n\r\n    {\r\n      &quot;title&quot;: &quot;MY Title&quot;,\r\n      &quot;columnCount&quot;: 1,\r\n      &quot;notes_OFF&quot;: &quot;First_Test&quot;,\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;My Title&quot;,\r\n          &quot;builds&quot;: [\r\n            {\r\n              &quot;title&quot;: &quot;Version MyVersion&quot;,\r\n              &quot;timestamp&quot;: &quot;$date&quot;,\r\n              &quot;iOS&quot;: &quot;My_URL.plist&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n**Original JSON:**\r\n\r\n    {\r\n      &quot;title&quot;: &quot;MY Title&quot;,\r\n      &quot;columnCount&quot;: 1,\r\n      &quot;notes_OFF&quot;: &quot;First_Test&quot;,\r\n      &quot;sections&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;My Title&quot;,\r\n          &quot;builds&quot;: [\r\n            \r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\n**What am I doing wrong here?**",
        "link": "https://stackoverflow.com/questions/70466960/jq-not-taking-in-variable-data",
        "title": "JQ Not Taking In Variable Data"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640297439,
                "last_edit_date": 1640297439,
                "creation_date": 1640297094,
                "answer_id": 70467839,
                "question_id": 70467640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "extend your function `pick_extension` for the desired output:\r\n\r\n```jq\r\ndef pick_extension:\r\n  [pick_nationality, pick_surname] as $extension\r\n  | { use: &quot;official&quot; }\r\n  | if $extension | length &gt; 0 then . + {extension: $extension} else . end;\r\n```\r\n\r\nIf no extension could be picked, the empty array will no longer be added to the json object this way.",
                "title": "jq: avoid empty arrays mapped field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640302327,
                "last_edit_date": 1640302327,
                "creation_date": 1640301957,
                "answer_id": 70468274,
                "question_id": 70467640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply add \r\n```\r\n| del(..|select(. == []))\r\n```\r\nas a trailing to your script in order to remove all such empty arrays\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/j8KVWtctGn)&lt;/kbd&gt;",
                "title": "jq: avoid empty arrays mapped field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1640302327,
        "creation_date": 1640295537,
        "question_id": 70467640,
        "body_markdown": "Here my jq script:\r\n\r\n```\r\ndef pick_nationality:\r\n  select(.NACIONALITAT) |\r\n  {nation: {country: .NACIONALITAT, code: &quot;some code&quot;} };\r\n\r\ndef pick_surname: \r\n  select(.SURNAME) |\r\n  {name: {surname: .SURNAME, code: &quot;some code&quot;} };\r\n\r\ndef pick_extension:\r\n  { use: &quot;official&quot;, extension: [pick_nationality, pick_surname] };\r\n\r\nmap(pick_extension)\r\n```\r\n\r\nInput json is like:\r\n\r\n```lang-json\r\n{\r\n  &quot;SURNAME&quot;: &quot;surname1&quot;\r\n}\r\n{\r\n  &quot;NACIONALITAT&quot;: &quot;nacionalitat1&quot;\r\n}\r\n```\r\n\r\nHowever, sometimes any input objects don&#39;t contain any look up field:\r\n\r\n```lang-json\r\n{\r\n  &quot;field1&quot;: &quot;value1&quot;\r\n}\r\n{\r\n  &quot;field2&quot;: &quot;value2&quot;\r\n}\r\n```\r\n\r\nAbove script returns:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;use&quot;: &quot;official&quot;,\r\n    &quot;extension&quot;: []\r\n  },\r\n  {\r\n    &quot;use&quot;: &quot;official&quot;,\r\n    &quot;extension&quot;: []\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d like `extension` doesn&#39;t appear:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;use&quot;: &quot;official&quot;\r\n  },\r\n  {\r\n    &quot;use&quot;: &quot;official&quot;\r\n  }\r\n]\r\n```\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/70467640/jq-avoid-empty-arrays-mapped-field",
        "title": "jq: avoid empty arrays mapped field"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1640303325,
                "last_edit_date": 1640303325,
                "creation_date": 1640301891,
                "answer_id": 70468268,
                "question_id": 70467714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d do it in two steps.\r\n\r\n---\r\n\r\nFirst, group into ranges.\r\n\r\n```jq\r\nreduce .[] as $_ (\r\n   [];\r\n   if $_ - 1 == .[-1][1] then\r\n      .[-1][1] = $_\r\n   else\r\n      . + [ [ $_, $_ ] ]\r\n   end\r\n)\r\n```\r\n\r\nThis step produces `[[1,1],[2,4],[6,6],[98,99],[101,101]]`.\r\n\r\n---\r\n\r\nThen, build the string.\r\n\r\n```jq\r\nmap(\r\n   if .[0] == .[1] then\r\n      &quot;\\( .[0] )&quot;\r\n   else\r\n      &quot;\\( .[0] )-\\( .[1] )&quot;\r\n   end\r\n) |\r\njoin(&quot;,&quot;)\r\n```\r\n\r\n---\r\n\r\n[Demo](https://jqplay.org/s/xou87tXVQS) on jqplay\r\n\r\nIt&#39;s not much shorter, but I think it&#39;s a lot simpler and cleaner.\r\n\r\nAlso, separating the concerns doesn&#39;t just have beneficial consequences for simplicity and clarity. You gain the option of hiding the code in two small functions. And you can customize the output more easily, say to produce `98,99` instead of `98-99` for `[98,99]`. You could even decide to reuse the code where you don&#39;t need to produce a string at all.\r\n\r\nBut best of all, this solution eliminates the magic `99999`!\r\n",
                "title": "Replace consecutive integers in an array with ranges"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1640334460,
                "last_edit_date": 1640334460,
                "creation_date": 1640333641,
                "answer_id": 70470847,
                "question_id": 70467714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another solution:\r\n```\r\nreduce .[1:][] as $n ([.[:1]];\r\n  if $n == .[-1][-1] + 1 then .[-1][1] = $n else . + [[$n]] end\r\n) | map(join(&quot;-&quot;)) | join(&quot;,&quot;)\r\n```\r\nWhen fed with\r\n```json\r\n[1,2,3,4,6,98,99,101]\r\n[1,3,5]\r\n[1,2,3,4,5]\r\n[4]\r\n[]\r\n```\r\nit outputs\r\n```json\r\n&quot;1-4,6,98-99,101&quot;\r\n&quot;1,3,5&quot;\r\n&quot;1-5&quot;\r\n&quot;4&quot;\r\n&quot;&quot;\r\n```\r\n[Demo](https://jqplay.org/s/M68QybQtHw)",
                "title": "Replace consecutive integers in an array with ranges"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1640334460,
        "creation_date": 1640296085,
        "question_id": 70467714,
        "body_markdown": "I want to combine consecutive integers in a sorted array and replace them with ranges using `jq`.\r\n\r\nexample 1\r\n---------\r\n&gt; input: `[1,2,3,4,6,98,99,101]`  \r\n&gt; desired output: `&quot;1-4,6,98-99,101&quot;`\r\n\r\nexample 2\r\n---------\r\n&gt; input: `[1,3,5]`  \r\n&gt; desired output: `&quot;1,3,5&quot;`\r\n\r\nexample 3\r\n---------\r\n&gt; input: `[1,2,3,4,5]`  \r\n&gt; desired output:  `&quot;1-5&quot;`\r\n\r\nI have found a solution using `foreach`, but it does not seem very elegant and compact to me.\r\n\r\nIs there a simpler solution for this task?\r\n\r\n```jq\r\n[foreach (.[], 99999) as $current\r\n  ({};\r\n   if length == 0 then\r\n     {first: $current}\r\n   elif (has(&quot;last&quot;) | not) and .first + 1 != $current then\r\n     {first: $current, extract: &quot;\\(.first)&quot;}\r\n   elif has(&quot;last&quot;) and .last + 1 != $current then\r\n     {first: $current, extract: &quot;\\(.first)-\\(.last)&quot;}\r\n   else\r\n     {first, last: $current}\r\n   end;\r\n   .extract // empty\r\n  )]\r\n| join(&quot;,&quot;)\r\n```",
        "link": "https://stackoverflow.com/questions/70467714/replace-consecutive-integers-in-an-array-with-ranges",
        "title": "Replace consecutive integers in an array with ranges"
    },
    {
        "tags": [
            "shell",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640881971,
                "last_edit_date": 1640881971,
                "creation_date": 1640345973,
                "answer_id": 70472517,
                "question_id": 70472404,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `startswith` builtin function such as \r\n```\r\njq -r &#39;.Storages[] | select(.version | startswith(&quot;21a&quot;)) | {id, Volume}&#39; \r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/aIlldrqOeY)&lt;/kbd&gt;\r\n\r\n**Edit** : Assuming the JSON embedded into a file(`Storages.json`), then you can assign the results into shell variables such as\r\n```\r\n$ readarray -t vars &lt; &lt;( jq -r &#39;.Storages[] | select(.version|startswith(&quot;21a&quot;))| .id, .Volume&#39; Storages.json )\r\n```\r\nand display those variables as\r\n```\r\n$ declare -p vars\r\ndeclare -a vars=&#39;([0]=&quot;10003&quot; [1]=&quot;/home/abcd&quot;)&#39;\r\n```\r\n\r\n",
                "title": "looping through json object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640581396,
                "last_edit_date": 1640581396,
                "creation_date": 1640574149,
                "answer_id": 70491348,
                "question_id": 70472404,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For educational purposes, here&#39;s a `jq` command that does both the things you want, but in 2 separate steps:\r\n\r\n    jq -r &#39;del(.Storages[] | select(.version | startswith(&quot;21a&quot;) | not))\r\n           .Storages[] | {id, version}&#39;\r\n\r\nThe first part (`del(.Storages[] | select(.version | startswith(&quot;21a&quot;) | not))`) filters out the array elements that don&#39;t have a version starting with `21a`. The second part (`.Storages[] | {id, version}`) drills and extracts the specific information you need.",
                "title": "looping through json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1640881971,
        "creation_date": 1640345095,
        "last_edit_date": 1640861231,
        "question_id": 70472404,
        "body_markdown": "I have a json file which i have obtained using curl command and it looks as below.\r\n```json\r\n{\r\n  &quot;Storages&quot;: [\r\n    {\r\n      &quot;Creation&quot;: &quot;2020-04-21T14:01:54&quot;,\r\n      &quot;Modified&quot;: &quot;2020-04-21T14:01:54&quot;,\r\n      &quot;Volume&quot;: &quot;/dev/null&quot;,\r\n      &quot;id&quot;: 10000,\r\n      &quot;version&quot;: &quot;20190925-230722&quot;\r\n    },\r\n    {\r\n      &quot;Creation&quot;: &quot;2020-04-22T14:01:54&quot;,\r\n      &quot;Modified&quot;: &quot;2020-04-22T14:01:54&quot;,\r\n      &quot;Volume&quot;: &quot;/opt/home&quot;,\r\n      &quot;id&quot;: 10001,\r\n      &quot;version&quot;: &quot;22a-20190925-230722&quot;\r\n    },\r\n    {\r\n      &quot;Creation&quot;: &quot;2020-04-23T14:01:54&quot;,\r\n      &quot;Modified&quot;: &quot;2020-04-23T14:01:54&quot;,\r\n      &quot;Volume&quot;: &quot;/home/abcd&quot;,\r\n      &quot;id&quot;: 10003,\r\n      &quot;version&quot;: &quot;21c-20190925-230722&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNow I need to loop thorough array and get id and volume values into 2 variables if version startswith 21a. No need to form another json",
        "link": "https://stackoverflow.com/questions/70472404/looping-through-json-object-using-jq",
        "title": "looping through json object using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640348544,
                "post_id": 70472812,
                "comment_id": 124574667,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17621100,
                    "reputation": 11,
                    "user_id": 12787048,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-pp6Ua1jP-Lc/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rfVrbnbnDAfZw_Ki1YGj8QzuAywZw/s256-rj/photo.jpg",
                    "display_name": "la minute dom",
                    "link": "https://stackoverflow.com/users/12787048/la-minute-dom"
                },
                "reply_to_user": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640362686,
                "post_id": 70472812,
                "comment_id": 124578176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1640375744,
                "creation_date": 1640375744,
                "answer_id": 70476182,
                "question_id": 70472812,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This topic is covered in the [jq FAQ][1]. For the situation you describe you might be able to use the simpler of the two possibilities given there:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39;\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ#streaming-json-parser",
                "title": "one json object per line with jq from a large json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640375744,
        "creation_date": 1640348233,
        "last_edit_date": 1640348766,
        "question_id": 70472812,
        "body_markdown": "Here is my json file :\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;4&quot;\r\n  }\r\n]\r\n```\r\ni would like to get all object in a file one by line :\r\n\r\n    {&quot;name&quot;:&quot;1&quot;}\r\n    {&quot;name&quot;:&quot;2&quot;}\r\n    {&quot;name&quot;:&quot;3&quot;}\r\n    {&quot;name&quot;:&quot;4&quot;}\r\n\r\nand my file is very big and i&#39;am using the stream option.\r\n\r\nHere is my attempt so far :\r\n\r\n    jq --stream -c &#39;.[]&#39; car.json &gt; result.json\r\n\r\nbut it gives me :\r\n\r\n    [0,&quot;name&quot;]\r\n    &quot;1&quot;\r\n    [1,&quot;name&quot;]\r\n    &quot;2&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70472812/one-json-object-per-line-with-jq-from-a-large-json-file",
        "title": "one json object per line with jq from a large json file"
    },
    {
        "tags": [
            "bash",
            "jq",
            "couchbase"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640351525,
                "last_edit_date": 1640351525,
                "creation_date": 1640350648,
                "answer_id": 70473161,
                "question_id": 70473090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `unique` after applying array conversion and then `join` such as\r\n```\r\nproductIds=$(jq -r &#39;[.items[].product.id] | unique | join(&quot; &quot;)&#39; $Outputfile)\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/XMhdjKbdI4)&lt;/kbd&gt;",
                "title": "Duplicate ids are coming into result with some null values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1665727527,
        "creation_date": 1640350127,
        "last_edit_date": 1665727527,
        "question_id": 70473090,
        "body_markdown": "I have the below JSON where I want to filter out unique product.id into the array variable.\r\n\r\nI am using the below query but the result is not coming in the proper way.\r\n\r\n`productIds=($(jq -r .items[].product.id $Outputfile))` \r\n\r\n**Actual output**:\r\n123\r\n123\r\n123\r\n456\r\n456\r\nnull\r\nnull\r\n\r\n**Expected output**: \r\n123\r\n456\r\n\r\n```json\r\n{\r\n  &quot;documentType&quot;: &quot;product&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;ResourceId&quot;: null,\r\n      &quot;product&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;123&quot;,\r\n        &quot;mainId&quot;: &quot;qwe345&quot;,\r\n        &quot;primaryId&quot;: &quot;5298&quot;\r\n      },\r\n      &quot;lastModifiedBy&quot;: &quot;test&quot;,\r\n      &quot;quantity&quot;: null,\r\n      &quot;effectiveDate&quot;: null,\r\n      &quot;extensions&quot;: null\r\n    },\r\n    {\r\n      &quot;product&quot;: {\r\n        &quot;href&quot;: null,\r\n        &quot;id&quot;: &quot;123&quot;,\r\n        &quot;mainId&quot;: &quot;qwe678&quot;,\r\n        &quot;primaryId&quot;: &quot;5643&quot;\r\n      },\r\n      &quot;lastModifiedBy&quot;: &quot;test&quot;,\r\n      &quot;quantity&quot;: null,\r\n      &quot;effectiveDate&quot;: null,\r\n      &quot;extensions&quot;: null\r\n    }\r\n  ],\r\n  &quot;createdBy&quot;: &quot;test&quot;,\r\n  &quot;createdOn&quot;: &quot;2021-10-05&quot;,\r\n  &quot;currentSeqNum&quot;: 2\r\n}\r\n\r\n```\r\nThen I want to encode those value into base64 format and then concatenate with some constant value. I am not able to concatenate with constant as well and store in same variable inside loop.\r\n\r\nCan you please help me with above two issues.",
        "link": "https://stackoverflow.com/questions/70473090/duplicate-ids-are-coming-into-result-with-some-null-values",
        "title": "Duplicate ids are coming into result with some null values"
    },
    {
        "tags": [
            "azure",
            "terraform",
            "azure-sql-database",
            "jq",
            "terraform-provider-azure"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12671520,
                    "reputation": 20972,
                    "user_id": 9208887,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c4bf119024165bb1121e77fbd4115df?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "The Fool",
                    "link": "https://stackoverflow.com/users/9208887/the-fool"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640358566,
                "post_id": 70473422,
                "comment_id": 124577237,
                "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": 1640360859,
                "post_id": 70473422,
                "comment_id": 124577777,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640366685,
                "last_edit_date": 1640366685,
                "creation_date": 1640360671,
                "answer_id": 70474521,
                "question_id": 70473422,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t think there&#39;s enough information here to be certain, but I can give a partial, speculative answer.\r\n```\r\naz sql db list --resource-group $DB_RG --server $SERVER_NAME --query [*].id | grep -v master 2&gt;/dev/null\r\n```\r\nThis looks suspicious: the `az` command outputs JSON, but you&#39;re filtering it with grep. What does the output from `az` look like here? Do you expect the result to be valid JSON?\r\n\r\nYou say that our output has a comma that you don&#39;t expect. This is what you&#39;d expect to see if the `az` command spat out something like:\r\n```\r\n[\r\n  &quot;/blah/blah/databaseprd-db1&quot;,\r\n  &quot;/blah/blah/databaseprd-db2&quot;,\r\n  &quot;/blah/blah/databaseprd-db3&quot;,\r\n  &quot;/blah/blah/master&quot;\r\n]\r\n```\r\nThe `grep -v master` would remove the line containing the term &quot;master&quot;, leaving you with invalid JSON:\r\n```\r\n[\r\n  &quot;/blah/blah/databaseprd-db1&quot;,\r\n  &quot;/blah/blah/databaseprd-db2&quot;,\r\n  &quot;/blah/blah/databaseprd-db3&quot;,\r\n]\r\n```\r\n\r\nIf you want to use `jq`, you could replace the grep with something like\r\n```\r\njq &#39;map(select(index(&quot;master&quot;)|not))&#39;\r\n```\r\n",
                "title": "JSONDecode json format error from terraform"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640366685,
        "creation_date": 1640352845,
        "question_id": 70473422,
        "body_markdown": "Trying to add sql dbs created from azure portal to azure failover group.\r\n\r\nTerraform block will call bash script :\r\n\r\n    data &quot;external&quot; &quot;database_names&quot; {\r\n      program = [&quot;sh&quot;, &quot;${path.module}/scripts/fetch_db_id.sh&quot;]\r\n      query = {\r\n        db_rg            = azurerm_resource_group.mssql.name\r\n        server_name      = azurerm_mssql_server.mssqlserver.name\r\n      }\r\n    }\r\nfetch_db_id.sh bash script:\r\n\r\n\r\n    #!/usr/bin/env bash\r\n    # This script will get the database names at runtime.\r\n    eval &quot;$(jq -r &#39;@sh &quot;export DB_RG=\\(.db_rg) SERVER_NAME=\\(.server_name)&quot;&#39;)&quot;\r\n    \r\n    if [[ -z $DB_RG || -z $SERVER_NAME ]]; then\r\n    echo &quot;Required variables DB_RG &amp; SERVER_NAME not set&quot; 1&gt;&amp;2\r\n    exit 1\r\n    fi\r\n    \r\n    db_id=$(az sql db list --resource-group $DB_RG --server $SERVER_NAME --query [*].id | grep -v master 2&gt;/dev/null)\r\n    \r\n    jq -n --arg db_id &quot;$db_id&quot; &#39;{&quot;db_id&quot;:$db_id}&#39;\r\n    \r\n    unset DB_RG SERVER_NAME NODE_RG db_id\r\n    \r\n    exit 0\r\nBash script output : Ran it locally on a linux VM without terraform :\r\n\r\n*&quot;db_id&quot;: &quot;[\\n \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-db1\\&quot;,\\n \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-db2\\&quot;,\\n \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-db3\\&quot;\\n]&quot;\r\n}*\r\n\r\nTerraform resource block to add database inside failover group:\r\n\r\n    resource &quot;azurerm_sql_failover_group&quot; &quot;mssql_failover&quot; {\r\n      count                         = (var.enable_read_replica  &amp;&amp; var.environment == &quot;prd&quot;) ? 0 : 1\r\n      name                          = var.mssql_failover_group\r\n      resource_group_name           = azurerm_resource_group.mssql.name\r\n      server_name                   = azurerm_mssql_server.mssqlserver.name\r\n      databases                     = toset(jsondecode(data.external.database_names.result[&quot;db_id&quot;]))\r\n      partner_servers {\r\n        id = azurerm_mssql_server.replica[0].id\r\n      }\r\n    \r\n      read_write_endpoint_failover_policy {\r\n        mode                        = &quot;Automatic&quot;\r\n        grace_minutes               = 60\r\n      }\r\n      depends_on = [\r\n        azurerm_mssql_server.replica\r\n      ]\r\n    }\r\nterraform error code: when executed via terraform jenkins pipeline\r\n\r\n\r\n *[1mdata.external.database_names.result[&quot;db_id&quot;][0m is &quot;[\\n  \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-db1\\&quot;,\\n  \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-db2\\&quot;,\\n  \\&quot;/subscriptions/my_subscription_id/resourceGroups/sql_rg/providers/Microsoft.Sql/servers/sql_server_name/databases/databaseprd-**db3\\&quot;,\\n]&quot;**\r\nCall to function &quot;jsondecode&quot; failed: invalid character &#39;]&#39; looking for\r\n  beginning of value*\r\n\r\nNote: it is introducing an extra &quot;,&quot; when we run it with terraform jenkins pipeline, which could lead to json error.\r\n",
        "link": "https://stackoverflow.com/questions/70473422/jsondecode-json-format-error-from-terraform",
        "title": "JSONDecode json format error from terraform"
    },
    {
        "tags": [
            "arrays",
            "json",
            "dictionary",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640429428,
                "creation_date": 1640429428,
                "answer_id": 70479503,
                "question_id": 70479157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this code should work for you:\r\n\r\n```bash\r\ncurl https://sample_api | \\\r\njq -r &#39;(.product[0] | .A_key1, .A_key3.keyA3y_nested),\r\n       (.product[1] | .B_key1, .B_key3.keyB3y_nested)&#39;\r\n```",
                "title": "Need help parsing JSON structure using jq in Terminal"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640471656,
                "creation_date": 1640471656,
                "answer_id": 70483155,
                "question_id": 70479157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Hope this achieves what you are expecting :\r\n\r\n```\r\n#!/bin/bash \r\n                  \r\njq &#39;. as $root | null &#39;&quot;$(jq -nr &#39;\r\ndef spread_paths($array):\r\n    reduce $array[] as $element ([];\r\n        . + (if ($element|type) == &quot;object&quot;\r\n             then ($element | to_entries | map(.key + spread_paths(.value)[]) )\r\n             else [$element] end)\r\n        );\r\nspread_paths([   \r\n   {&quot;.product[0].&quot;: [&quot;A_key1&quot;, &quot;A_key3.keyA3y_nested&quot;]},\r\n   {&quot;.product[1].&quot;: [&quot;B_key1&quot;, &quot;B_key3.keyB3y_nested&quot;]}\r\n])[] | &quot;|\\(.)=$root\\(.)&quot;\r\n   &#39;) | map_values(.|add)&quot; input-file\r\n```",
                "title": "Need help parsing JSON structure using jq in Terminal"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1640471656,
        "creation_date": 1640425350,
        "question_id": 70479157,
        "body_markdown": "I have a JSON code in the following format, and I&#39;m having trouble figuring out how to use JQ to call information from the nested dictionaries within the objects within the list - if that makes sense. The list is the entire Value of the highest dictionary. Here is a sample of the structure:\r\n\r\n    { &quot;product&quot; : [ { &quot;A_key1&quot; : &quot;valueA1&quot;,\r\n                      &quot;A_key2&quot; : &quot;valueA2&quot;,\r\n                      &quot;A_key3&quot; : {&quot;keyA3x_nested&quot; : &quot;valueA3x_nested&quot;, &quot;keyA3y_nested&quot; : &quot;valueA3y_nested&quot;}\r\n                     },\r\n                    { &quot;B_key1&quot; : &quot;valueB1&quot;,\r\n                      &quot;B_key2&quot; : &quot;valueB2&quot;,\r\n                      &quot;B_key3&quot; : {&quot;keyB3x_nested&quot; : &quot;valueB3x_nested&quot;, &quot;keyB3y_nested&quot; : &quot;valueB3y_nested&quot;}\r\n                     },\r\n                  ]\r\n    }\r\n\r\nWhat I&#39;m trying to do is select only some items from different positions within the hierarchy as follows:\r\n\r\n{ &quot;product&quot;: { &quot;A_key1&quot;: &quot;valueA1&quot;, &quot;A_key3&quot;: {&quot;keyA3y_nested&quot;: &quot;valueA3y_nested&quot;} &quot;B_key1&quot;: &quot;valueB1&quot;, &quot;B_key3&quot;: {&quot;keyB3y_nested&quot;: &quot;valueB3y_nested&quot;} } }\r\n\r\nSo far, I am able to do this on the command prompt:\r\ncurl https://sample_api | jq &#39;{product : .product[0]}&#39;\r\n\r\n^ That returns the entire object for &quot;A&quot; which includes all 3 of A&#39;s keys, but how do I just pull information selectively from lower in the hierarchy?\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/70479157/need-help-parsing-json-structure-using-jq-in-terminal",
        "title": "Need help parsing JSON structure using jq in Terminal"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640463546,
                "last_edit_date": 1640463546,
                "creation_date": 1640437153,
                "answer_id": 70480184,
                "question_id": 70480119,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can convert to this one\r\n```\r\njq &#39;.[] | { (.description) : .tags }&#39;\r\n```\r\nin order to get rid of multiple occurences\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/SZBAZ5_Nwd)&lt;/kbd&gt;",
                "title": "How to solve JQ processing as multiple dictionaries if document has an array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1640466122,
        "creation_date": 1640436410,
        "last_edit_date": 1640466122,
        "question_id": 70480119,
        "body_markdown": "I have the following JSON document \r\n\r\n```json\r\n[\r\n  {\r\n    &quot;description&quot;: &quot;Component 1&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;abc&quot;,\r\n      &quot;123&quot;,\r\n      &quot;xyz&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;description&quot;: &quot;Component 2&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;def&quot;,\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;description&quot;: &quot;Component 3&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;def&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\nI have written below JQ filter to parse the JSON, the expected output is not to generate multiple dictionaries. \r\n```shell\r\n{ (.[].description):(.[].tags)}\r\n```\r\n\r\nAfter applying the filter, i get the below output with `multiple dictionaries` because of the `tags` array\r\n```JSON\r\n{\r\n  &quot;Component 1&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;123&quot;,\r\n    &quot;xyz&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 1&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 1&quot;: [\r\n    &quot;def&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 2&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;123&quot;,\r\n    &quot;xyz&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 2&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 2&quot;: [\r\n    &quot;def&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 3&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;123&quot;,\r\n    &quot;xyz&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 3&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 3&quot;: [\r\n    &quot;def&quot;\r\n  ]\r\n}\r\n\r\n\r\n```\r\nThe output I am expecting is without `multiple dictionaries` as below \r\n\r\n```JSON\r\n{\r\n  &quot;Component 1&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;123&quot;,\r\n    &quot;xyz&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 2&quot;: [\r\n    &quot;def&quot;,\r\n    &quot;foo&quot;,\r\n    &quot;bar&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Component 3&quot;: [\r\n    &quot;def&quot;\r\n  ]\r\n}\r\n```\r\n\r\nHow can I generate the above-expected output using JQ? \r\n\r\n",
        "link": "https://stackoverflow.com/questions/70480119/how-to-solve-jq-processing-as-multiple-dictionaries-if-document-has-an-array",
        "title": "How to solve JQ processing as multiple dictionaries if document has an array?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640465220,
                "last_edit_date": 1640465220,
                "creation_date": 1640464492,
                "answer_id": 70482600,
                "question_id": 70481609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To just bring together `.description` and `.tags` use\r\n```sh\r\njq &#39;.[] | del(.description, .tags) + ({(.description): .tags | join(&quot;;&quot;)})&#39;\r\n```\r\n[Demo](https://jqplay.org/s/ZL5erhQ2Bw)\r\n\r\nTo also group by `.project` and just consider `.project`, `.status` and an array with the `.description` and `.tags` from above, go\r\n```sh\r\njq &#39;\r\n  group_by(.project)[]\r\n  | (first | {project, status})\r\n  + {description: map({(.description): .tags | join(&quot;;&quot;)})}\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/ykhbMqlpAD)",
                "title": "How to solve JQ processing as multiple dictionaries if document has an array and JQ filter uses group_by?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640465836,
                "creation_date": 1640465836,
                "answer_id": 70482684,
                "question_id": 70481609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One similar option to yours would be \r\n```\r\njq &#39;group_by(.project)[] \r\n             | { project: .[0].project, status:.[0].status, &quot;description&quot;: [.[] \r\n             | { (.description) : .tags|join(&quot;;&quot;) } ] }&#39;\r\n```\r\n\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/yYXkS9DI0E)&lt;/kbd&gt;",
                "title": "How to solve JQ processing as multiple dictionaries if document has an array and JQ filter uses group_by?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1640466264,
        "creation_date": 1640452686,
        "last_edit_date": 1640466264,
        "question_id": 70481609,
        "body_markdown": "I have the following JSON document \r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 6,\r\n    &quot;description&quot;: &quot;Component 1&quot;,\r\n    &quot;due&quot;: &quot;20211122T183000Z&quot;,\r\n    &quot;entry&quot;: &quot;20211119T181735Z&quot;,\r\n    &quot;modified&quot;: &quot;20211119T181735Z&quot;,\r\n    &quot;project&quot;: &quot;product1&quot;,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;uuid&quot;: &quot;55bf0497-208c-492a-8f76-bb692d48afaa&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;abc&quot;,\r\n      &quot;123&quot;\r\n    ],\r\n    &quot;urgency&quot;: 13.9699\r\n  },\r\n  {\r\n    &quot;id&quot;: 10,\r\n    &quot;description&quot;: &quot;Component 2&quot;,\r\n    &quot;due&quot;: &quot;20211129T183000Z&quot;,\r\n    &quot;entry&quot;: &quot;20211130T045620Z&quot;,\r\n    &quot;modified&quot;: &quot;20211130T045620Z&quot;,\r\n    &quot;project&quot;: &quot;product2&quot;,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;uuid&quot;: &quot;d57eb8f7-e5ec-497c-ac47-f1cf34b005db&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;foo&quot;,\r\n      &quot;bar&quot;\r\n    ],\r\n    &quot;urgency&quot;: 14.0151\r\n  },\r\n  {\r\n    &quot;id&quot;: 11,\r\n    &quot;description&quot;: &quot;Component 3&quot;,\r\n    &quot;due&quot;: &quot;20211202T183000Z&quot;,\r\n    &quot;entry&quot;: &quot;20211130T121529Z&quot;,\r\n    &quot;completed&quot;: &quot;20211130T123915Z&quot;,\r\n    &quot;project&quot;: &quot;product3&quot;,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;uuid&quot;: &quot;9f15e6a4-5cef-4b0f-915b-fc916ab152c7&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;xyz&quot;,\r\n      &quot;676&quot;\r\n    ],\r\n    &quot;urgency&quot;: 14.0096\r\n  },\r\n  {\r\n    &quot;id&quot;: 12,\r\n    &quot;description&quot;: &quot;Component 4&quot;,\r\n    &quot;due&quot;: &quot;20211202T183000Z&quot;,\r\n    &quot;entry&quot;: &quot;20211130T122537Z&quot;,\r\n    &quot;pending&quot;: &quot;20211130T122537Z&quot;,\r\n    &quot;project&quot;: &quot;product1&quot;,\r\n    &quot;status&quot;: &quot;pending&quot;,\r\n    &quot;uuid&quot;: &quot;91c9ec76-42a7-4ebc-9649-b3a12027feb1&quot;,\r\n    &quot;tags&quot;: [\r\n      &quot;def&quot;\r\n    ],\r\n    &quot;urgency&quot;: 13.9096\r\n  }\r\n]\r\n```\r\nI have written below JQ filter to parse the JSON, the expected output is not to generate multiple dictionaries. \r\n```\r\ngroup_by(.project,.status)  \r\n         | .[] \r\n         | { project: .[0].project , status: .[0].status , \r\n             description: [{&quot;\\(.[].description)&quot; : (.[].tags | join(&quot;;&quot;))}] }\r\n\r\n```\r\n\r\nAfter applying the filter, i get the below output with `multiple dictionaries` because of the `tags` array\r\n```JSON\r\n{\r\n  &quot;project&quot;: &quot;product1&quot;,\r\n  &quot;status&quot;: &quot;pending&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 1&quot;: &quot;abc;123&quot;\r\n    },\r\n    {\r\n      &quot;Component 1&quot;: &quot;def&quot;\r\n    },\r\n    {\r\n      &quot;Component 4&quot;: &quot;abc;123&quot;\r\n    },\r\n    {\r\n      &quot;Component 4&quot;: &quot;def&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;project&quot;: &quot;product2&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 2&quot;: &quot;foo;bar&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;project&quot;: &quot;product3&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 3&quot;: &quot;xyz;676&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\nThe output I am expecting is without `multiple dictionaries` as below \r\n\r\n```JSON\r\n{\r\n  &quot;project&quot;: &quot;product1&quot;,\r\n  &quot;status&quot;: &quot;pending&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 1&quot;: &quot;abc;123&quot;\r\n    },\r\n    {\r\n      &quot;Component 4&quot;: &quot;def&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;project&quot;: &quot;product2&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 2&quot;: &quot;foo;bar&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;project&quot;: &quot;product3&quot;,\r\n  &quot;status&quot;: &quot;completed&quot;,\r\n  &quot;description&quot;: [\r\n    {\r\n      &quot;Component 3&quot;: &quot;xyz;676&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can I generate the above-expected output using JQ? \r\n\r\n```",
        "link": "https://stackoverflow.com/questions/70481609/how-to-solve-jq-processing-as-multiple-dictionaries-if-document-has-an-array-and",
        "title": "How to solve JQ processing as multiple dictionaries if document has an array and JQ filter uses group_by?"
    },
    {
        "tags": [
            "json",
            "regex",
            "string",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640492165,
                "last_edit_date": 1640492165,
                "creation_date": 1640472569,
                "answer_id": 70483232,
                "question_id": 70482956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do the trick:\r\n```\r\ndef deregex:\r\n  reduce (&quot;\\\\\\\\&quot;, &quot;\\\\*&quot;, &quot;\\\\^&quot;, &quot;\\\\?&quot;, &quot;\\\\+&quot;, &quot;\\\\.&quot;, &quot;\\\\!&quot;, &quot;\\\\{&quot;, &quot;\\\\}&quot;, &quot;\\\\[&quot;, &quot;\\\\]&quot;, &quot;\\\\$&quot;, &quot;\\\\|&quot;, &quot;\\\\(&quot;, &quot;\\\\)&quot; ) as $c \r\n    (.; gsub( $c; $c));\r\n```\r\n\r\nExample:\r\n```\r\n&quot;^.*$&quot;,\r\n &quot;/*&quot;,\r\n &quot;*/&quot;\r\n| [., deregex]\r\n```\r\nproduces:\r\n```\r\n[&quot;^.*$&quot;,&quot;\\\\^\\\\.\\\\*\\\\$&quot;]\r\n[&quot;/*&quot;,&quot;/\\\\*&quot;]\r\n[&quot;*/&quot;,&quot;\\\\*/&quot;]\r\n```",
                "title": "Escape Regex special characters in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1640476900,
                "creation_date": 1640476900,
                "answer_id": 70483499,
                "question_id": 70482956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The limits of working without functions that use regexes may be peferable to the risks of missing any regex syntax, for example with `split/1`:\r\n\r\n    TEXT=&#39;Hello $ spaceman Spiff&#39;\r\n    SEARCH=&#39;Hello $&#39;   # does not work, because &#39;$&#39; is interpreted as regex special character\r\n    REPLACE=&#39;Ola &#39;\r\n    echo &quot;$TEXT&quot; | \\\r\n    \tjq -rR --arg search &quot;$SEARCH&quot; --arg replace &quot;$REPLACE&quot; &#39;split($search)|join($replace)&#39;",
                "title": "Escape Regex special characters in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1640521025,
        "creation_date": 1640469196,
        "last_edit_date": 1640521025,
        "question_id": 70482956,
        "body_markdown": "I want to do search and replace in a larger `jq` program. \r\nThe problem is that `search` may contain special characters that are interpreted as regex functionality, which I dont want. Special characters should be treated like normal characters.  \r\n\r\nSo what I need is a regex format escaping function, similar to `@uri`, `@html` or `@sh`.\r\nHow can I escape _all_ special characters that have meaning in regular expressions (brackets, ., ?, *, + etc.) in the search string so that they are not interpreted as regex syntax?\r\n\r\n```bash\r\nTEXT=&#39;Hello $ spaceman Spiff&#39;\r\nSEARCH=&#39;Hello $&#39;   # does not work, because &#39;$&#39; is interpreted as regex special character\r\nREPLACE=&#39;Ola &#39;\r\necho &quot;$TEXT&quot; | \\\r\njq -rR --arg search &quot;$SEARCH&quot; --arg replace &quot;$REPLACE&quot; &#39;gsub($search; $replace; &quot;g&quot;)&#39;\r\n```\r\n\r\nIn the original program, &#39;search&#39; and &#39;replace&#39; are defined in an external file (passed here by parameter) and the replacement takes place as part of a larger processing of text data coming from another external source.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70482956/escape-regex-special-characters-in-jq",
        "title": "Escape Regex special characters in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1640512417,
                "creation_date": 1640512417,
                "answer_id": 70485536,
                "question_id": 70485305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Both `{junction:.records[].nas.path}`and `{uuid:.records[].uuid}` produce a stream of two objects each due to the iteration caused by `.records[]`. Adding up the cartesian product, this totals to four objects.\r\n\r\nIf you want to iterate jut once, pull out the iterator `.records[]` up front to define a common input context for the subsequent filter:\r\n```\r\n.records[] | {junction:.nas.path} + {uuid:.uuid}\r\n```\r\nThis can then further be simplified to\r\n```\r\n.records[] | {junction:.nas.path, uuid}\r\n```\r\n```json\r\n{\r\n  &quot;junction&quot;: &quot;/data/nlp/datasets/ds0&quot;,\r\n  &quot;uuid&quot;: &quot;14e20b5a-6619-11ec-a838-0050568168f7&quot;\r\n}\r\n{\r\n  &quot;junction&quot;: &quot;/data/nlp/datasets/ds1&quot;,\r\n  &quot;uuid&quot;: &quot;799ce816-656c-11ec-a838-0050568168f7&quot;\r\n}\r\n```\r\nwhich is presumably what you were looking for.\r\n\r\n[Demo](https://jqplay.org/s/2qL6XRIQ3N)",
                "title": "JQ duplicate results in output json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1640512584,
        "creation_date": 1640509661,
        "last_edit_date": 1640512584,
        "question_id": 70485305,
        "body_markdown": "I have the following input json for jq: \r\n\r\n```json\r\n{\r\n  &quot;records&quot;: [\r\n    {\r\n      &quot;uuid&quot;: &quot;14e20b5a-6619-11ec-a838-0050568168f7&quot;,\r\n      &quot;nas&quot;: {\r\n        &quot;path&quot;: &quot;/data/nlp/datasets/ds0&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;uuid&quot;: &quot;799ce816-656c-11ec-a838-0050568168f7&quot;,\r\n      &quot;nas&quot;: {\r\n        &quot;path&quot;: &quot;/data/nlp/datasets/ds1&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat is the reason the following jq duplicate the results:\r\n\r\n```\r\n[{junction:.records[].nas.path}+{uuid:.records[].uuid}]\r\n```\r\n\r\nResult:\r\n```json\r\n[\r\n  {\r\n    &quot;junction&quot;: &quot;/data/nlp/datasets/ds0&quot;,\r\n    &quot;uuid&quot;: &quot;14e20b5a-6619-11ec-a838-0050568168f7&quot;\r\n  },\r\n  {\r\n    &quot;junction&quot;: &quot;/data/nlp/datasets/ds1&quot;,\r\n    &quot;uuid&quot;: &quot;14e20b5a-6619-11ec-a838-0050568168f7&quot;\r\n  },\r\n  {\r\n    &quot;junction&quot;: &quot;/data/nlp/datasets/ds0&quot;,\r\n    &quot;uuid&quot;: &quot;799ce816-656c-11ec-a838-0050568168f7&quot;\r\n  },\r\n  {\r\n    &quot;junction&quot;: &quot;/data/nlp/datasets/ds1&quot;,\r\n    &quot;uuid&quot;: &quot;799ce816-656c-11ec-a838-0050568168f7&quot;\r\n  }\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70485305/jq-duplicate-results-in-output-json",
        "title": "JQ duplicate results in output json"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6186008,
                    "reputation": 3720,
                    "user_id": 4820101,
                    "user_type": "registered",
                    "accept_rate": 24,
                    "profile_image": "https://www.gravatar.com/avatar/760db34fde55539cd06db424c46bc4fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "samshers",
                    "link": "https://stackoverflow.com/users/4820101/samshers"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640542774,
                "post_id": 70488126,
                "comment_id": 124602519,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6186008,
                    "reputation": 3720,
                    "user_id": 4820101,
                    "user_type": "registered",
                    "accept_rate": 24,
                    "profile_image": "https://www.gravatar.com/avatar/760db34fde55539cd06db424c46bc4fb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "samshers",
                    "link": "https://stackoverflow.com/users/4820101/samshers"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640543317,
                "post_id": 70488126,
                "comment_id": 124602601,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640538336,
                "last_edit_date": 1640538336,
                "creation_date": 1640537744,
                "answer_id": 70488237,
                "question_id": 70488126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The string quotes are part of bash scripting and are needed if you want to pass an argument that contains spaces to a command. In your case the arguments does not contain spaces, so no quotes are needed to pass `.[&quot;app.properties&quot;]` as argument to `jq`.  \r\n\r\nIn the last case bash concatenates one string with two spaces `.[&quot;., ., app.properties&quot;]` that is passed to `jq` as _one_ argument.\r\n\r\nSo your fellow developer is doing everything right ;-)\r\nAlthough I myself also find it clearer to use simple quotes for the entire jq program.",
                "title": "Whats happening when jq commands are used without quotes?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1640538327,
                "creation_date": 1640538327,
                "answer_id": 70488328,
                "question_id": 70488126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Actually, also `cat explorejq.json |  jq &#39;.data &#39; | jq &#39;.&quot;app.properties&quot;&#39;` would work (or simplified to `jq &#39;.data.&quot;app.properties&quot;&#39; explorejq.json`). The relevant part is that `&quot;app.properties&quot;` is surrounded by quotes as it needs to be a JSON string (within jq). In turn, the whole jq filter is also a string for the calling environment (within the shell). That&#39;s why you also need to quote the filter (if it contains spaces, quotes etc). However, as it contains double quotes for the JSON string, single quotes are the appropriate choice for the jq filter string. If you did&#39;t use those outer quotes, the shell would interpret itself the inner ones as string boundaries and as such they wouldn&#39;t appear in the actual jq filter anymore. As a consequence, jq would fail in rendering `app.properties` as actual JSON string.",
                "title": "Whats happening when jq commands are used without quotes?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640569630,
                "creation_date": 1640569630,
                "answer_id": 70491041,
                "question_id": 70488126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ve already figured out that the shell is processing `.[&quot;., ., app.properties&quot;]` into `..` but you may not have figured out why yet.\r\n\r\nUnquoted square brackets are [pattern-matching syntax for a single character][1], similar to the way `?` is a wildcard for any single character and `*` is a wildcard for zero or more characters. In this case, you&#39;ve created a pattern-match for any file with a name starting with `.` and followed by any single character from the set `., ., app.properties` which simplifies to the set `., aeioprst`. Since `..` is present in every directory, it always matches and you get `..`. However, if for example you had a file called `.p` in the current directory, it would match too and you&#39;d send an extra argument to `jq`. The immediate lesson of the story is always single-quote your filter argument to `jq`. The broader moral is that it&#39;s hard to learn and remember all the shell rules and behaviours, but it&#39;s much easier to remember a safe subset. If you know that single quotes pass the entire argument through verbatim, and if you stick to them for any argument containing characters you&#39;re unsure might have special behaviour, you don&#39;t need to worry about all the things you don&#39;t know.\r\n\r\n[1]: https://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_13_01",
                "title": "Whats happening when jq commands are used without quotes?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640572407,
                "creation_date": 1640572407,
                "answer_id": 70491229,
                "question_id": 70488126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may want to take advantage of the `-f` option of jq, where you can put your filter program in a file, and have jq read it from the file. This saves you from the hassles of shell quoting.\r\n\r\n",
                "title": "Whats happening when jq commands are used without quotes?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640739992,
                "last_edit_date": 1640739992,
                "creation_date": 1640739311,
                "answer_id": 70514095,
                "question_id": 70488126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, \r\n\r\n```sh\r\ncat explorejq.json | jq &#39;.data &#39; | jq &#39;.[&quot;app.properties&quot;]&#39;\r\n```\r\n\r\nis better written as one of the following:\r\n\r\n```sh\r\njq &#39;.data.[&quot;app.properties&quot;]&#39; explorejq.json\r\n```\r\n\r\n```sh\r\njq &#39;.data.&quot;app.properties&quot;&#39; explorejq.json\r\n```\r\n\r\nTo keep things simple, I&#39;ll be using the first of those commands as the example in the rest of the post.\r\n\r\n---\r\n\r\nThe following is the jq program you want to execute:\r\n\r\n```jq\r\n.data.[&quot;app.properties&quot;]\r\n```\r\n\r\nSo you want to devise a shell command that passes that string as an argument. \r\n\r\nBecause `&quot;` is special to the shell, this won&#39;t do:\r\n\r\n```sh\r\njq .data.[&quot;app.properties&quot;]      # XXX Passes `.data.[app.properties]`\r\n```\r\n\r\nYou need to employ some form of quoting or escaping. The following are two options:\r\n\r\n```sh\r\njq &#39;.data.[&quot;app.properties&quot;]&#39;    # Ok. Passes `.data.[&quot;app.properties&quot;]`\r\n```\r\n\r\n```sh\r\njq .data.[\\&quot;app.properties\\&quot;]    # Ok. Passes `.data.[&quot;app.properties&quot;]`\r\n```\r\n\r\n---\r\n\r\nQuoting tips:\r\n\r\nIf it doesn&#39;t contain single quotes (`&#39;`), you can simply wrap the argument in single quotes.\r\n\r\nIf it does contain single quotes (`&#39;`), you can simply wrap the argument in single quotes, plus replace each existing `&#39;` with `&#39;\\&#39;&#39;`.\r\n",
                "title": "Whats happening when jq commands are used without quotes?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 1,
        "last_activity_date": 1640739992,
        "creation_date": 1640536893,
        "last_edit_date": 1640551711,
        "question_id": 70488126,
        "body_markdown": "This is my data file: `explorejq.json` - \r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;data&quot;: {\r\n            &quot;app.properties&quot;: &quot;some.base64encoded.data&quot;\r\n        },\r\n        &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n        &quot;metadata&quot;: {\r\n            &quot;creationTimestamp&quot;: &quot;2021-05-17T09:54:15Z&quot;,\r\n            &quot;name&quot;: &quot;myappproperties&quot;,\r\n            &quot;namespace&quot;: &quot;myappnamespace&quot;,\r\n            &quot;resourceVersion&quot;: &quot;352258550&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/namespaces/myappnamespace/configmap/myappproperties&quot;,\r\n            &quot;uid&quot;: &quot;cb23197e-54ee-412a-a07a-7d02df3d59a1&quot;\r\n        },\r\n        &quot;type&quot;: &quot;IncorrectType&quot;\r\n    }\r\n\r\nAnd i want to retrive the value of key `app.properties` which is nested in `data`. I know the right way of doing this is using -   \r\n`cat explorejq.json |  jq &#39;.data &#39; | jq &#39;.[&quot;app.properties&quot;]&#39;` or    \r\n`cat explorejq.json |  jq &#39;.data | .[&quot;app.properties&quot;]&#39;`  and i get   \r\noutput:   `&quot;some.base64encoded.data&quot;`    as required\r\n\r\n**Now the problem is one of my fellow developer is using jq commands without single quotes for the last part.  Example -**  \r\n`cat explorejq.json |  jq &#39;.data &#39; | jq .[&quot;app.properties&quot;]`  or  \r\n`cat explorejq.json |  jq &#39;.data &#39; | jq .[&quot;.app.properties&quot;]`    or  \r\n`cat explorejq.json |  jq &#39;.data &#39; | jq .[&quot;., ., app.properties&quot;]`    and getting   \r\noutput -   \r\n\r\n    {\r\n      &quot;app.properties&quot;: &quot;some.base64encoded.data&quot;\r\n    }\r\n    &quot;some.base64encoded.data&quot;\r\nNow, i know all the above three are incorrect ways, but i need to understand whats happening in these cases so i can explain the same.\r\n\r\nCan someone explain what happens when jq commands are used without single quote and particularly whats happening in above cases.\r\n\r\n**Edit -**  \r\nBasically the issue here is with `jq .[&quot;app.properties&quot;]`. Shell is interpreting it before passing it to jq.  \r\n`echo jq .[&quot;., ., app.properties&quot;]` output: `jq ..`.\r\nSame is the case with rest of the two patterns i mentioned.\r\n\r\nSo posted a new Q here - [what is .. (two dots) in jq filter][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/70489706/what-is-two-dots-in-jq-filter",
        "link": "https://stackoverflow.com/questions/70488126/whats-happening-when-jq-commands-are-used-without-quotes",
        "title": "Whats happening when jq commands are used without quotes?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1719739530,
                "last_edit_date": 1719739530,
                "creation_date": 1640551566,
                "answer_id": 70489743,
                "question_id": 70489706,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is the [recursive descent](https://jqlang.github.io/jq/manual/v1.6/#recursive-descent) operator `..`. Starting from the input, it recursively descends and produces every value it can find.\r\n\r\nFirst, you see the whole input (the array), then each member of the array (the objects), and after each of them all field values within an object (the strings).\r\n",
                "title": "what is .. (two dots) in jq filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1719739530,
        "creation_date": 1640551293,
        "question_id": 70489706,
        "body_markdown": "given my input file: kind.json\r\n\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap2&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap&#39;4&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap\\&quot;6&quot;\r\n      }\r\n    ]\r\n\r\nand on using jq command `jq .. kind.json`, i am seeing unexpected output. You can see that here -&gt; https://jqplay.org/s/pTe-CtdXV1. \r\n\r\n    [\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap2&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap&#39;4&quot;\r\n      },\r\n      {\r\n        &quot;kind&quot;: &quot;ConfigMap\\&quot;6&quot;\r\n      }\r\n    ]\r\n    {\r\n      &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n    }\r\n    &quot;ConfigMap1&quot;\r\n    {\r\n      &quot;kind&quot;: &quot;ConfigMap1&quot;\r\n    }\r\n    &quot;ConfigMap1&quot;\r\n    {\r\n      &quot;kind&quot;: &quot;ConfigMap2&quot;\r\n    }\r\n    &quot;ConfigMap2&quot;\r\n    {\r\n      &quot;kind&quot;: &quot;ConfigMap&#39;4&quot;\r\n    }\r\n    &quot;ConfigMap&#39;4&quot;\r\n    {\r\n      &quot;kind&quot;: &quot;ConfigMap\\&quot;6&quot;\r\n    }\r\n    &quot;ConfigMap\\&quot;6&quot;\r\n\r\n \r\nJust wondering what the two dots mean here and what jq is doing here. Any help and explanation will be greatly appriciated. \r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70489706/what-is-two-dots-in-jq-filter",
        "title": "what is .. (two dots) in jq filter"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640591645,
                "post_id": 70492898,
                "comment_id": 124609941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 220462,
                    "reputation": 181667,
                    "user_id": 477878,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/qounX.jpg?s=256",
                    "display_name": "Joachim Isaksson",
                    "link": "https://stackoverflow.com/users/477878/joachim-isaksson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640592214,
                "post_id": 70492898,
                "comment_id": 124610065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1640592247,
                "creation_date": 1640592247,
                "answer_id": 70492993,
                "question_id": 70492898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need try like: \r\n\r\n    .fruits |= sort_by(.version)\r\n\r\nExample: https://jqplay.org/s/ntjioYhKWq\r\n\r\nReference [sort by keys][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/30331504/how-to-sort-a-json-file-by-keys-and-values-of-those-keys-in-jq",
                "title": "using jq how to sort array of object"
            },
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1640600494,
                "last_edit_date": 1640600494,
                "creation_date": 1640595923,
                "answer_id": 70493529,
                "question_id": 70492898,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`cat fruits.json | jq &#39;.fruits | sort_by(-.version)[0].price&#39; `\r\n\r\nproduces:\r\n\r\n`0.52`",
                "title": "using jq how to sort array of object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 10,
        "last_activity_date": 1640600494,
        "creation_date": 1640591499,
        "question_id": 70492898,
        "body_markdown": "There is an array of json object, using jq how to check if an object exists if so returns the true else false\r\n\r\nI tried this but getting error\r\n\r\n    cat fruits.json | jq &#39;.fruits[]| sort_by(.version)&#39;\r\n\r\nI would like to sort by decending order and output the price of the most recent version.\r\n\r\n    {\r\n        &quot;fruits&quot;: [\r\n            {\r\n                &quot;name&quot;: &quot;banana&quot;,\r\n                &quot;color&quot;: &quot;yellow&quot;,\r\n                &quot;price&quot;: 0.51,\r\n               &quot;version&quot;: 1\r\n            },\r\n            {\r\n                &quot;name&quot;: &quot;banana&quot;,\r\n                &quot;color&quot;: &quot;yellow&quot;,\r\n                &quot;price&quot;: 0.52,\r\n                &quot;version&quot;: 2\r\n            }\r\n        ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70492898/using-jq-how-to-sort-array-of-object",
        "title": "using jq how to sort array of object"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640598498,
                "creation_date": 1640598498,
                "answer_id": 70493909,
                "question_id": 70493870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n```sh\r\njq -r --arg name &quot;test3&quot; &#39;.values[] | select(.name== $name).id&#39;\r\n```\r\n```\r\n10002\r\n```\r\n[Demo](https://jqplay.org/s/VS3d1W0vlx)",
                "title": "Json response data extraction using linux command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1640602136,
        "creation_date": 1640598230,
        "last_edit_date": 1640602136,
        "question_id": 70493870,
        "body_markdown": "Below is the json response of an api endpoint, I wanted to get the id value of specific name in the below array of json response.\r\n```json\r\n{\r\n  &quot;self&quot;: &quot;https://testtoo.atlassian.net/rest/api/3/project/TEST/version?maxResults=50&amp;startAt=0&quot;,\r\n  &quot;maxResults&quot;: 50,\r\n  &quot;startAt&quot;: 0,\r\n  &quot;total&quot;: 2,\r\n  &quot;isLast&quot;: true,\r\n  &quot;values&quot;: [\r\n    {\r\n      &quot;self&quot;: &quot;https://testtoo.atlassian.net/rest/api/3/version/10001&quot;,\r\n      &quot;id&quot;: &quot;10001&quot;,\r\n      &quot;description&quot;: &quot;test release&quot;,\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;archived&quot;: false,\r\n      &quot;released&quot;: true,\r\n      &quot;releaseDate&quot;: &quot;2021-12-29&quot;,\r\n      &quot;userReleaseDate&quot;: &quot;29/Dec/21&quot;,\r\n      &quot;projectId&quot;: 10000\r\n    },\r\n    {\r\n      &quot;self&quot;: &quot;https://testtoo.atlassian.net/rest/api/3/version/10002&quot;,\r\n      &quot;id&quot;: &quot;10002&quot;,\r\n      &quot;name&quot;: &quot;test3&quot;,\r\n      &quot;archived&quot;: false,\r\n      &quot;released&quot;: true,\r\n      &quot;projectId&quot;: 10000\r\n    }\r\n  ]\r\n}\r\n```\r\neg: I wanted to get id value(10002) of name test3, with the help of name key. Using jq I&#39;m able to select the name key, but I&#39;m not to find a way to get previous key value(id) using name key! My requirement is to get id value by inputting the corresponding name value.",
        "link": "https://stackoverflow.com/questions/70493870/json-response-data-extraction-using-linux-command",
        "title": "Json response data extraction using linux command"
    },
    {
        "tags": [
            "shell",
            "sed",
            "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": 2,
                "creation_date": 1640650189,
                "post_id": 70501541,
                "comment_id": 124625589,
                "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": 1640663784,
                "post_id": 70501541,
                "comment_id": 124627455,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640680464,
                "creation_date": 1640680464,
                "answer_id": 70504553,
                "question_id": 70501541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Bengamin W. comment put me on track with the use of arguments. I finally managed to append a couple of new fields to an existing json file like this:\r\n\r\n`echo $(jq --arg a &quot;$firstValue&quot; --arg b &quot;$secondValue&quot; &#39;.firstField=$a | .secondField=$b&#39; $jsonFileAddress) &gt; $jsonFileAddress`",
                "title": "I can&#39;t use sed or jq with variables including whitespaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640681619,
        "creation_date": 1640649378,
        "question_id": 70501541,
        "body_markdown": "I want to add a couple fields to a json file in a shell script. The values for both files come in a parameter and there doesn&#39;t seem to be a way to make sed or jq work with such values. I&#39;ve traid with simple and double quotes everywhere but can&#39;t make it work.\r\n\r\n`sh myscript.sh &#39;value&#39; &#39;second value&#39;`\r\n\r\n```\r\nfirstValue=$1\r\nsecondValue=$2\r\n\r\njq &#39;.firstField=&quot;&#39;$firstValue&#39;&quot; | .secondField=&quot;&#39;$secondValue&#39;&quot;&#39; $jsonFileAddress\r\nsed -i &#39;$s/}/,&quot;firstField&quot;:&quot;&#39;$firstValue&#39;&quot;,&quot;secondField&quot;:&quot;&#39;$secondValue&#39;&quot;}/&#39; $jsonFileAddress\r\n```",
        "link": "https://stackoverflow.com/questions/70501541/i-cant-use-sed-or-jq-with-variables-including-whitespaces",
        "title": "I can&#39;t use sed or jq with variables including whitespaces"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "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": 3,
                "creation_date": 1640656336,
                "post_id": 70502025,
                "comment_id": 124626457,
                "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": 1640656577,
                "post_id": 70502025,
                "comment_id": 124626503,
                "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": 1640718289,
                "post_id": 70502025,
                "comment_id": 124642350,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1640656870,
                "last_edit_date": 1640656870,
                "creation_date": 1640656401,
                "answer_id": 70502078,
                "question_id": 70502025,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need `cat` (you don&#39;t _ever_ need `cat` when reading from a single file; its purpose is to _concatenate_ multiple input sources together). Take it out, and everything gets far easier:\r\n\r\n```python\r\nsubprocess.run([&#39;jq&#39;, &#39;-c&#39;, &#39;.features[]&#39;],\r\n               stdin=open(os.path.expanduser(&#39;~/file1.json&#39;), &#39;r&#39;),\r\n               stdout=open(&#39;converted.json&#39;, &#39;w&#39;))\r\n```\r\n\r\nYou can also avoid the `stdin=` argument by passing the input filename (after replacing the `~` with a fully-qualified path, since there&#39;s no shell to do it for you) on jq&#39;s command line:\r\n\r\n```python\r\nsubprocess.run([&#39;jq&#39;, &#39;-c&#39;, &#39;.features[]&#39;,\r\n                os.path.expanduser(&#39;~/file1.json&#39;)\r\n               ], stdout=open(&#39;converted.json&#39;, &#39;w&#39;))\r\n\r\n```\r\n\r\nIf you want to read output to a variable instead of writing it to a file, take out the `stdout=` argument and add `capture_output=True`.",
                "title": "How to run jq command in python?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1640656870,
        "creation_date": 1640655935,
        "question_id": 70502025,
        "body_markdown": "I am following a bigquery geospatial guide, and my json file is changed via a jq command. Specifically this one:\r\n\r\n```cat ~/file1.json | jq -c &#39;.features[]&#39; &gt; converted.json```\r\n\r\nI&#39;m having difficulties running the equivalent of above in python. I&#39;m using the subprocess module, and it&#39;s not working.\r\n\r\n```cmd = [&#39;cat&#39;, &#39;./sample.json&#39;, &#39;|&#39;, &#39;c&#39;, &#39;.features[]&#39;]```\r\n\r\n```print(subprocess.check_output(cmd))```\r\n\r\nthe output im getting is this:\r\n```\r\ncat: |: No such file or directory\r\ncat: -c: No such file or directory\r\ncat: .features[]: No such file or directory\r\nTraceback (most recent call last):\r\n  File &quot;/Users/rtom/kml2geo/main.py&quot;, line 12, in &lt;module&gt;\r\n    result = subprocess.check_output(cmd)\r\n  File &quot;/Users/rtom/opt/anaconda3/lib/python3.8/subprocess.py&quot;, line 415, in check_output\r\n    return run(*popenargs, stdout=PIPE, timeout=timeout, check=True,\r\n  File &quot;/Users/rtom/opt/anaconda3/lib/python3.8/subprocess.py&quot;, line 516, in run\r\n    raise CalledProcessError(retcode, process.args,\r\nsubprocess.CalledProcessError: Command &#39;[&#39;cat&#39;, &#39;./sample.json&#39;, &#39;|&#39;, &#39;-c&#39;, &#39;.features[]&#39;]&#39; returned non-zero exit status 1.\r\n(base) rtom@Ryans-MacBook-Pro kml2geo %\r\n```\r\n\r\n\r\nAny help here?\r\n",
        "link": "https://stackoverflow.com/questions/70502025/how-to-run-jq-command-in-python",
        "title": "How to run jq command in python?"
    },
    {
        "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": 1640670997,
                "post_id": 70502720,
                "comment_id": 124628507,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23762871,
                    "reputation": 1,
                    "user_id": 17778003,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/52f7be0624e82355b8f58066c620f417?s=256&d=identicon&r=PG",
                    "display_name": "Chris Livermore",
                    "link": "https://stackoverflow.com/users/17778003/chris-livermore"
                },
                "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": 1640673548,
                "post_id": 70502720,
                "comment_id": 124628947,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640674310,
                "creation_date": 1640674310,
                "answer_id": 70503666,
                "question_id": 70502720,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that you are piping the filenames to jq rather than making the contents available to jq. \r\n\r\nMost likely you could use the following approach, e.g. if you want the augmented contents of each file to be handled separately:\r\n\r\n\r\n    find ... | while read f ; do jq ... &quot;$f&quot; ; done\r\n\r\nAn alternative that might be relevant would be:\r\n\r\n    jq ... $(find ...)\r\n\r\n",
                "title": "iterating through JSON files adding properties to each with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640760482,
                "creation_date": 1640760482,
                "answer_id": 70516008,
                "question_id": 70502720,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have 2 files:\r\nfile01.json :\r\n\r\n    {&quot;a&quot;:&quot;1&quot;,&quot;b&quot;:&quot;2&quot;}\r\n\r\nfile02.json :\r\n\r\n    {&quot;x&quot;:&quot;10&quot;,&quot;y&quot;:&quot;12&quot;,&quot;z&quot;:&quot;15&quot;}\r\n\r\nyou can: \r\n\r\n    for f in file*.json ;do cat $f | jq  &#39;. +  { creators:[{address: &quot;xxx&quot;,share:1}] } &#39;  ; done\r\n\r\n\r\n**result:**\r\n\r\n    {\r\n      &quot;a&quot;: &quot;1&quot;,\r\n      &quot;b&quot;: &quot;2&quot;,\r\n      &quot;creators&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;xxx&quot;,\r\n          &quot;share&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;x&quot;: &quot;10&quot;,\r\n      &quot;y&quot;: &quot;12&quot;,\r\n      &quot;z&quot;: &quot;15&quot;,\r\n      &quot;creators&quot;: [\r\n        {\r\n          &quot;address&quot;: &quot;xxx&quot;,\r\n          &quot;share&quot;: 1\r\n        }\r\n      ]\r\n    }",
                "title": "iterating through JSON files adding properties to each with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1640760482,
        "creation_date": 1640664792,
        "last_edit_date": 1640674766,
        "question_id": 70502720,
        "body_markdown": "I am attempting to iterate through all my JSON files and add properties but I am relatively new jq.\r\n\r\nhere is what I am attempting:\r\n\r\n```sh\r\nfind hashlips_art_engine/build -type f -name &#39;*.json&#39; | jq &#39;. + {\r\n  &quot;creators&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;4iUFmB3H3RZGRrtuWhCMtkXBT51iCUnX8UV7R8rChJsU&quot;,\r\n      &quot;share&quot;: 10\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;2JApg1AXvo1Xvrk3vs4vp3AwamxQ1DHmqwKwWZTikS9w&quot;,\r\n      &quot;share&quot;: 45\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;Zdda4JtApaPs47Lxs1TBKTjh1ZH2cptjxXMwrbx1CWW&quot;,\r\n      &quot;share&quot;: 45\r\n    }\r\n  ]\r\n}&#39;\r\n```\r\n\r\nHowever this is returning an error: \r\n\r\n&gt; parse error: Invalid numeric literal at line 2, column 0\r\n\r\nI have around 10,000 JSON files that I need to iterate over and add \r\n```json\r\n{\r\n  &quot;creators&quot;: [\r\n    {\r\n      &quot;address&quot;: &quot;4iUFmB3H3RZGRrtuWhCMtkXBT51iCUnX8UV7R8rChJsU&quot;,\r\n      &quot;share&quot;: 10\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;2JApg1AXvo1Xvrk3vs4vp3AwamxQ1DHmqwKwWZTikS9w&quot;,\r\n      &quot;share&quot;: 45\r\n    },\r\n    {\r\n      &quot;address&quot;: &quot;Zdda4JtApaPs47Lxs1TBKTjh1ZH2cptjxXMwrbx1CWW&quot;,\r\n      &quot;share&quot;: 45\r\n    }\r\n  ]\r\n}\r\n```\r\nto, is this possible or am I barking up the wrong tree on this?\r\n\r\nthanks for your assistance with this, I have been searching the web for several hours now but either my terminology is incorrect or there isn&#39;t much out there regarding this issue.",
        "link": "https://stackoverflow.com/questions/70502720/iterating-through-json-files-adding-properties-to-each-with-jq",
        "title": "iterating through JSON files adding properties to each with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1640670767,
                "last_edit_date": 1640670767,
                "creation_date": 1640670460,
                "answer_id": 70503215,
                "question_id": 70503009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `transpose` builtin to match the array members to each other\r\n```sh\r\njq -r &#39;.MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | @csv&#39;\r\n```\r\n```csv\r\n&quot;2021-12-28T02:11:00Z&quot;,5,&quot;groupDesiredCapacity&quot;\r\n&quot;2021-12-28T02:10:00Z&quot;,2,&quot;groupDesiredCapacity&quot;\r\n&quot;2021-12-28T02:09:00Z&quot;,2,&quot;groupDesiredCapacity&quot;\r\n...\r\n&quot;2021-12-28T01:54:00Z&quot;,0.4000066667777796,&quot;cpuUtilization&quot;\r\n&quot;2021-12-28T01:53:00Z&quot;,58.31569473842103,&quot;cpuUtilization&quot;\r\n&quot;2021-12-28T01:52:00Z&quot;,5.98135840794e-05,&quot;cpuUtilization&quot;\r\n```\r\n[Demo](https://jqplay.org/s/U0nQ-al5aC)\r\n\r\nIf you want to have your desired output format instead of csv, replace `@csv` with `join(&quot; | &quot;)`\r\n```sh\r\njq -r &#39;.MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | join(&quot; | &quot;)&#39;\r\n```\r\n```\r\n2021-12-28T02:11:00Z | 5 | groupDesiredCapacity\r\n2021-12-28T02:10:00Z | 2 | groupDesiredCapacity\r\n2021-12-28T02:09:00Z | 2 | groupDesiredCapacity\r\n...\r\n2021-12-28T01:54:00Z | 0.4000066667777796 | cpuUtilization\r\n2021-12-28T01:53:00Z | 58.31569473842103 | cpuUtilization\r\n2021-12-28T01:52:00Z | 5.98135840794e-05 | cpuUtilization\r\n```\r\n[Demo](https://jqplay.org/s/WW9WKjUH2I)",
                "title": "jq map values from different arrays"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1640670672,
                "creation_date": 1640670672,
                "answer_id": 70503239,
                "question_id": 70503009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward alternative:\r\n```\r\n.MetricDataResults[]\r\n| .Id as $Id\r\n| range(0; .Timestamps|length) as $i\r\n| [.Timestamps[$i], .Values[$i], $Id]\r\n| @csv\r\n```",
                "title": "jq map values from different arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1640671008,
        "creation_date": 1640668328,
        "last_edit_date": 1640671008,
        "question_id": 70503009,
        "body_markdown": "I want to parse the following json array that comes out of AWS GetMetricData API. It contains the timestamps and values in different arrays: \r\n\r\n```json\r\n{\r\n    &quot;Messages&quot;: [],\r\n    &quot;MetricDataResults&quot;: [\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-12-28T02:11:00Z&quot;,\r\n                &quot;2021-12-28T02:10:00Z&quot;,\r\n                &quot;2021-12-28T02:09:00Z&quot;,\r\n                &quot;2021-12-28T02:08:00Z&quot;,\r\n                &quot;2021-12-28T02:07:00Z&quot;,\r\n                &quot;2021-12-28T02:06:00Z&quot;,\r\n                &quot;2021-12-28T02:05:00Z&quot;,\r\n                &quot;2021-12-28T02:04:00Z&quot;,\r\n                &quot;2021-12-28T02:03:00Z&quot;,\r\n                &quot;2021-12-28T02:02:00Z&quot;,\r\n                &quot;2021-12-28T02:01:00Z&quot;,\r\n                &quot;2021-12-28T02:00:00Z&quot;,\r\n                &quot;2021-12-28T01:59:00Z&quot;,\r\n                &quot;2021-12-28T01:58:00Z&quot;,\r\n                &quot;2021-12-28T01:57:00Z&quot;,\r\n                &quot;2021-12-28T01:56:00Z&quot;,\r\n                &quot;2021-12-28T01:55:00Z&quot;,\r\n                &quot;2021-12-28T01:54:00Z&quot;,\r\n                &quot;2021-12-28T01:53:00Z&quot;,\r\n                &quot;2021-12-28T01:52:00Z&quot;,\r\n                &quot;2021-12-28T01:51:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                5.0,\r\n                2.0,\r\n                2.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                0.0\r\n            ],\r\n            &quot;Id&quot;: &quot;groupDesiredCapacity&quot;,\r\n            &quot;Label&quot;: &quot;myRequestLabel&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-12-28T02:11:00Z&quot;,\r\n                &quot;2021-12-28T02:10:00Z&quot;,\r\n                &quot;2021-12-28T02:09:00Z&quot;,\r\n                &quot;2021-12-28T02:08:00Z&quot;,\r\n                &quot;2021-12-28T02:07:00Z&quot;,\r\n                &quot;2021-12-28T02:06:00Z&quot;,\r\n                &quot;2021-12-28T02:05:00Z&quot;,\r\n                &quot;2021-12-28T02:04:00Z&quot;,\r\n                &quot;2021-12-28T02:03:00Z&quot;,\r\n                &quot;2021-12-28T02:02:00Z&quot;,\r\n                &quot;2021-12-28T02:01:00Z&quot;,\r\n                &quot;2021-12-28T02:00:00Z&quot;,\r\n                &quot;2021-12-28T01:59:00Z&quot;,\r\n                &quot;2021-12-28T01:58:00Z&quot;,\r\n                &quot;2021-12-28T01:57:00Z&quot;,\r\n                &quot;2021-12-28T01:56:00Z&quot;,\r\n                &quot;2021-12-28T01:55:00Z&quot;,\r\n                &quot;2021-12-28T01:54:00Z&quot;,\r\n                &quot;2021-12-28T01:53:00Z&quot;,\r\n                &quot;2021-12-28T01:52:00Z&quot;,\r\n                &quot;2021-12-28T01:51:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                5.0,\r\n                2.0,\r\n                2.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                1.0,\r\n                0.0\r\n            ],\r\n            &quot;Id&quot;: &quot;groupInServiceCapacity&quot;,\r\n            &quot;Label&quot;: &quot;myRequestLabel&quot;\r\n        },\r\n        {\r\n            &quot;Timestamps&quot;: [\r\n                &quot;2021-12-28T02:11:00Z&quot;,\r\n                &quot;2021-12-28T02:10:00Z&quot;,\r\n                &quot;2021-12-28T02:09:00Z&quot;,\r\n                &quot;2021-12-28T02:08:00Z&quot;,\r\n                &quot;2021-12-28T02:07:00Z&quot;,\r\n                &quot;2021-12-28T02:06:00Z&quot;,\r\n                &quot;2021-12-28T02:05:00Z&quot;,\r\n                &quot;2021-12-28T02:04:00Z&quot;,\r\n                &quot;2021-12-28T02:03:00Z&quot;,\r\n                &quot;2021-12-28T02:02:00Z&quot;,\r\n                &quot;2021-12-28T02:01:00Z&quot;,\r\n                &quot;2021-12-28T02:00:00Z&quot;,\r\n                &quot;2021-12-28T01:59:00Z&quot;,\r\n                &quot;2021-12-28T01:58:00Z&quot;,\r\n                &quot;2021-12-28T01:57:00Z&quot;,\r\n                &quot;2021-12-28T01:56:00Z&quot;,\r\n                &quot;2021-12-28T01:55:00Z&quot;,\r\n                &quot;2021-12-28T01:54:00Z&quot;,\r\n                &quot;2021-12-28T01:53:00Z&quot;,\r\n                &quot;2021-12-28T01:52:00Z&quot;\r\n            ],\r\n            &quot;StatusCode&quot;: &quot;Complete&quot;,\r\n            &quot;Values&quot;: [\r\n                94.20519316022799,\r\n                97.325,\r\n                99.95833333333333,\r\n                99.94166666666666,\r\n                97.35833333333333,\r\n                62.375,\r\n                96.61666666666666,\r\n                0.3916666666666666,\r\n                0.3833525009583812,\r\n                0.391647084312451,\r\n                24.05873431223854,\r\n                60.84898585023583,\r\n                64.54059099015015,\r\n                25.07541792363206,\r\n                0.25,\r\n                0.2499958334027766,\r\n                0.28333333333333327,\r\n                0.4000066667777796,\r\n                58.31569473842103,\r\n                5.98135840794e-05\r\n            ],\r\n            &quot;Id&quot;: &quot;cpuUtilization&quot;,\r\n            &quot;Label&quot;: &quot;myRequestLabel&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI&#39;m trying to transform it to a table that looks like this:\r\n```\r\nTimestamp | Value | Id\r\n2021-12-28T02:11:00Z | 5.0 | groupDesiredCapacity\r\n```\r\nI googled around and came up with this jq query\r\n`.MetricDataResults[] | {t: .Timestamps[], v: .Values[],i: .Id}|[.t,.v,.i]|@csv`\r\nbut it seems to &quot;multiply&quot; the values instead of mapping them.\r\n\r\nA bit stuck on this one, any ideas/help are appreciated.\r\n",
        "link": "https://stackoverflow.com/questions/70503009/jq-map-values-from-different-arrays",
        "title": "jq map values from different arrays"
    },
    {
        "tags": [
            "json",
            "command-line-interface",
            "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": 1640762615,
                "post_id": 70514746,
                "comment_id": 124651293,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640756746,
                "creation_date": 1640756746,
                "answer_id": 70515563,
                "question_id": 70514746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I hope this can be useful, in this example there are 3 items one with effect: NoSchedule, one with effect: anyother and one with taints empty. If am correct, you need only the second one:\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;8768&quot;\r\n      },\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/nodes/ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;uid&quot;: &quot;2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h&quot;,\r\n            &quot;resourceVersion&quot;: &quot;8768&quot;,\r\n            &quot;creationTimestamp&quot;: &quot;2020-11-19T12:27:05Z&quot;\r\n              },\r\n          &quot;spec&quot;: {\r\n            &quot;podCIDR&quot;: &quot;101.191.101.101/24&quot;,\r\n            &quot;providerID&quot;: &quot;aws:///us-west-1e/i-lidss9jsjldsjli&quot;,\r\n            &quot;taints&quot;: [\r\n              {\r\n                &quot;key&quot;: &quot;worker-group&quot;,\r\n                &quot;value&quot;: &quot;prometheus&quot;,\r\n                &quot;effect&quot;: &quot;NoSchedule&quot;\r\n              }\r\n            ]\r\n          }\r\n        },\r\n    \r\n      {\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/nodes/ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;uid&quot;: &quot;2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h&quot;,\r\n            &quot;resourceVersion&quot;: &quot;8768&quot;,\r\n            &quot;creationTimestamp&quot;: &quot;2020-11-19T12:27:05Z&quot;\r\n              },\r\n          &quot;spec&quot;: {\r\n            &quot;podCIDR&quot;: &quot;101.191.101.101/24&quot;,\r\n            &quot;providerID&quot;: &quot;aws:///us-west-1e/i-lidss9jsjldsjli&quot;,\r\n            &quot;taints&quot;: [\r\n              {\r\n                &quot;key&quot;: &quot;worker-group&quot;,\r\n                &quot;value&quot;: &quot;prometheus&quot;,\r\n                &quot;effect&quot;: &quot;anyother&quot;\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;selfLink&quot;: &quot;/api/v1/nodes/ip-101-191-101-101.ec2.internal&quot;,\r\n            &quot;uid&quot;: &quot;2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h&quot;,\r\n            &quot;resourceVersion&quot;: &quot;8768&quot;,\r\n            &quot;creationTimestamp&quot;: &quot;2020-11-19T12:27:05Z&quot;\r\n              },\r\n          &quot;spec&quot;: {\r\n            &quot;podCIDR&quot;: &quot;101.191.101.101/24&quot;,\r\n            &quot;providerID&quot;: &quot;aws:///us-west-1e/i-lidss9jsjldsjli&quot;,\r\n            &quot;taints&quot;: [\r\n    \r\n            ]\r\n          }\r\n        }\r\n    \r\n    \r\n      ]\r\n\r\n**The command will be:**\r\n\r\n     jq &#39;.items[]|select(.spec.taints[].effect!=&quot;NoSchedule&quot;) &#39; data1.jtxt\r\n\r\nresult:\r\n \r\n\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ip-101-191-101-101.ec2.internal&quot;,\r\n        &quot;selfLink&quot;: &quot;/api/v1/nodes/ip-101-191-101-101.ec2.internal&quot;,\r\n        &quot;uid&quot;: &quot;2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h&quot;,\r\n        &quot;resourceVersion&quot;: &quot;8768&quot;,\r\n        &quot;creationTimestamp&quot;: &quot;2020-11-19T12:27:05Z&quot;\r\n      },\r\n      &quot;spec&quot;: {\r\n        &quot;podCIDR&quot;: &quot;101.191.101.101/24&quot;,\r\n        &quot;providerID&quot;: &quot;aws:///us-west-1e/i-lidss9jsjldsjli&quot;,\r\n        &quot;taints&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;worker-group&quot;,\r\n            &quot;value&quot;: &quot;prometheus&quot;,\r\n            &quot;effect&quot;: &quot;anyother&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nNote: I put your data ina a file to simulate input.",
                "title": "How to ignore json elements when a nested array has an key:value matching patterm?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640757299,
                "creation_date": 1640757299,
                "answer_id": 70515621,
                "question_id": 70514746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on the question, my understanding is that the `taints` could have multiple entries. It could be a mix of `NoSchedule` and other values. Here&#39;s the `jq` where the item will be ignored if at least one taint with `effect` value `NoSchedule` exists.\r\n\r\n```\r\n. as $in | $in * { items: $in.items | map(select(.spec.taints | all(.effect != &quot;NoSchedule&quot;))) }```",
                "title": "How to ignore json elements when a nested array has an key:value matching patterm?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640774456,
                "creation_date": 1640774456,
                "answer_id": 70518269,
                "question_id": 70514746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This deletes from the `.items` array every member that has an array in `.spec.taints` which in turn has at least one object item with `.effect` set to `&quot;NoSchedule&quot;`. In every other case, i.e. there&#39;s only objects with `.effect` set to something else, or `.taints` is empty, or there&#39;s no `.taints` at all, or there&#39;s no `.spec` at all, up to just an empty object `{}` as member of the `.items` array, that array member will be retained.\r\n\r\n```\r\n.items -= (.items | map(select(.spec.taints[].effect == &quot;NoSchedule&quot;)?))\r\n```\r\n[Demo](https://jqplay.org/s/u7lhoa7Kss)",
                "title": "How to ignore json elements when a nested array has an key:value matching patterm?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640777071,
                "creation_date": 1640777071,
                "answer_id": 70518750,
                "question_id": 70514746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `del` to delete the one(s) you intended :\r\n\r\n```\r\ncurl api | jq &#39;del(.items[] | select(.spec.taints[].effect == &quot;NoSchedule&quot;)?)&#39;\r\n```",
                "title": "How to ignore json elements when a nested array has an key:value matching patterm?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1640777071,
        "creation_date": 1640747048,
        "question_id": 70514746,
        "body_markdown": "I have been using jq(1) and getting a similar response back from a kubernetes api (api/v1/nodes). \r\n\r\n\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;8768&quot;\r\n  },\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ip-101-191-101-101.ec2.internal&quot;,\r\n        &quot;selfLink&quot;: &quot;/api/v1/nodes/ip-101-191-101-101.ec2.internal&quot;,\r\n        &quot;uid&quot;: &quot;2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h&quot;,\r\n        &quot;resourceVersion&quot;: &quot;8768&quot;,\r\n        &quot;creationTimestamp&quot;: &quot;2020-11-19T12:27:05Z&quot;,\r\n          },\r\n      &quot;spec&quot;: {\r\n        &quot;podCIDR&quot;: &quot;101.191.101.101/24&quot;,\r\n        &quot;providerID&quot;: &quot;aws:///us-west-1e/i-lidss9jsjldsjli&quot;,\r\n        &quot;taints&quot;: [\r\n          {\r\n            &quot;key&quot;: &quot;worker-group&quot;,\r\n            &quot;value&quot;: &quot;prometheus&quot;,\r\n            &quot;effect&quot;: &quot;NoSchedule&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs you can see there can be many **items** in the Array. There are some with the .spec.taints and others without it. Some may be empty and some may be full. \r\n\r\nMy goal is to just ignore all items that have the taints `&quot;effect&quot;: &quot;NoSchedule&quot;`\r\n\r\nI&#39;m finding this very troublesome because no matter what I try and I&#39;ve been searching online for days, i can&#39;t get it to work properly. \r\n\r\nI&#39;ve gotten this far but am now stuck\r\n\r\n`curl api | jq -c &#39;.items[].spec.taints |= map(select(.effect | . != &quot;NoSchedule&quot;))&#39;`\r\n\r\nany help would be appreciated. ",
        "link": "https://stackoverflow.com/questions/70514746/how-to-ignore-json-elements-when-a-nested-array-has-an-keyvalue-matching-patter",
        "title": "How to ignore json elements when a nested array has an key:value matching patterm?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1640800466,
                "post_id": 70522587,
                "comment_id": 124663315,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1640813990,
                "last_edit_date": 1640813990,
                "creation_date": 1640804625,
                "answer_id": 70523842,
                "question_id": 70522587,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\ndef to_set(s): reduce s as $_ ( {}; .[ $_ ] = true );\r\n\r\n[ &quot;PROM_FD_ARCNA&quot;, &quot;PROM_JOB_ICMP&quot;, &quot;PROM_JOB_WIN&quot; ] as $roots |\r\n\r\nmap(\r\n   {\r\n      name,\r\n      has_rg: to_set( .rgs | split( &quot;, &quot; )[] )\r\n   }\r\n) as $hosts |\r\n\r\n[\r\n   range( 0;    $roots | length ) as $i |  $roots[ $i ] as $g1 |\r\n   range( $i+1; $roots | length ) as $j |  $roots[ $j ] as $g2 |\r\n   {\r\n      root_rgs: [ $g1, $g2 ],\r\n      names: [\r\n         $hosts[] |\r\n         select( .has_rg[ $g1 ] and .has_rg[ $g2 ] ) |\r\n         .name\r\n      ]\r\n   } |\r\n   select( .names | length &gt; 0 )\r\n]\r\n```\r\n\r\nproduces\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;root_rgs&quot;: [\r\n      &quot;PROM_FD_ARCNA&quot;,\r\n      &quot;PROM_JOB_ICMP&quot;\r\n    ],\r\n    &quot;names&quot;: [\r\n      &quot;HCC02155&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;root_rgs&quot;: [\r\n      &quot;PROM_FD_ARCNA&quot;,\r\n      &quot;PROM_JOB_WIN&quot;\r\n    ],\r\n    &quot;names&quot;: [\r\n      &quot;VM00006&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n[Demo](https://jqplay.org/s/7rLRDrgTao) on jqplay\r\n",
                "title": "How to spare &amp; group objects according key-value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640813990,
        "creation_date": 1640797224,
        "last_edit_date": 1640801293,
        "question_id": 70522587,
        "body_markdown": "I&#39;m new on this, those are my first steps. I guess I&#39;ve started with a not simple case.\r\n\r\nLet&#39;s see: \r\nI have objects, with an ID (`name`) and a resource group (`rgs`). Each object may be part of several groups. And what a do need is to get the intersections of the groups.\r\n\r\nIt is important to say that the object may part of several groups, which are parent-child groups, and I just need to get the parent group. It is easy to identify the parenthoods as they share prefixes.\r\n\r\ne.g. Group `PROM_FD_ARCNA` contains the child groups `PROM_FD_ARCNA_TGM` and `PROM_FD_ARCNA_TGM_TGA`.\r\nAnd the child groups contains the objects itself. But, as long as I can get the information from object, it is over. \r\n\r\nThe parent groups are `PROM_FD_ARCNA`, `PROM_JOB_ICMP` and `PROM_JOB_WIN`. That is to say, I need to get those objects which belong to the intersections of those groups.\r\n\r\nThe JSON file which looks like:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;id_ci&quot;: &quot;487006&quot;,\r\n        &quot;name&quot;: &quot;LABTNSARWID625&quot;,\r\n        &quot;id_ci_class&quot;: &quot;host&quot;,\r\n        &quot;rgs&quot;: &quot;PROM_FD_ARCNA, PROM_FD_ARCNA_TGM, PROM_FD_ARCNA_TGM_TGA&quot;\r\n    },\r\n    {\r\n        &quot;id_ci&quot;: &quot;5706&quot;,\r\n        &quot;name&quot;: &quot;HCCQ2001&quot;,\r\n        &quot;id_ci_class&quot;: &quot;host&quot;,\r\n        &quot;rgs&quot;: &quot;PROM_JOB_ICMP&quot;\r\n    },\r\n    {\r\n        &quot;id_ci&quot;: &quot;9106&quot;,\r\n        &quot;name&quot;: &quot;HCC02155&quot;,\r\n        &quot;id_ci_class&quot;: &quot;host&quot;,\r\n        &quot;rgs&quot;: &quot;PROM_FD_ARCNA, PROM_FD_ARCNA_TGA, PROM_JOB_ICMP&quot;\r\n    },\r\n    {\r\n        &quot;id_ci&quot;: &quot;2306&quot;,\r\n        &quot;name&quot;: &quot;VM00006&quot;,\r\n        &quot;id_ci_class&quot;: &quot;host&quot;,\r\n        &quot;rgs&quot;: &quot;PROM_FD_ARCNA, PROM_FD_ARCNA_TGA, PROM_JOB_WIN, PROM_JOB_WIN_TGA&quot;\r\n    }\r\n]\r\n```\r\n\r\nIf my explanation was not good, I need to get a JSON like this:\r\n\r\n```json\r\nPROM_FD_ARCNA, PROM_JOB_ICMP\r\n{\r\n&quot;HCC02155&quot;\r\n}\r\n\r\nPROM_FD_ARCNA, PROM_JOB_WIN \r\n{\r\n&quot;VM00006&quot;\r\n}\r\n```\r\n\r\nAs those are the intersections.\r\n\r\n\r\n---------------------------------------------\r\n\r\nSo far, I tried this: \r\n\r\n```sh\r\njq &#39;[.[] | select(.id_ci_class == &quot;host&quot;) | select (.rgs | startswith(&quot;PROM_FD_ARCNA&quot;)) | .rgs = &quot;PROM_FD_ARCNA&quot;] \r\n| group_by(.rgs) | map({&quot;rgs&quot;: .[0].rgs, &quot;Hosts&quot;: map(.name)}) &#39;  ./prom_jobs.json &gt;&gt; Step0A.json \r\n```\r\n\r\n```sh\r\njq &#39;[.[] | select(.id_ci_class == &quot;host&quot;) | select (.rgs | startswith(&quot;PROM_JOB_WIN&quot;)) | .rgs = &quot;PROM_JOB_WIN&quot;] \r\n| group_by(.rgs) | map({&quot;rgs&quot;: .[0].rgs, &quot;Hosts&quot;: map(.name)}) &#39;  ./prom_jobs.json &gt;&gt; Step0A.json \r\n```\r\n\r\n```sh\r\njq &#39;[.[] | select(.id_ci_class == &quot;host&quot;) | select (.rgs | startswith(&quot;PROM_JOB_ICMP&quot;)) | .rgs = &quot;PROM_JOB_ICMP&quot;] \r\n| group_by(.rgs) | map({&quot;rgs&quot;: .[0].rgs, &quot;Hosts&quot;: map(.name)}) &#39;  ./prom_jobs.json &gt;&gt; Step0A.json\r\n```\r\n\r\nAnd the result is:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;rgs&quot;: &quot;PROM_FD_ARCNA&quot;,\r\n    &quot;Hosts&quot;: [\r\n      &quot;LABTNSARWID625&quot;,\r\n      &quot;HCC02155&quot;,\r\n      &quot;VM00006&quot;\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;rgs&quot;: &quot;PROM_JOB_WIN&quot;,\r\n    &quot;Hosts&quot;: [\r\n      &quot;VM00006&quot;\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;rgs&quot;: &quot;PROM_JOB_ICMP&quot;,\r\n    &quot;Hosts&quot;: [\r\n      &quot;HCCQ2001&quot;,\r\n      &quot;HCC02155&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nOf course, the full JSON is quite long and I need to process this as lightweight as possible. Don&#39;t know if I&#39;ve started well or bad.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70522587/how-to-spare-group-objects-according-key-value",
        "title": "How to spare &amp; group objects according key-value"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640805658,
                "last_edit_date": 1640805658,
                "creation_date": 1640805347,
                "answer_id": 70523976,
                "question_id": 70523457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this using [String interpolation](https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-%5C(foo))\r\n```sh\r\n… | jq -r &#39;.observations[]\r\n  | &quot;Wind Direction: \\(.winddir)&quot;\r\n  , &quot;Humidity: \\(.humidity)&quot;\r\n  , &quot;Temperature: \\(.imperial.temp)&quot;\r\n&#39; \r\n```\r\n```\r\nWind Direction: 292\r\nHumidity: 92\r\nTemperature: 20\r\n```\r\n[Demo](https://jqplay.org/s/uCJH3aMH37)",
                "title": "jq: missing key in front of the value, only value is printing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1640808493,
                "last_edit_date": 1640808493,
                "creation_date": 1640806924,
                "answer_id": 70524237,
                "question_id": 70523457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet you can keep *the original key names* through use of\r\n```\r\njq -r &#39;.observations[] | {winddir},{humidity},(.imperial| {temp})| &quot;\\(keys[]) : \\(.[])&quot;&#39;\r\n```\r\nwhich results\r\n```\r\nwinddir : 292\r\nhumidity : 92\r\ntemp : 20\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/AztkjHph7z)&lt;/kbd&gt;",
                "title": "jq: missing key in front of the value, only value is printing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1640808493,
        "creation_date": 1640802323,
        "last_edit_date": 1640807255,
        "question_id": 70523457,
        "body_markdown": "This is the raw data I pull from my api:\r\n```\r\n{\r\n  &quot;observations&quot;: [\r\n    {\r\n      &quot;winddir&quot;: 292,\r\n      &quot;humidity&quot;: 92,\r\n      &quot;qcStatus&quot;: 1,\r\n      &quot;imperial&quot;: {\r\n        &quot;temp&quot;: 20,\r\n        &quot;heatIndex&quot;: 20,\r\n        &quot;dewpt&quot;: 40,\r\n        &quot;windChill&quot;: 20,\r\n        &quot;windSpeed&quot;: 3, \r\n        &quot;windGust&quot;: 3,\r\n        &quot;pressure&quot;: 29.71,\r\n        &quot;precipRate&quot;: 0,\r\n        &quot;precipTotal&quot;: 0.01,\r\n        &quot;elev&quot;: 1905\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nThis is the command that I run:\r\n\r\n    curl -s &#39;https://api.myawesomeapidata.com&#39; | jq -r &#39;.observations[].winddir, .observations[].humidity, .observations[].imperial.temp&#39;\r\n\r\nThis is the output:\r\n\r\n    292\r\n    92\r\n    20\r\n\r\nThis is the output I would like:\r\n\r\n    Wind Direction: 292\r\n    Humidity: 92\r\n    Temperature: 20\r\n\r\nBut I would be fine if this were the output:\r\n\r\n    winddir: 292\r\n    humidity: 92\r\n    temp: 20\r\n\r\nAs you can see, I would like the key to appear in front of the value. Preferably allowing me to change the name of the key (Wind Direction) before printing, but I would also be fine with the original key name (winddir).  ",
        "link": "https://stackoverflow.com/questions/70523457/jq-missing-key-in-front-of-the-value-only-value-is-printing",
        "title": "jq: missing key in front of the value, only value is printing"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640890468,
                "creation_date": 1640890468,
                "answer_id": 70535624,
                "question_id": 70535534,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq &#39;.[] | select( .id == 1 ) | .attributes.preferences&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/P5ebBreXda) on jqplay",
                "title": "Parse JSON Elements in Array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640929611,
        "creation_date": 1640889843,
        "question_id": 70535534,
        "body_markdown": "I&#39;m trying to figure out how to print just the attributes-&gt;preferences section in the following JSON example using jq.  What&#39;s throwing me is that this is an array that contains multiple entries that are identified by an id key value pair and I need the attributes-&gt;preferences section just from the array element with id 1 without knowing the exact order of the array entries ahead of time.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;attributes&quot;: {\r\n      &quot;preferences&quot;: {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;,\r\n        &quot;key3&quot;: &quot;value3&quot;,\r\n        &quot;key4&quot;: &quot;value4&quot;,\r\n        ...\r\n      }\r\n    },\r\n    ...\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    ...\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    ...\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nMy desired output would be:\r\n```\r\n{\r\n  &quot;key1&quot;: &quot;value1&quot;,\r\n  &quot;key2&quot;: &quot;value2&quot;,\r\n  &quot;key3&quot;: &quot;value3&quot;,\r\n  &quot;key4&quot;: &quot;value4&quot;,\r\n  ...\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/70535534/parse-json-elements-in-array-with-jq",
        "title": "Parse JSON Elements in Array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1640935086,
                "creation_date": 1640935086,
                "answer_id": 70539910,
                "question_id": 70539704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When the extraneous comma is removed from the JSON, and when the -r command-line option is used, the filter:\r\n\r\n```\r\nto_entries[]\r\n| select( any(.value[]; test(&quot;\\\\*\\\\*\\\\*&quot;) ))\r\n| .key\r\n```\r\nproduces the stream:\r\n```\r\n19\r\n20\r\n333\r\n3454\r\n23\r\n23424\r\n\r\n```\r\n\r\nYou can easily package these values any way you want, e.g. using jq itself.",
                "title": "How to get root elements contains specific character"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640940216,
                "creation_date": 1640940216,
                "answer_id": 70540502,
                "question_id": 70539704,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@peak&#39;s [solution](https://stackoverflow.com/a/70539910/2158479) is the right answer to the question asked. However, if you want to _dive into_ the encoded JSON contained within the top arrays&#39; third elements and search just in them instead, use the `fromjson` builtin:\r\n```\r\nto_entries[]\r\n| select(any(.value[2] | fromjson | .RegistrationUserID[]; test(&quot;\\\\*\\\\*\\\\*&quot;)))\r\n| .key\r\n```\r\n```\r\n19\r\n20\r\n333\r\n3454\r\n23\r\n23424\r\n```\r\n[Demo](https://jqplay.org/s/bbwIHfsnGu)\r\n",
                "title": "How to get root elements contains specific character"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1640940216,
        "creation_date": 1640933215,
        "question_id": 70539704,
        "body_markdown": "I have a json file and want to extract all root elements contains a specific character in array.\r\n\r\nMy json file structure:\r\n\r\n    {\r\n\t&quot;12&quot;: [\r\n\t\t&quot;12&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {}\\r\\n}&quot;\r\n\t],\r\n\t&quot;19&quot;: [\r\n\t\t&quot;23&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019***091\\&quot;,\\r\\n    \\&quot;2\\&quot;: \\&quot;2019****67\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n\t&quot;20&quot;: [\r\n\t\t&quot;434&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019****83\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n\t&quot;333&quot;: [\r\n\t\t&quot;25&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019****32\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n\t&quot;3454&quot;: [\r\n\t\t&quot;55&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019****1\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n\t&quot;23&quot;: [\r\n\t\t&quot;66&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019****5\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n\t&quot;23424&quot;: [\r\n\t\t&quot;34&quot;,\r\n\t\t&quot;200 OK&quot;,\r\n\t\t&quot;{\\r\\n  \\&quot;ResponseText\\&quot;: null,\\r\\n  \\&quot;RegistrationUserID\\&quot;: {\\r\\n    \\&quot;1\\&quot;: \\&quot;2019****2\\&quot;\\r\\n  }\\r\\n}&quot;\r\n\t],\r\n}\r\n\r\n\r\nI want to extract all root values contains &quot;***&quot; on them.\r\n\r\nResult should looks:\r\n\r\n&gt; 19 20 333 3454 23 23424\r\n\r\nHow can I parse my json file using JQ to extract target root elements?",
        "link": "https://stackoverflow.com/questions/70539704/how-to-get-root-elements-contains-specific-character",
        "title": "How to get root elements contains specific character"
    },
    {
        "tags": [
            "installation",
            "ansible",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1640964123,
                "post_id": 70543343,
                "comment_id": 124700316,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1640964206,
                "post_id": 70543343,
                "comment_id": 124700330,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1640974059,
                "creation_date": 1640974059,
                "answer_id": 70544699,
                "question_id": 70543343,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without seeing a sample of the relevant JSON, it&#39;s a bit difficult to check, but hopefully the following will provide the nudge you&#39;re looking for:\r\n```\r\n.ansible_facts\r\n| {hostname: .ansible_hostname,\r\n   Disks: (.ansible_devices | with_entries(.value |= .size)),\r\n   Partitions: ([.ansible_devices[].partitions | with_entries(.value |= .size)]|add),\r\n   Mounts: [.ansible_mounts[].mount]\r\n  }\r\n```",
                "title": "Retrieve specific facts from the Ansible Setup module using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1640974059,
        "creation_date": 1640961979,
        "last_edit_date": 1640964152,
        "question_id": 70543343,
        "body_markdown": "I&#39;m trying to pull out data from the setup module in Ansible. I can do most of what I need to but I&#39;m stuck on something that is probably quite simple.\r\n\r\nI&#39;m trying to generate a list of hosts including disks + sizes and partitions + sizes AND mount points.\r\n\r\nI can get the first two quite easily like this (this should work on any server running on localhost) - I need the sed to format the json correctly:\r\n\r\n```\r\n$ ansible localhost -m setup | sed &#39;1 s/^.*$/{/&#39; | jq &#39;.ansible_facts | {hostname: .ansible_hostname, Disks: .ansible_devices| with_entries(.value |= .size), Partitions: .ansible_devices[].partitions | with_entries(.value |= .size) }&#39;\r\n\r\n{\r\n&quot;hostname&quot;: &quot;ip-172-31-16-55&quot;,\r\n&quot;Disks&quot;: {\r\n  &quot;xvda&quot;: &quot;10.00 GB&quot;\r\n  },\r\n&quot;Partitions&quot;: {\r\n  &quot;xvda1&quot;: &quot;1.00 GB&quot;,\r\n  &quot;xvda2&quot;: &quot;9.00 GB&quot;\r\n  }\r\n}\r\n```\r\n\r\nNow if I want to collect mount points I can do it like this:\r\n\r\n```\r\n$ ansible localhost -m setup | sed &#39;1 s/^.*$/{/&#39; | jq -r &#39;.ansible_facts.ansible_mounts[].mount&#39;\r\n/\r\n/boot\r\n```\r\n\r\nBut because the mount information is an array (I think?) i need to map it to get it to work? I&#39;d like to get the results in the same list as the one above but when i add it in it works, but it gives me a new list for every mount point instead of just one list!\r\n\r\nThis is what I get:\r\n\r\n```\r\n$ ansible localhost -m setup | sed &#39;1 s/^.*$/{/&#39; | jq &#39;.ansible_facts | {hostname: .ansible_hostname, Disks: .ansible_devices|  with_entries(.value |= .size), Partitions: .ansible_devices[].partitions |  with_entries(.value |= .size), Mounts: .ansible_mounts[].mount }&#39;\r\n{\r\n  &quot;hostname&quot;: &quot;ip-172-31-16-55&quot;,\r\n  &quot;Disks&quot;: {\r\n    &quot;xvda&quot;: &quot;10.00 GB&quot;\r\n  },\r\n  &quot;Partitions&quot;: {\r\n    &quot;xvda1&quot;: &quot;1.00 GB&quot;,\r\n    &quot;xvda2&quot;: &quot;9.00 GB&quot;\r\n  },\r\n  &quot;Mounts&quot;: &quot;/&quot;\r\n}\r\n{\r\n  &quot;hostname&quot;: &quot;ip-172-31-16-55&quot;,\r\n  &quot;Disks&quot;: {\r\n    &quot;xvda&quot;: &quot;10.00 GB&quot;\r\n  },\r\n  &quot;Partitions&quot;: {\r\n    &quot;xvda1&quot;: &quot;1.00 GB&quot;,\r\n    &quot;xvda2&quot;: &quot;9.00 GB&quot;\r\n  },\r\n  &quot;Mounts&quot;: &quot;/boot&quot;\r\n}\r\n```\r\n\r\nBUT, this is what I&#39;m trying to get:\r\n\r\n```json\r\n{\r\n  &quot;hostname&quot;: &quot;ip-172-31-16-55&quot;,\r\n  &quot;Disks&quot;: {\r\n    &quot;xvda&quot;: &quot;10.00 GB&quot;\r\n  },\r\n  &quot;Partitions&quot;: {\r\n    &quot;xvda1&quot;: &quot;1.00 GB&quot;,\r\n    &quot;xvda2&quot;: &quot;9.00 GB&quot;\r\n  },\r\n  &quot;Mounts&quot;: &quot;/&quot;\r\n  &quot;Mounts&quot;: &quot;/boot&quot;\r\n  }\r\n}\r\n```\r\n\r\nor even a `,` separated list on one line?\r\n\r\n```\r\n  },\r\n  &quot;Mounts&quot;: &quot;/&quot;, &quot;/boot&quot;\r\n  }\r\n```\r\n\r\nI think I can&#39;t see the wood for the trees now and a little nudge would be greatly appreciated.\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/70543343/retrieve-specific-facts-from-the-ansible-setup-module-using-jq",
        "title": "Retrieve specific facts from the Ansible Setup module using JQ"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641159710,
                "creation_date": 1641159710,
                "answer_id": 70559982,
                "question_id": 70559755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Did you try using this library?\r\n[https://www.npmjs.com/package/json-to-csv-stream][1]\r\n\r\n\r\n  [1]: https://www.npmjs.com/package/json-to-csv-stream\r\n\r\n    npm i json-to-csv-stream\r\n",
                "title": "Generate csv files from a JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641226657,
                "last_edit_date": 1641226657,
                "creation_date": 1641163686,
                "answer_id": 70560323,
                "question_id": 70559755,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you decide to use jq, then unless there is some specific reason not to, I&#39;d suggest invoking jq once for each of the three output files.  The three invocations would then look like these:\r\n```\r\njq -r &#39;.result.dropped1 | [to_entries[][]] | @csv&#39; &gt; 1.csv\r\n\r\njq -r &#39;.result.rates.total | [&quot;total&quot;, .[&quot;1min&quot;], .[&quot;5min&quot;], .[&quot;15min&quot;], .[&quot;60min&quot;]] | @csv&#39; &gt; 2.csv\r\n\r\njq -r &#39;.result.rates.dropped2\r\n | to_entries[]\r\n | [.key] + ( .value | [ .[&quot;1min&quot;], .[&quot;5min&quot;], .[&quot;15min&quot;], .[&quot;60min&quot;]] )\r\n | @csv\r\n&#39; &gt; 3.csv\r\n```\r\nIf you can be sure the ordering of keys within the `total` and `address20` objects is fixed and in the correct order, then the last two invocations can be simplified.",
                "title": "Generate csv files from a JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1641226657,
        "creation_date": 1641139236,
        "question_id": 70559755,
        "body_markdown": "Unfortunately I have considerable difficulties to generate three csv files from one json format. Maybe someone has a good hint how I could do this. Thanks \r\n\r\nHere is the output. Within `dropped1` and `dropped2` can be several different and multiple addresses.\r\n\r\n```\r\n{\r\n  &quot;result&quot;: {\r\n    &quot;found&quot;: 0,\r\n    &quot;dropped1&quot;: {\r\n      &quot;address10&quot;: 1140\r\n    },\r\n    &quot;rates&quot;: {\r\n      &quot;total&quot;: {\r\n        &quot;1min&quot;: 3579,\r\n        &quot;5min&quot;: 1593,\r\n        &quot;15min&quot;: 5312,\r\n        &quot;60min&quot;: 1328\r\n      },\r\n      &quot;dropped2&quot;: {\r\n        &quot;address20&quot;: {\r\n          &quot;1min&quot;: 9139,\r\n          &quot;5min&quot;: 8355,\r\n          &quot;15min&quot;: 2785,\r\n          &quot;60min&quot;: 8196\r\n        }\r\n      }\r\n    },\r\n    &quot;connections&quot;: 1\r\n  },\r\n  &quot;id&quot;: &quot;whatever&quot;,\r\n  &quot;jsonrpc&quot;: &quot;2.0&quot;\r\n}\r\n```\r\n\r\nThe 3 csv files should be displayed in this form.\r\n\r\n\r\n    \r\n    address10,1140\r\n\r\n    total,3579,1593,5312,1328\r\n\r\n    address20,9139,8355,2785,8196\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70559755/generate-csv-files-from-a-json",
        "title": "Generate csv files from a JSON"
    },
    {
        "tags": [
            "json",
            "bash",
            "variables",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641366112,
                "post_id": 70558211,
                "comment_id": 124783245,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641392323,
                "last_edit_date": 1641392323,
                "creation_date": 1641151759,
                "answer_id": 70559091,
                "question_id": 70558211,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your claim that you can&#39;t use the variable in the loop is false. You&#39;ve proved this using `echo &quot;Downloading Archive: ${archive_id}&quot;`. This means the problem is actually with the second command of the loop.\r\n\r\nSpecifically, the issue is your construction of the string used as the parameter to `--job-parameters`. Everything in single quotes is produced exactly, so you produce the string\r\n\r\n```json\r\n{\r\n        &quot;Type&quot;: &quot;archive-retrieval&quot;,\r\n        &quot;Description&quot;: &quot;Download all my archives&quot;,\r\n        &quot;ArchiveId&quot;: &quot;${archive_id}&quot;\r\n    }\r\n```\r\n\r\nFour solutions follow.\r\n\r\n---\r\n\r\n**Creating the JSON from the shell using double-quoted string**\r\n\r\n```sh\r\n    --job-parameters &quot;{\r\n        \\&quot;Type\\&quot;:        \\&quot;archive-retrieval\\&quot;,\r\n        \\&quot;Description\\&quot;: \\&quot;Download all my archives\\&quot;,\r\n        \\&quot;ArchiveId\\&quot;:   \\&quot;$archive_id\\&quot;\r\n    }&quot;\r\n```\r\n\r\nIn general, I hate the approach of generating code from a shell script. It is however safe in this case since the id consists entirely of word characters. We do end up with a lot of backslashes, though.\r\n\r\n**Creating the JSON from the shell using a here-doc**\r\n\r\n```sh\r\n    --job-parameters &lt;&lt;EOS\r\n{\r\n   &quot;Type&quot;:        &quot;archive-retrieval&quot;,\r\n   &quot;Description&quot;: &quot;Download all my archives&quot;,\r\n   &quot;ArchiveId&quot;:   &quot;$archive_id&quot;\r\n}\r\nEOS\r\n```\r\n\r\nThis is still generating code from a shell script. But by using a here-doc, `&quot;` is no longer special, so removed the need to escape them.\r\n\r\n**Creating the JSON using jq**\r\n\r\n```sh\r\n    --job-parameters &quot;$(\r\n       jq -n --arg archive_id &quot;$archive_id&quot; &#39;\r\n          {\r\n             &quot;Type&quot;:        &quot;archive-retrieval&quot;,\r\n             &quot;Description&quot;: &quot;Download all my archives&quot;,\r\n             &quot;ArchiveId&quot;:   $archive_id\r\n          }\r\n       &#39;\r\n    )&quot;\r\n```\r\n\r\nNote that this uses the `jq` variable `$archive_id` (created using `--arg`) in a `jq` program, so no quotes around it. `jq` will produce a correct JSON string literal for it (including it if contains special characters such as `&quot;`).\r\n\r\nThis is a lot cleaner, and works even if archive_id contains special characters. It is a little slower, having to launch jq each time.\r\n\r\n**Creating the JSON using a single instance of jq**\r\n\r\nThis addresses the issue of having to launch jq multiple times.\r\n\r\n```sh\r\njq -c &#39;\r\n   .ArchiveList[] |\r\n   {\r\n      &quot;Type&quot;:        &quot;archive-retrieval&quot;,\r\n      &quot;Description&quot;: &quot;Download all my archives&quot;,\r\n      &quot;ArchiveId&quot;:   .ArchiveId\r\n   }\r\n&#39; &quot;$file&quot; |\r\nwhile read -r job; do\r\n   aws glacier initiate-job     \\\r\n      --account-id 510422384120 \\\r\n      --vault-name ebony-backup \\\r\n      --job-parameters &quot;$job&quot;\r\ndone\r\n```\r\n\r\n---\r\n\r\nNote that there should not be a comma after the archive id. Trailing commas aren&#39;t allowed in JSON.\r\n",
                "title": "Im trying to use json to pull a variable into a loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641392323,
        "creation_date": 1641144751,
        "last_edit_date": 1641199445,
        "question_id": 70558211,
        "body_markdown": "I&#39;m copying json? from two websites to try to achieve my goal \r\n\r\nhttps://softwaredevelopmentstuff.com/2017/05/02/downloading-an-aws-glacier-archive-step-by-step/\r\n\r\nhttps://gist.github.com/veuncent/ac21ae8131f24d3971a621fac0d95be5\r\n\r\nThis works:\r\n\r\n\r\n```# file to loop action on archives\r\n#!/bin/bash\r\n\r\nfile=&#39;/home/nat/Documents/glacier_access/output.json&#39;\r\n\r\nif [[ -z ${AWS_ACCOUNT_ID} ]] || [[ -z ${AWS_REGION} ]] || [[ -z ${AWS_VAULT_NAME} ]]; then\r\n\techo &quot;Please set the following environment variables: &quot;\r\n\techo &quot;AWS_ACCOUNT_ID&quot;\r\n\techo &quot;AWS_REGION&quot;\r\n\techo &quot;AWS_VAULT_NAME&quot;\r\n\texit 1\r\nfi\r\n\r\narchive_ids=$(jq .ArchiveList[].ArchiveId &lt; $file)\r\n\r\nfor archive_id in ${archive_ids}; do\r\n    echo &quot;Downloading Archive: ${archive_id}&quot;\r\n     aws glacier delete-archive --archive-id=${archive_id} --vault-name ${AWS_VAULT_NAME} --account-id ${AWS_ACCOUNT_ID} --region ${AWS_REGION}\r\n \r\ndone\r\n```\r\nas does this:\r\n\r\n```\r\n# file to loop action on archives\r\n#!/bin/bash\r\n\r\nfile=&#39;/home/nat/Documents/glacier_access/output.json&#39;\r\n\r\nif [[ -z ${AWS_ACCOUNT_ID} ]] || [[ -z ${AWS_REGION} ]] || [[ -z ${AWS_VAULT_NAME} ]]; then\r\n\techo &quot;Please set the following environment variables: &quot;\r\n\techo &quot;AWS_ACCOUNT_ID&quot;\r\n\techo &quot;AWS_REGION&quot;\r\n\techo &quot;AWS_VAULT_NAME&quot;\r\n\texit 1\r\nfi\r\n\r\narchive_ids=$(jq .ArchiveList[].ArchiveId &lt; $file)\r\n\r\nfor archive_id in ${archive_ids}; do\r\n    echo &quot;Downloading Archive: ${archive_id}&quot;\r\naws glacier initiate-job \\\r\n    --account-id 510422384120\\\r\n    --vault-name ebony-backup \\\r\n    --job-parameters &#39;{\r\n     \t&quot;Type&quot;: &quot;archive-retrieval&quot;,\r\n  \t\t&quot;Description&quot;: &quot;Download all my archives&quot;,\r\n  \t\t&quot;ArchiveId&quot;: &quot;w0GUthLDLDR6NL1z4c53M1IFktxBCrW_qZ2Qm_&quot;,\r\n  \t}&#39;\r\n \r\ndone\r\n```\r\n\r\nbut I cant reference the variable in the loop\r\n\r\nso this doesnt work:\r\n\r\n`\r\n&quot;ArchiveId&quot;: &quot;${archive_id}&quot;\r\n`\r\n\r\nnor this:\r\n\r\n`&quot;ArchiveId&quot;: &quot;{archive_id}&quot;`\r\n\r\n\r\nAn important thing to note is that the ArcihiveID MUST be referenced from inside the job parameters section.\r\n\r\nAny help gratefully received. I&#39;m assuming this is a JSON question?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70558211/im-trying-to-use-json-to-pull-a-variable-into-a-loop",
        "title": "Im trying to use json to pull a variable into a loop"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641185157,
                "last_edit_date": 1641185157,
                "creation_date": 1641182988,
                "answer_id": 70561597,
                "question_id": 70561419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following to get the desired output. \r\n\r\n    echo $(curl &lt;some-url&gt; | jq -r &#39;.[] | [.project_id, .name] | join(&quot;#&quot;)&#39; &amp;&amp; curl &lt;some-url&gt; | jq -r &#39;.[] |  ._links.web_path&#39; | awk -F/ &#39;{ print $4}&#39;) | tr &#39; &#39; &#39;#&#39;\r\n\r\nPS: There may be a more optimal way to achieve this. Comments are welcome!",
                "title": "Parse json using jq utility &amp; append fields together"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641184735,
                "creation_date": 1641184735,
                "answer_id": 70561726,
                "question_id": 70561419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For just the one object you show, which corresponds to your code after `.[]`: you can use string interpolation and `split` / array indexing to extract the web path string:\r\n\r\n```sh\r\njq -r &#39;&quot;\\(.project_id)#\\(.name)#\\(._links.web_path | split(&quot;/&quot;)[3])&quot;&#39;\r\n```",
                "title": "Parse json using jq utility &amp; append fields together"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641184748,
                "creation_date": 1641184748,
                "answer_id": 70561727,
                "question_id": 70561419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One can accomplish this with:\r\n\r\n```bash\r\n$ jq &#39;{ project_id, name, &quot;path&quot;: ._links.web_path | split(&quot;/&quot;) | .[3] } | join (&quot;#&quot;)&#39; &lt; example.txt\r\n&quot;667845#MKLIU#ONEMTH&quot;\r\n```\r\n\r\nThe `project_id` and `name` fields are &quot;passed through&quot; from the input. You didn&#39;t specify the exact rules for pulling out your target substring, `&quot;ONEMTH&quot;`, from the `_links.web_path` key. The above assumes it&#39;s always the fourth element resulting from splitting the string on `&quot;/&quot;`. Please update your question if that&#39;s not always the case.\r\n\r\nThe data is then collected into an object, rather than array, and the values joined by the `&quot;#&quot;` character.\r\n\r\nInterestingly, using an array here doesn&#39;t seem to work:\r\n\r\n```bash\r\n$ jq &#39;[.project_id, .name, ._links.web_path | split(&quot;/&quot;) | .[3]] | join (&quot;#&quot;)&#39; &lt; example.txt\r\njq: error (at &lt;stdin&gt;:14): split input and separator must be strings\r\n```\r\n\r\nI&#39;m not sure why. The `jq` documentation [explicitly states](https://stedolan.github.io/jq/manual/#TypesandValues) that array elements may be pipelines, so it seems like that should be fine. But in any case, the former works!",
                "title": "Parse json using jq utility &amp; append fields together"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641184835,
                "creation_date": 1641184835,
                "answer_id": 70561735,
                "question_id": 70561419,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key is to use the [split/1][1] method on a delimiter(`/`) and extract the field required by specifying the index\r\n\r\n```none\r\n[ .project_id, .name, (._links.web_path | split(&quot;/&quot;)[3]) ] | join(&quot;#&quot;)\r\n```\r\n\r\n[jqplay][2] - working demo\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#split(str)\r\n  [2]: https://jqplay.org/s/XXsqpZuVAo",
                "title": "Parse json using jq utility &amp; append fields together"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1641190220,
        "creation_date": 1641180485,
        "last_edit_date": 1641190220,
        "question_id": 70561419,
        "body_markdown": "One of the many thousand json blocks in an array of json blocks looks as follows -\r\n```json\r\n{\r\n  &quot;id&quot;: 4409976,\r\n  &quot;name&quot;: &quot;MKLIU&quot;,\r\n  &quot;version&quot;: &quot;1.0&quot;,\r\n  &quot;package_type&quot;: &quot;generic&quot;,\r\n  &quot;status&quot;: &quot;default&quot;,\r\n  &quot;_links&quot;: {\r\n    &quot;web_path&quot;: &quot;/part1/part2/ONEMTH/part4/-/part5/part6&quot;,\r\n    &quot;delete_api_path&quot;: &quot;https://example.com/api/v1/part40/part90/part65/part73&quot;\r\n  },\r\n  &quot;created_at&quot;: &quot;2019-01-02T10:52:34.857Z&quot;,\r\n  &quot;project_id&quot;: 667845,\r\n  &quot;project_path&quot;: &quot;hereitis/downloads/ONEMTH/MKLIU&quot;,\r\n  &quot;tags&quot;: []\r\n}\r\n```\r\nI am looking to parse the array of json blocks on Ubuntu command line using `jq` utility\r\n\r\n**Expected output**\r\n\r\n    667845#MKLIU#ONEMTH\r\n\r\nThe code I&#39;ve written so far is as below\r\n\r\n    curl &lt;some url&gt; | jq -r &#39;.[] | [.project_id, .name, ._links.web_path] | join(&quot;#&quot;)&#39;\r\n\r\nI can&#39;t work out how to pull out just the part `ONEMTH` from `._links.web_path`\r\n\r\nCould use `project_path` field too from the json block to parse out the value.\r\n\r\nPlease could I request some guidance ?",
        "link": "https://stackoverflow.com/questions/70561419/parse-json-using-jq-utility-append-fields-together",
        "title": "Parse json using jq utility &amp; append fields together"
    },
    {
        "tags": [
            "bash",
            "docker",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1641207928,
                "creation_date": 1641207928,
                "answer_id": 70564826,
                "question_id": 70564184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nAdd threshold variables and values using `--argjson` (preferred over `--arg` as we talk about numbers), then extract from the `.audits` object each item that smashes the corresponding threshold using `select`, format them in a way to carry the actual value and the threshold to be reused in the output, and finally convert those items into an alert string (which will be output as is due to the `--raw-output` parameter).\r\n\r\n```sh\r\nfor sat in `docker exec -i storagenode wget -qO - localhost:14002/api/sno | jq .satellites[].id -r`\r\ndo\r\n  docker exec -i storagenode wget -qO - localhost:14002/api/sno/satellite/$sat \\\r\n  | jq --raw-output \\\r\n    --argjson auditThreshold 1 \\\r\n    --argjson suspensionThreshold 1 \\\r\n    --argjson onlineThreshold 1 \\\r\n    &#39;.audits\r\n      | .satelliteName as $name\r\n      | (\r\n          [{auditScore}, $auditThreshold],\r\n          [{suspensionScore}, $suspensionThreshold],\r\n          [{onlineScore}, $onlineThreshold]\r\n        )\r\n      | select(.[0][] &lt; .[1])\r\n      | &quot;\\(.[0] | keys[]) (\\(.[0][])) below threshold (\\(.[1])) for \\($name)&quot;\r\n    &#39;\r\ndone\r\n```\r\n```\r\nonlineScore (0.9989041005632043) below threshold (1) for saltlake.tardigrade.io:7777\r\n```\r\n[Simplified Demo](https://jqplay.org/s/xvDgRDMjno)",
                "title": "JSON with jq into bash array / loop through for proper alerting output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641209357,
                "last_edit_date": 1641209357,
                "creation_date": 1641208498,
                "answer_id": 70564946,
                "question_id": 70564184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can produce an output which can readable to a while read loop (i.e. `while read audit_score suspension_score online_score satellite_name; do`) by changing `jq .id,.audits` to `jq -r &#39;.audits | &quot;\\(.auditScore) \\(.suspensionScore) \\(.onlineScore) \\(.satelliteName)&quot;&#39;`.  Use `bc` as a comparison tool since Bash doesn&#39;t support floating points.\r\n\r\nAlso this took me a while to compose but you can compose the messages directly using this:\r\n\r\n\tjq -r &#39;.audits | \r\n\t\t(select(.auditScore &lt; 1) | &quot;auditScore below threshold: \\(.auditScore) for \\(.satelliteName)&quot;),\r\n\t\t(select(.suspensionScore &lt; 1) | &quot;suspensionScore below threshold: \\(.suspensionScore) for \\(.satelliteName)&quot;),\r\n\t\t(select(.onlineScore &lt; 1) | &quot;onlineScore below threshold: \\(.onlineScore) for \\(.satelliteName)&quot;)\r\n\t&#39;\r\n\r\nIt should work even with merged outputs from this:\r\n\r\n    docker exec -i storagenode wget -qO - localhost:14002/api/sno | jq .satellites[].id -r | \\\r\n    \txargs -I&#39;{}&#39; docker exec -i storagenode wget -qO - &#39;localhost:14002/api/sno/satellite/{}&#39;",
                "title": "JSON with jq into bash array / loop through for proper alerting output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641238694,
        "creation_date": 1641204473,
        "last_edit_date": 1641238694,
        "question_id": 70564184,
        "body_markdown": "I have a JSON result which I want to go through and send an alert, if one or several of the values in the JSON string is smashing thresholds. \r\n\r\nThis bash command: \r\n\r\n```sh\r\nfor sat in `docker exec -i storagenode wget -qO - localhost:14002/api/sno | jq .satellites[].id -r`; do docker exec -i storagenode wget -qO - localhost:14002/api/sno/satellite/$sat | jq .id,.audits; done\r\n```\r\n\r\nProvides the following (excerpt):\r\n\r\n&lt;!-- language: lang-JSON --&gt;\r\n\r\n    &quot;12tRQrMTWUWwzwGh18i7Fqs67kmdhH9t6aToeiwbo5mfS2rUmo&quot;\r\n    {\r\n      &quot;auditScore&quot;: 1,\r\n      &quot;suspensionScore&quot;: 1,\r\n      &quot;onlineScore&quot;: 0.9974358974358974,\r\n      &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n    }\r\n    &quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;\r\n    {\r\n      &quot;auditScore&quot;: 1,\r\n      &quot;suspensionScore&quot;: 1,\r\n      &quot;onlineScore&quot;: 0.9989041005632043,\r\n      &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n    }\r\n\r\nNow I want to go through the results and e.g. in case, onlineScore drops below 0.9 (or suspensionScore resp. auditScore below 1.0, I want to create a text alert, which also includes the satelliteName. Example: ```auditScore below threshold: 0.98 for us2.storj.io```\r\n\r\nI guess I can start with the following (from https://unix.stackexchange.com/questions/413878/json-array-to-bash-variables-using-jq), but I do not know, how to loop through the results and how to name and validate the fields: \r\n\r\n&lt;!-- language: lang-sh --&gt;\r\n\r\n    jq -r &#39;.[] | to_entries | .[] | .key + &quot;=&quot; + (.value | @sh)&#39;\r\n\r\nWhat the above mentioned statement delivers in subtleties:\r\n\r\n```bash\r\ndocker exec -i storagenode wget -qO - localhost:14002/api/sno\r\n```\r\n\r\nprovides:\r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {&quot;nodeID&quot;:&quot;1veqEG5xuBNkt...&quot;,&quot;wallet&quot;:&quot;12345&quot;,&quot;walletFeatures&quot;:[&quot;zksync&quot;],&quot;satellites&quot;:[{&quot;id&quot;:&quot;12tRQrMTWUWwzwGh18i7Fqs67kmdhH9t6aToeiwbo5mfS2rUmo&quot;,&quot;url&quot;:&quot;us2.storj.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:4592556672},{&quot;id&quot;:&quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;,&quot;url&quot;:&quot;saltlake.tardigrade.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:513269323264},{&quot;id&quot;:&quot;121RTSDpyNZVcEU84Ticf2L1ntiuUimbWgfATz21tuvgk3vzoA6&quot;,&quot;url&quot;:&quot;ap1.storj.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:70956116864},{&quot;id&quot;:&quot;12EayRS2V1kEsWESU9QMRseFhdxYxKicsiFmxrsLZHeLUtdps3S&quot;,&quot;url&quot;:&quot;us1.storj.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:322340591104},{&quot;id&quot;:&quot;12L9ZFwhzVpuEKMUNUqkaTLGzwY9G24tbiigLiXpmZWKwmcNDDs&quot;,&quot;url&quot;:&quot;eu1.storj.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:148740125312},{&quot;id&quot;:&quot;12rfG3sh9NCWiX3ivPjq2HtdLmbqCrvHVEzJubnzFzosMuawymB&quot;,&quot;url&quot;:&quot;europe-north-1.tardigrade.io:7777&quot;,&quot;disqualified&quot;:null,&quot;suspended&quot;:null,&quot;currentStorageUsed&quot;:100681406976}],&quot;diskSpace&quot;:{&quot;used&quot;:1162257094528,&quot;available&quot;:9500000000000,&quot;trash&quot;:43196690332,&quot;overused&quot;:0},&quot;bandwidth&quot;:{&quot;used&quot;:31670206976,&quot;available&quot;:0},&quot;lastPinged&quot;:&quot;2022-01-02T07:55:51.886776586Z&quot;,&quot;version&quot;:&quot;1.45.3&quot;,&quot;allowedVersion&quot;:&quot;1.24.0&quot;,&quot;upToDate&quot;:true,&quot;startedAt&quot;:&quot;2021-12-31T00:00:32.209840775Z&quot;}\r\n\r\nAnd this one: \r\n```sh\r\ndocker exec -i storagenode wget -qO - localhost:14002/api/sno/satellite/1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE\r\n```\r\n\r\nprovides:\r\n\r\n```json\r\n{&quot;id&quot;:&quot;1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE&quot;,&quot;storageDaily&quot;:[{&quot;atRestTotal&quot;:11726579066524.266,&quot;intervalStart&quot;:&quot;2022-01-01T00:00:00Z&quot;}],&quot;bandwidthDaily&quot;:[{&quot;egress&quot;:{&quot;repair&quot;:390576640,&quot;audit&quot;:7424,&quot;usage&quot;:2373615872},&quot;ingress&quot;:{&quot;repair&quot;:2745100032,&quot;usage&quot;:26744320},&quot;delete&quot;:0,&quot;intervalStart&quot;:&quot;2022-01-01T00:00:00Z&quot;},{&quot;egress&quot;:{&quot;repair&quot;:143168256,&quot;audit&quot;:3584,&quot;usage&quot;:786989568},&quot;ingress&quot;:{&quot;repair&quot;:1034401280,&quot;usage&quot;:8107264},&quot;delete&quot;:0,&quot;intervalStart&quot;:&quot;2022-01-02T00:00:00Z&quot;}],&quot;storageSummary&quot;:11726579066524.266,&quot;bandwidthSummary&quot;:7508714240,&quot;egressSummary&quot;:3694361344,&quot;ingressSummary&quot;:3814352896,&quot;currentStorageUsed&quot;:513269323264,&quot;audits&quot;:{&quot;auditScore&quot;:1,&quot;suspensionScore&quot;:1,&quot;onlineScore&quot;:0.9989041005632043,&quot;satelliteName&quot;:&quot;saltlake.tardigrade.io:7777&quot;},&quot;auditHistory&quot;:{&quot;score&quot;:0.9989041005632043,&quot;windows&quot;:[{&quot;windowStart&quot;:&quot;2021-12-03T00:00:00Z&quot;,&quot;totalCount&quot;:36,&quot;onlineCount&quot;:36},{&quot;windowStart&quot;:&quot;2021-12-03T12:00:00Z&quot;,&quot;totalCount&quot;:30,&quot;onlineCount&quot;:30},{&quot;windowStart&quot;:&quot;2021-12-04T00:00:00Z&quot;,&quot;totalCount&quot;:43,&quot;onlineCount&quot;:42},{&quot;windowStart&quot;:&quot;2021-12-04T12:00:00Z&quot;,&quot;totalCount&quot;:68,&quot;onlineCount&quot;:68},{&quot;windowStart&quot;:&quot;2021-12-05T00:00:00Z&quot;,&quot;totalCount&quot;:53,&quot;onlineCount&quot;:53},{&quot;windowStart&quot;:&quot;2021-12-05T12:00:00Z&quot;,&quot;totalCount&quot;:36,&quot;onlineCount&quot;:36},{&quot;windowStart&quot;:&quot;2021-12-06T00:00:00Z&quot;,&quot;totalCount&quot;:33,&quot;onlineCount&quot;:33},{&quot;windowStart&quot;:&quot;2021-12-06T12:00:00Z&quot;,&quot;totalCount&quot;:53,&quot;onlineCount&quot;:53},{&quot;windowStart&quot;:&quot;2021-12-07T00:00:00Z&quot;,&quot;totalCount&quot;:27,&quot;onlineCount&quot;:27},{&quot;windowStart&quot;:&quot;2021-12-07T12:00:00Z&quot;,&quot;totalCount&quot;:65,&quot;onlineCount&quot;:65},{&quot;windowStart&quot;:&quot;2021-12-08T00:00:00Z&quot;,&quot;totalCount&quot;:30,&quot;onlineCount&quot;:30},{&quot;windowStart&quot;:&quot;2021-12-08T12:00:00Z&quot;,&quot;totalCount&quot;:27,&quot;onlineCount&quot;:27},{&quot;windowStart&quot;:&quot;2021-12-09T00:00:00Z&quot;,&quot;totalCount&quot;:46,&quot;onlineCount&quot;:46},{&quot;windowStart&quot;:&quot;2021-12-09T12:00:00Z&quot;,&quot;totalCount&quot;:48,&quot;onlineCount&quot;:48},{&quot;windowStart&quot;:&quot;2021-12-10T00:00:00Z&quot;,&quot;totalCount&quot;:49,&quot;onlineCount&quot;:49},{&quot;windowStart&quot;:&quot;2021-12-10T12:00:00Z&quot;,&quot;totalCount&quot;:67,&quot;onlineCount&quot;:67},{&quot;windowStart&quot;:&quot;2021-12-11T00:00:00Z&quot;,&quot;totalCount&quot;:71,&quot;onlineCount&quot;:71},{&quot;windowStart&quot;:&quot;2021-12-11T12:00:00Z&quot;,&quot;totalCount&quot;:52,&quot;onlineCount&quot;:52},{&quot;windowStart&quot;:&quot;2021-12-12T00:00:00Z&quot;,&quot;totalCount&quot;:59,&quot;onlineCount&quot;:59},{&quot;windowStart&quot;:&quot;2021-12-12T12:00:00Z&quot;,&quot;totalCount&quot;:77,&quot;onlineCount&quot;:77},{&quot;windowStart&quot;:&quot;2021-12-13T00:00:00Z&quot;,&quot;totalCount&quot;:79,&quot;onlineCount&quot;:79},{&quot;windowStart&quot;:&quot;2021-12-13T12:00:00Z&quot;,&quot;totalCount&quot;:79,&quot;onlineCount&quot;:79},{&quot;windowStart&quot;:&quot;2021-12-14T00:00:00Z&quot;,&quot;totalCount&quot;:65,&quot;onlineCount&quot;:65},{&quot;windowStart&quot;:&quot;2021-12-14T12:00:00Z&quot;,&quot;totalCount&quot;:59,&quot;onlineCount&quot;:59},{&quot;windowStart&quot;:&quot;2021-12-15T00:00:00Z&quot;,&quot;totalCount&quot;:87,&quot;onlineCount&quot;:87},{&quot;windowStart&quot;:&quot;2021-12-15T12:00:00Z&quot;,&quot;totalCount&quot;:82,&quot;onlineCount&quot;:81},{&quot;windowStart&quot;:&quot;2021-12-16T00:00:00Z&quot;,&quot;totalCount&quot;:96,&quot;onlineCount&quot;:96},{&quot;windowStart&quot;:&quot;2021-12-16T12:00:00Z&quot;,&quot;totalCount&quot;:66,&quot;onlineCount&quot;:64},{&quot;windowStart&quot;:&quot;2021-12-17T00:00:00Z&quot;,&quot;totalCount&quot;:36,&quot;onlineCount&quot;:36},{&quot;windowStart&quot;:&quot;2021-12-17T12:00:00Z&quot;,&quot;totalCount&quot;:48,&quot;onlineCount&quot;:48},{&quot;windowStart&quot;:&quot;2021-12-18T00:00:00Z&quot;,&quot;totalCount&quot;:37,&quot;onlineCount&quot;:37},{&quot;windowStart&quot;:&quot;2021-12-18T12:00:00Z&quot;,&quot;totalCount&quot;:60,&quot;onlineCount&quot;:60},{&quot;windowStart&quot;:&quot;2021-12-19T00:00:00Z&quot;,&quot;totalCount&quot;:69,&quot;onlineCount&quot;:69},{&quot;windowStart&quot;:&quot;2021-12-19T12:00:00Z&quot;,&quot;totalCount&quot;:32,&quot;onlineCount&quot;:32},{&quot;windowStart&quot;:&quot;2021-12-20T00:00:00Z&quot;,&quot;totalCount&quot;:53,&quot;onlineCount&quot;:53},{&quot;windowStart&quot;:&quot;2021-12-20T12:00:00Z&quot;,&quot;totalCount&quot;:37,&quot;onlineCount&quot;:37},{&quot;windowStart&quot;:&quot;2021-12-21T00:00:00Z&quot;,&quot;totalCount&quot;:80,&quot;onlineCount&quot;:80},{&quot;windowStart&quot;:&quot;2021-12-21T12:00:00Z&quot;,&quot;totalCount&quot;:57,&quot;onlineCount&quot;:57},{&quot;windowStart&quot;:&quot;2021-12-22T00:00:00Z&quot;,&quot;totalCount&quot;:46,&quot;onlineCount&quot;:46},{&quot;windowStart&quot;:&quot;2021-12-22T12:00:00Z&quot;,&quot;totalCount&quot;:33,&quot;onlineCount&quot;:33},{&quot;windowStart&quot;:&quot;2021-12-23T00:00:00Z&quot;,&quot;totalCount&quot;:42,&quot;onlineCount&quot;:42},{&quot;windowStart&quot;:&quot;2021-12-23T12:00:00Z&quot;,&quot;totalCount&quot;:73,&quot;onlineCount&quot;:73},{&quot;windowStart&quot;:&quot;2021-12-24T00:00:00Z&quot;,&quot;totalCount&quot;:35,&quot;onlineCount&quot;:35},{&quot;windowStart&quot;:&quot;2021-12-24T12:00:00Z&quot;,&quot;totalCount&quot;:44,&quot;onlineCount&quot;:44},{&quot;windowStart&quot;:&quot;2021-12-25T00:00:00Z&quot;,&quot;totalCount&quot;:81,&quot;onlineCount&quot;:81},{&quot;windowStart&quot;:&quot;2021-12-25T12:00:00Z&quot;,&quot;totalCount&quot;:43,&quot;onlineCount&quot;:43},{&quot;windowStart&quot;:&quot;2021-12-26T00:00:00Z&quot;,&quot;totalCount&quot;:62,&quot;onlineCount&quot;:62},{&quot;windowStart&quot;:&quot;2021-12-26T12:00:00Z&quot;,&quot;totalCount&quot;:79,&quot;onlineCount&quot;:79},{&quot;windowStart&quot;:&quot;2021-12-27T00:00:00Z&quot;,&quot;totalCount&quot;:70,&quot;onlineCount&quot;:70},{&quot;windowStart&quot;:&quot;2021-12-27T12:00:00Z&quot;,&quot;totalCount&quot;:90,&quot;onlineCount&quot;:90},{&quot;windowStart&quot;:&quot;2021-12-28T00:00:00Z&quot;,&quot;totalCount&quot;:65,&quot;onlineCount&quot;:65},{&quot;windowStart&quot;:&quot;2021-12-28T12:00:00Z&quot;,&quot;totalCount&quot;:77,&quot;onlineCount&quot;:77},{&quot;windowStart&quot;:&quot;2021-12-29T00:00:00Z&quot;,&quot;totalCount&quot;:83,&quot;onlineCount&quot;:83},{&quot;windowStart&quot;:&quot;2021-12-29T12:00:00Z&quot;,&quot;totalCount&quot;:99,&quot;onlineCount&quot;:99},{&quot;windowStart&quot;:&quot;2021-12-30T00:00:00Z&quot;,&quot;totalCount&quot;:74,&quot;onlineCount&quot;:74},{&quot;windowStart&quot;:&quot;2021-12-30T12:00:00Z&quot;,&quot;totalCount&quot;:84,&quot;onlineCount&quot;:84},{&quot;windowStart&quot;:&quot;2021-12-31T00:00:00Z&quot;,&quot;totalCount&quot;:70,&quot;onlineCount&quot;:70},{&quot;windowStart&quot;:&quot;2021-12-31T12:00:00Z&quot;,&quot;totalCount&quot;:93,&quot;onlineCount&quot;:93},{&quot;windowStart&quot;:&quot;2022-01-01T00:00:00Z&quot;,&quot;totalCount&quot;:120,&quot;onlineCount&quot;:120},{&quot;windowStart&quot;:&quot;2022-01-01T12:00:00Z&quot;,&quot;totalCount&quot;:112,&quot;onlineCount&quot;:112},{&quot;windowStart&quot;:&quot;2022-01-02T00:00:00Z&quot;,&quot;totalCount&quot;:46,&quot;onlineCount&quot;:46}]},&quot;priceModel&quot;:{&quot;EgressBandwidth&quot;:2000,&quot;RepairBandwidth&quot;:1000,&quot;AuditBandwidth&quot;:1000,&quot;DiskSpace&quot;:150},&quot;nodeJoinedAt&quot;:&quot;2021-05-11T20:11:14.910165Z&quot;}\r\n```\r\n\r\nSorry, not sure how to better format the huge json content here in a better way.\r\n\r\nThank you for your help. I am not sure how I can modify the output, loop through the results and create the corresponding target output. jq as a tool is new for me and the documentation is not yet self-explanatory for me. \r\n\r\n**UPDATE #1**\r\n\r\nThere is a result for `http://localhost:14002/api/sno/satellites`, I was not aware of before. The result is: \r\n\r\n&lt;!-- language: lang-json --&gt;\r\n\r\n    {\r\n    ...\r\n       &quot;storageSummary&quot;: 6.8624392E13,\r\n    ...\r\n       &quot;audits&quot;: [\r\n          {\r\n             &quot;auditScore&quot;: 1,\r\n             &quot;suspensionScore&quot;: 1,\r\n             &quot;onlineScore&quot;: 0.99743587,\r\n             &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n          },\r\n          {\r\n             &quot;auditScore&quot;: 1,\r\n             &quot;suspensionScore&quot;: 1,\r\n             &quot;onlineScore&quot;: 0.9992917,\r\n             &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n          },\r\n    ...\r\n          {\r\n             &quot;auditScore&quot;: 1,\r\n             &quot;suspensionScore&quot;: 1,\r\n             &quot;onlineScore&quot;: 0.99930555,\r\n             &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n          }\r\n       ]\r\n    }\r\n\r\n\r\n\r\nI think that makes the required handling much easier at the end, right?",
        "link": "https://stackoverflow.com/questions/70564184/json-with-jq-into-bash-array-loop-through-for-proper-alerting-output",
        "title": "JSON with jq into bash array / loop through for proper alerting output"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "inner-join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1641314220,
                "last_edit_date": 1641314220,
                "creation_date": 1641221243,
                "answer_id": 70567476,
                "question_id": 70567330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have two files `labels.json` and `runners.json`, you could read in the latter (runners) as a variable using `--argjson` and append to each element of the input array (labels) using `map` the corresponding fields determined by `select`.\r\n\r\n```sh\r\njq --argjson runners &quot;$(cat runners.json)&quot; &#39;\r\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\r\n&#39; labels.json\r\n```\r\n\r\nHowever, this reads the whole runners array into your shells command line space (`--argjson` takes two strings: a name and a value) which can easily overflow if the runners array gets big enough.\r\n\r\nTherefore, instead of using [command substitution](https://www.gnu.org/software/bash/manual/html_node/Command-Substitution.html) `&quot;$(…)&quot;`, you could read in the runners file directly using either `--slurpfile` for the cost of another iteration level `[][]`, or (despite the [manual](https://stedolan.github.io/jq/manual/v1.6/) saying not to - read more about it in the comments) using `--argfile` with just a single iteration level as before:\r\n```sh\r\njq --slurpfile runners runners.json &#39;\r\n  map(.name as $name | . + ($runners[][] | select(.name == $name)))\r\n&#39; labels.json\r\n```\r\n```sh\r\njq --argfile runners runners.json &#39;\r\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\r\n&#39; labels.json\r\n```\r\n\r\nTo circumvent all these issues, @peak [suggested](https://stackoverflow.com/questions/70567330/merge-json-arrays-with-duplicate-keys#comment124749465_70567476) using `input` for each file together with the `-n` option. Note that this requires the two files to be provided in this exact order as they are being read in sequentially.\r\n\r\n```sh\r\njq -n &#39;input as $runners | input |\r\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\r\n&#39; runners.json labels.json\r\n```\r\n\r\nAs the second `input` (labels) is passed on directly as the filter&#39;s main input (in contrast to runners, which is stored in a variable for later use), this could be further simplified by removing again the `-n` option (order of the files still matters):\r\n```sh\r\njq &#39;input as $runners |\r\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\r\n&#39; runners.json labels.json\r\n```\r\n\r\nFinally, here&#39;s yet another approach using the [SQL-style operators](https://stedolan.github.io/jq/manual/v1.6/#SQL-StyleOperators) `INDEX` and `JOIN` which were introduced in jq v1.6. This also employs the technique using just one `input` and also the order of the files still matters as we need the runners array as the filter&#39;s primary input.\r\n\r\n```sh\r\njq &#39;\r\n  JOIN(INDEX(input[]; .name); .name) | map(select(.[1]) | add)\r\n&#39; runners.json labels.json\r\n```\r\n",
                "title": "Merge json arrays with duplicate keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1641345317,
        "creation_date": 1641220500,
        "last_edit_date": 1641345317,
        "question_id": 70567330,
        "body_markdown": "I want to merge two json arrays with help of `jq`. Each object in arrays contains name field, which allow me to group by and merge two arrays into one. \r\n\r\nLABELS\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;description&quot;: &quot;master&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_branch&quot;,\r\n    &quot;description&quot;: &quot;main&quot;\r\n  }\r\n]\r\n```\r\n\r\nRUNNERS\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;runner&quot;: &quot;power&quot;,\r\n    &quot;runner_tag&quot;: &quot;macos&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;runner&quot;: &quot;power&quot;,\r\n    &quot;runner_tag&quot;: &quot;ubuntu&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_branch&quot;,\r\n    &quot;runner&quot;: &quot;tester&quot;,\r\n    &quot;runner_tag&quot;: &quot;&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;development&quot;,\r\n    &quot;runner&quot;: &quot;dev&quot;,\r\n    &quot;runner_tag&quot;: &quot;ubuntu&quot;\r\n  }\r\n]\r\n```\r\n\r\nDesired Output\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;description&quot;: &quot;master&quot;,\r\n    &quot;runner&quot;: &quot;power&quot;,\r\n    &quot;runner_tag&quot;: &quot;macos&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;description&quot;: &quot;master&quot;,\r\n    &quot;runner&quot;: &quot;power&quot;,\r\n    &quot;runner_tag&quot;: &quot;ubuntu&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_branch&quot;,\r\n    &quot;description&quot;: &quot;main&quot;,\r\n    &quot;runner&quot;: &quot;tester&quot;,\r\n    &quot;runner_tag&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\nI tried with following script, but power_branch entry was override, instead i want another entry with different runner_tag\r\n\r\n```lang-bash\r\n#!/usr/bin/bash\r\n\r\nLABELS=&#39;[{&quot;name&quot;: &quot;power_branch&quot;,&quot;description&quot;: &quot;master&quot;},{&quot;name&quot;: &quot;test_branch&quot;,&quot;description&quot;: &quot;main&quot;}]&#39;\r\nRUNNERS=&#39;&#39;&#39;\r\n[\r\n  { &quot;name&quot;: &quot;power_branch&quot;, &quot;runner&quot;: &quot;power&quot;, &quot;runner_tag&quot;: &quot;macos&quot; },\r\n  { &quot;name&quot;: &quot;power_branch&quot;, &quot;runner&quot;: &quot;power&quot;, &quot;runner_tag&quot;: &quot;ubuntu&quot; },\r\n  { &quot;name&quot;: &quot;test_branch&quot;, &quot;runner&quot;: &quot;tester&quot;, &quot;runner_tag&quot;: &quot;&quot; },\r\n  { &quot;name&quot;: &quot;development&quot;, &quot;runner&quot;: &quot;dev&quot;, &quot;runner_tag&quot;: &quot;ubuntu&quot; }\r\n]\r\n&#39;&#39;&#39;\r\n\r\nFINAL=$(jq -s &#39;[ .[0] + .[1] | group_by(.name)[] | select(length &gt; 1) | add]&#39; &lt;(echo $LABELS) &lt;(echo $RUNNERS))\r\necho $FINAL\r\n```\r\n\r\nOUTPUT\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;power_branch&quot;,\r\n    &quot;description&quot;: &quot;master&quot;,\r\n    &quot;runner&quot;: &quot;power&quot;,\r\n    &quot;runner_tag&quot;: &quot;ubuntu&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_branch&quot;,\r\n    &quot;description&quot;: &quot;main&quot;,\r\n    &quot;runner&quot;: &quot;tester&quot;,\r\n    &quot;runner_tag&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70567330/merge-json-arrays-with-duplicate-keys",
        "title": "Merge json arrays with duplicate keys"
    },
    {
        "tags": [
            "json",
            "file",
            "jq",
            "partition"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641255000,
                "post_id": 70569726,
                "comment_id": 124753941,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641293916,
                "last_edit_date": 1641293916,
                "creation_date": 1641234474,
                "answer_id": 70569969,
                "question_id": 70569726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq itself cannot write to files, neither to one nor to many. The shell calling jq, however, can. Therefore, any solution needs to orchestrate these two levels by splitting up the task into parts and have each carried out by one of the two levels (or any third party tool).\r\n\r\nOne straightforward way could be to employ jq to separate the stream into documents and prepare them to already carry the file&#39;s name and content, and iterate in the shell over that output. Then, with each iteration step, jq can be used again to extract that data and have the shell save the content to a file.\r\n\r\n```sh\r\njq -c &#39;{\r\n  name: &quot;\\(.root_rgs | map(split(&quot;_&quot;)[-1]) | join(&quot;_&quot;)).json&quot;,\r\n  content: {targets}\r\n}&#39; input.json | while read -r json; do\r\n  jq &#39;.content&#39; &lt;&lt;&lt; &quot;$json&quot; &gt; &quot;$(jq -r &#39;.name&#39; &lt;&lt;&lt; &quot;$json&quot;)&quot;\r\ndone\r\n```\r\n\r\nAnother way could be to have jq generate a script that is executable in the shell. This would reduce the number of times jq has to be called from 2n+1 to just 1, which can be important if the input file contains many docuemnts.\r\n\r\n```sh\r\njq -r &#39;&quot;cat&quot;\r\n  + &quot; &gt;\\(.root_rgs | map(split(&quot;_&quot;)[-1]) | join(&quot;_&quot;)).json&quot;\r\n  + &quot; &lt;&lt;&lt;\\({targets} | tojson | @sh)&quot;\r\n&#39; input.json | bash\r\n```\r\n\r\nThis produces for each document in the input stream a line of the form `cat &gt;FILENAME &lt;&lt;&lt;&#39;JSON&#39;` which instructs the shell to `cat` to a file its input, which in turn is provided as a [Here String](https://tldp.org/LDP/abs/html/x17837.html) which is understood by `bash`, to which the commands are piped eventually.\r\n",
                "title": "JQ Split JSON in several files"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641312311,
                "last_edit_date": 1641312311,
                "creation_date": 1641247115,
                "answer_id": 70571900,
                "question_id": 70569726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possibility would be to combine one invocation of jq with one invocation of a utility like `awk` for writing the files:\r\n```\r\njq -cr &#39;(.root_rgs | &quot;\\(.[0]|sub(&quot;PROM_FD_&quot;;&quot;&quot;))\\(.[1]|sub(&quot;PROM_JOB&quot;;&quot;&quot;))&quot;),\r\n        {TARGETS: .targets}&#39; input.json |\r\n  awk &#39;NR%2==1 {fn = $1 &quot;.json&quot;; next} {print $0 &gt;&gt; fn}&#39;\r\n```\r\n\r\nOf course, the resultant files will not, in general, be pretty-printed.\r\n\r\nWARNING: the above appends to existing files.  In practice, an alternative method of handling such files would probably be preferable.",
                "title": "JQ Split JSON in several files"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1641312311,
        "creation_date": 1641232935,
        "last_edit_date": 1641253881,
        "question_id": 70569726,
        "body_markdown": "I&#39;m new on this. And trying to spare or split a JSON in several files according to the content.\r\nThe &quot;name&quot; of the target group is &quot;root_rgs&quot; and I&#39;d like to have it in different files each one.\r\n\r\n    {\r\n      &quot;root_rgs&quot;: [\r\n        &quot;PROM_FD_ARCNA&quot;,\r\n        &quot;PROM_JOB_ICMP&quot;\r\n      ],\r\n      &quot;targets&quot;: [\r\n        &quot;HCC02155&quot;,\r\n        &quot;HCC09350&quot;,\r\n        &quot;HCC09321&quot;,\r\n        &quot;HCCEFACTORYWWW&quot;,\r\n        &quot;HCC9723&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;root_rgs&quot;: [\r\n        &quot;PROM_FD_ARCNA&quot;,\r\n        &quot;PROM_JOB_WIN&quot;\r\n      ],\r\n      &quot;targets&quot;: [\r\n        &quot;LABTNSARWID236&quot;,\r\n        &quot;LABTNSARWID692&quot;,\r\n        &quot;VM00006&quot;\r\n      ]\r\n    }\r\n    {\r\n      &quot;root_rgs&quot;: [\r\n        &quot;PROM_FD_MTZ&quot;,\r\n        &quot;PROM_JOB_ICMP&quot;\r\n      ],\r\n      &quot;targets&quot;: [\r\n        &quot;TEIARWIN205&quot;,\r\n        &quot;TEIARWDB150&quot;,\r\n        &quot;TEIARWCXWA212&quot;\r\n      ]\r\n    }\r\n\r\nIs it possible to generate something like:\r\n\r\n`ARCNA_ICMP.json`\r\n\r\n    {\r\n    TARGETS:\r\n            &quot;HCC02155&quot;,\r\n            &quot;HCC09350&quot;,\r\n            &quot;HCC09321&quot;,\r\n            &quot;HCCEFACTORYWWW&quot;,\r\n            &quot;HCC9723&quot;\r\n    }\r\n\r\n-------------------------------------------\r\n`ARCNA_WIN.json`\r\n\r\n    {\r\n    TARGETS:\r\n        &quot;LABTNSARWID236&quot;,\r\n        &quot;LABTNSARWID692&quot;,\r\n        &quot;VM00006&quot;\r\n    }\r\n\r\n-------------------------------------------\r\nAnd so on...\r\n\r\nHope to be clear, thanks everyone!",
        "link": "https://stackoverflow.com/questions/70569726/jq-split-json-in-several-files",
        "title": "JQ Split JSON in several files"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641262005,
                "creation_date": 1641262005,
                "answer_id": 70573377,
                "question_id": 70573060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you have received is two valid JSON documents (or a stream, as it is called in the jq manuals). If you put a comma in between, it wouldn&#39;t be valid JSON anymore because then it&#39;d be neither a stream of two documents anymore (as of the superfluous comma) nor one array with two elements in it (as of no surrounding array brackets). You can, however, add those missing brackets, too, making it an array, if this is what you want.\r\n\r\nTo achieve this, surround your entire filter with brackets `jq &#39;[.[] | {…}]&#39;` and jq will take care of the commas. Also, as your filter&#39;s initial part `.[]` was already decomposing an array (or an object), you could simplify the array creation by exchanging it for a `map` with the same effect: `jq &#39;map({…})&#39;`.",
                "title": "combining multiple json files into a single json file with jq filters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1641262005,
        "creation_date": 1641258234,
        "question_id": 70573060,
        "body_markdown": "I have multiple json files that I need to comnine into one giant json file.\r\nI know I can use the basic -s and get a giant file\r\n`jq -s . littlefiles*.json &gt;&gt; giantfile.json`\r\n\r\nMy issue is I cannot seem to figure out how to filter things out and still combine them into a valid json. All my efforts have yielded the right filtered output, but it&#39;s missing the &quot;,&quot; between.  I&#39;ve seen some answers on the webz on using &quot;map&quot; but I don&#39;t see its application on my filtering.  Maybe I&#39;m using jq all wrong for what I need? \r\n\r\nhere&#39;s a cat of the jq\r\n```\r\nrfossi@xAMrfossi Responses % cat BBB.json | jq &#39;.[] | { repo: .url[37:-1] | [rtrimstr(&quot;/branches/master/protectio&quot;)], PushUsers: [.restrictions.users[].login], PushTeams: [.restrictions.teams[].slug]}&#39;\r\n{\r\n  &quot;repo&quot;: [\r\n    &quot;homelaunch_basic&quot;\r\n  ],\r\n  &quot;PushUsers&quot;: [],\r\n  &quot;PushTeams&quot;: [\r\n    &quot;master-branch-mergers&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;repo&quot;: [\r\n    &quot;homelaunch_base&quot;\r\n  ],\r\n  &quot;PushUsers&quot;: [],\r\n  &quot;PushTeams&quot;: []\r\n}\r\n```\r\n\r\nAs you can see, I get the info I need.  But it&#39;s missing the &quot;,&quot; that makes it a valid json file.   When I attempt to combine the files with this same filtering, I get one of the dreaded **Cannot index array with string** messages (basic example below).  I&#39;ve been looking at this too long I think, and I&#39;m missing something obvious. \r\n\r\n```\r\nrfossi@xAMrfossi Responses % jq -r &#39;.[] | { url: .url, users: [.restrictions.users[].login]}&#39; B*.json &gt; Bgiant.json\r\njq: error (at B1get-branch-prot-1641247960841.json:0): Cannot index string with string &quot;url&quot;\r\njq: error (at B2get-branch-prot-1641247961044.json:0): Cannot index string with string &quot;url&quot;\r\njq: error (at Bgiantfile.json:5): Cannot index array with string &quot;url&quot;\r\njq: error (at Bgiantfile.json:10): Cannot index array with string &quot;url&quot;\r\nrfossi@xAMrfossi Responses %\r\n```",
        "link": "https://stackoverflow.com/questions/70573060/combining-multiple-json-files-into-a-single-json-file-with-jq-filters",
        "title": "combining multiple json files into a single json file with jq filters"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641287479,
                "last_edit_date": 1641287479,
                "creation_date": 1641286827,
                "answer_id": 70576301,
                "question_id": 70576220,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, `select` the items that match the condition `.Sid == &quot;bla1&quot;`, then `del`ete from them any entry `.Condition.ArnLike.&quot;aws:bla&quot;[]` that matches `. == &quot;blablablablablabla*&quot;`.\r\n\r\n```sh\r\njq &#39;select(.Sid == &quot;bla1&quot;) |=\r\n  del(.Condition.ArnLike.&quot;aws:bla&quot;[] | select(. == &quot;blablablablablabla*&quot;))\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/Mb7luae8vn)\r\n\r\nIf your objects are in an array, apply this using a `map` onto that array.\r\n```sh\r\njq &#39;map(select(.Sid == &quot;bla1&quot;) |=\r\n  del(.Condition.ArnLike.&quot;aws:bla&quot;[] | select(. == &quot;blablablablablabla*&quot;))\r\n)&#39;\r\n```\r\n[Demo](https://jqplay.org/s/E5fQ3hkKm5)\r\n",
                "title": "JQ:How to remove items from json array with conditions?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1741189862,
        "creation_date": 1641286347,
        "last_edit_date": 1741189862,
        "question_id": 70576220,
        "body_markdown": "I have the following few json array objects that Id like to filter using a single jq command.\r\n\r\n```json\r\n{\r\n    &quot;Sid&quot;: &quot;bla1&quot;,\r\n    &quot;Effect&quot;: &quot;Allow&quot;,\r\n    &quot;Principal&quot;: {\r\n      &quot;AWS&quot;: &quot;*&quot;\r\n    },\r\n    &quot;Action&quot;: &quot;blabla&quot;,\r\n    &quot;Resource&quot;: &quot;blablablabla&quot;,\r\n    &quot;Condition&quot;: {\r\n      &quot;ArnLike&quot;: {\r\n        &quot;aws:bla&quot;: [\r\n          &quot;blablablablablabla*&quot;,\r\n          &quot;blablablablabla*&quot;,\r\n          &quot;blablablabla:*&quot;\r\n        ]\r\n      }\r\n    }\r\n  }\r\n```\r\n\r\nHow can i remove item &quot;blablablablablabla:*&quot; from &quot;Condition-&gt;ArnLike-&gt;aws:bla&quot; if &quot;Sid&quot; == &quot;bla1&quot; \r\n\r\nexpected result like below\r\n\r\n```json\r\n{\r\n    &quot;Sid&quot;: &quot;bla1&quot;,\r\n    &quot;Effect&quot;: &quot;Allow&quot;,\r\n    &quot;Principal&quot;: {\r\n      &quot;AWS&quot;: &quot;*&quot;\r\n    },\r\n    &quot;Action&quot;: &quot;blabla&quot;,\r\n    &quot;Resource&quot;: &quot;blablablabla&quot;,\r\n    &quot;Condition&quot;: {\r\n      &quot;ArnLike&quot;: {\r\n        &quot;aws:bla&quot;: [\r\n          &quot;blablablablabla*&quot;,\r\n          &quot;blablablabla:*&quot;\r\n        ]\r\n      }\r\n    }\r\n  }\r\n```\r\n\r\nbest regards",
        "link": "https://stackoverflow.com/questions/70576220/jqhow-to-remove-items-from-json-array-with-conditions",
        "title": "JQ:How to remove items from json array with conditions?"
    },
    {
        "tags": [
            "jq",
            "kubernetes-apiserver"
        ],
        "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": 1641325205,
                "post_id": 70583733,
                "comment_id": 124774884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641325248,
                "post_id": 70583733,
                "comment_id": 124774900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 358445,
                    "reputation": 26234,
                    "user_id": 699215,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/dac451eeb6941e002e455f5a4e48bf9b?s=256&d=identicon&r=PG",
                    "display_name": "Chris G.",
                    "link": "https://stackoverflow.com/users/699215/chris-g"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641326376,
                "post_id": 70583733,
                "comment_id": 124775274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641325956,
                "creation_date": 1641325956,
                "answer_id": 70584330,
                "question_id": 70583733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is what you need :\r\n\r\n```\r\ncurl &#39;127.0.0.1:8080/api/v1/pods&#39; |\r\n  jq -r &#39;.items[] | select(.metadata.name == &quot;my-pod&quot;).status.phase&#39;\r\n```",
                "title": "get pod creation status from k8s api json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641328893,
                "creation_date": 1641328893,
                "answer_id": 70584799,
                "question_id": 70583733,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will give you the right status:\r\n\r\n    curl &#39;127.0.0.1:8080/api/v1/pods&#39; |\r\n      jq -r &#39;.items[] | select(.metadata.name == &quot;my-pod).status.containerStatuses[0].state&#39;",
                "title": "get pod creation status from k8s api json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1641328893,
        "creation_date": 1641322339,
        "last_edit_date": 1641328229,
        "question_id": 70583733,
        "body_markdown": "I am trying to use jq in the following to get a status on my pod &quot;my pod&quot;:\r\n\r\n    curl &#39;127.0.0.1:8080/api/v1/pods&#39; | jq -r &#39;.items[] | select(.metadata.name)&#39;\r\n\r\nThis give me a ton of json, more specific how do you read json from k8s api - to get the status of a pod - running or not?\r\n\r\n\r\nIf I get items within a pod:\r\n\r\n     curl &#39;127.0.0.1:8080/api/v1/pods&#39; | jq -r &#39;select(.items[].metadata.name=&quot;go-test-volume1&quot;).items[]\r\n\r\nSure enough I get a list, but which one to chose - there is a status.phase in all of them?\r\n\r\n[![items][1]][1]\r\n\r\n\r\nIn the case of a status of CrashLoopBackOff:\r\n\r\n     curl &#39;127.0.0.1:8080/api/v1/pods&#39; |\r\n      jq -r &#39;.items[] | select(.metadata.name == &quot;my-pod&quot;).status.phase&#39;\r\n\r\nWill show it as Running?\r\n\r\n\r\n  [1]: https://i.sstatic.net/d3Sog.png?s=512\r\n",
        "link": "https://stackoverflow.com/questions/70583733/get-pod-creation-status-from-k8s-api-json-using-jq",
        "title": "get pod creation status from k8s api json using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641386427,
                "creation_date": 1641386427,
                "answer_id": 70593039,
                "question_id": 70592888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` function such as\r\n```\r\njq &#39;del(.children[] | select( to_entries[] | .key != &quot;filter&quot;))&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/EyRERl0qbK)&lt;/kbd&gt;",
                "title": "jq: Delete objects from an array based on its key"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1641386896,
                "creation_date": 1641386896,
                "answer_id": 70593134,
                "question_id": 70592888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\njq &#39;del(.children[] | select(.filter == null))&#39;\r\n```\r\n\r\nCheck it [online](https://jqplay.org/s/1QA-daSKN_).",
                "title": "jq: Delete objects from an array based on its key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1641387535,
        "creation_date": 1641385757,
        "last_edit_date": 1641386642,
        "question_id": 70592888,
        "body_markdown": "I want to use jq to delete all objects from an array whose key does not correspond to a defined value.\r\n\r\nThis is my JSON:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;config1&quot;,\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;customer&quot;: {\r\n        &quot;name&quot;: &quot;cust1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;filter&quot;: {\r\n        &quot;name&quot;: &quot;test1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;filter&quot;: {\r\n        &quot;name&quot;: &quot;test2&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;context&quot;: {\r\n        &quot;id&quot;: &quot;1&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFor example I want to remove all objects whose key is not &quot;filter&quot;. Desired output:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;config1&quot;,\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;filter&quot;: {\r\n        &quot;name&quot;: &quot;test1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;filter&quot;: {\r\n        &quot;name&quot;: &quot;test2&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nI tried\r\n\r\n```\r\njq &#39;del(.children[] | with_entries(select(.key != &quot;filter&quot;)))&#39;\r\n```\r\nbut that gives the following error:\r\n```\r\njq: error (at &lt;stdin&gt;:1): Invalid path expression near attempt to iterate through [&quot;customer&quot;]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70592888/jq-delete-objects-from-an-array-based-on-its-key",
        "title": "jq: Delete objects from an array based on its key"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "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": 1641390411,
                "post_id": 70593928,
                "comment_id": 124791975,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13526480,
                    "reputation": 491,
                    "user_id": 9758155,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-XdUIqdMkCWA/AAAAAAAAAAI/AAAAAAAAAAA/4252rscbv5M/s256-rj/photo.jpg",
                    "display_name": "ashishpm",
                    "link": "https://stackoverflow.com/users/9758155/ashishpm"
                },
                "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": 1641396408,
                "post_id": 70593928,
                "comment_id": 124794748,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641391687,
                "last_edit_date": 1641391687,
                "creation_date": 1641390592,
                "answer_id": 70594007,
                "question_id": 70593928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two major issues, and some additional items that may not matter for your current example use case but can be important when you&#39;re dealing with real-world data from untrusted sources:\r\n\r\n- Your current code iterates over _all_ `name`s before writing _any_ `id`s.\r\n- Your current code uses newline separators, but doesn&#39;t make any effort to read multiple lines into each `while` loop iteration.\r\n- Your code uses newline separators, but newlines can be present inside strings; consequently, this is constraining the input domain.\r\n- When you pipe into a `while` loop, that loop is run in a subshell; when the pipeline exits, the subshell does too, so any variables set by the loop are lost.\r\n- Starting up a copy of `/bin/cat` and making `jq` read a pipe from its output is silly and inefficient compared to letting `jq` read from `test.json` directly.\r\n\r\nWe can fix all of those:\r\n\r\n- To write `name`s and `id`s in pairs, you&#39;d want something more like `jq &#39;.[] | (.name, .id)&#39;`\r\n- To read both a name and an id for each element of the loop, you&#39;d want `while IFS= read -r name &amp;&amp; IFS= read -r id; do ...` to iterate over those pairs.\r\n- To switch from newlines to NULs (the NUL being the only character that can&#39;t exist in a C string, or thus a bash string), you&#39;d want to use the `-j` argument to `jq`, and then add explicit `&quot;\\u0000&quot;` elements to the content being written. To _read_ this NUL-delimited content on the bash side, you&#39;d need to add the `-d &#39;&#39;` argument to each `read`.\r\n- To move the `while read` loop out of the subshell, we can use [process substitution](https://wiki.bash-hackers.org/syntax/expansion/proc_subst), as described in [BashFAQ #24](https://mywiki.wooledge.org/BashFAQ/024).\r\n- To let `jq` read directly from `test.json`, use either `&lt;test.json` to have the shell connect the file directly to jq&#39;s stdin, or pass the filename on jq&#39;s command line.\r\n\r\nDoing everything described above in a manner robust against input data containing JSON-encoded NULs would look like the following:\r\n\r\n```\r\n#!/bin/bash\r\ndisplay() {\r\n  echo &quot;name is $1 and id is $2&quot;\r\n}\r\n\r\ncat &gt;test.json &lt;&lt;&#39;EOF&#39;\r\n[\r\n  { &quot;name&quot;: &quot;Akshay&quot;, &quot;id&quot;: &quot;234&quot; },\r\n  { &quot;name&quot;: &quot;Amit&quot;, &quot;id&quot;: &quot;28&quot; }\r\n]\r\nEOF\r\n\r\nwhile IFS= read -r -d &#39;&#39; name &amp;&amp; IFS= read -r -d &#39;&#39; id; do\r\n  display &quot;$name&quot; &quot;$id&quot;\r\ndone &lt; &lt;(jq -j &#39;\r\n  def stripnuls: sub(&quot;\\u0000&quot;; &quot;&lt;NUL&gt;&quot;);\r\n  .[] | ((.name | stripnuls), &quot;\\u0000&quot;, (.id | stripnuls), &quot;\\u0000&quot;)\r\n&#39; &lt;test.json)\r\n```\r\n\r\n\r\nYou can see the above running at https://replit.com/@CharlesDuffy2/BelovedForestgreenUnits#main.sh",
                "title": "Using jq how to pass multiple values as arguments to a function?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668026611,
                "last_edit_date": 1668026611,
                "creation_date": 1668026073,
                "answer_id": 74381084,
                "question_id": 70593928,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use string interpolation.\r\n\r\n    jq &#39;.[] | &quot;The name is \\(.name) and id \\(.id)&quot;&#39;\r\n\r\nResult: \r\n\r\n    &quot;The name is Akshay and id 234&quot;\r\n    &quot;The name is Amit and id 28&quot;\r\n    &quot;The name is hi and id 28&quot;\r\n\r\nIf you want to get rid of the double-quotes from each object, then:\r\n\r\n    jq --raw-output &#39;.[] | &quot;The name is \\(.name) and is \\(.id)&quot;&#39;\r\n\r\nhttps://jqplay.org/s/-lkpHROTBk0\r\n\r\n\r\n\r\n",
                "title": "Using jq how to pass multiple values as arguments to a function?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668026611,
        "creation_date": 1641390344,
        "question_id": 70593928,
        "body_markdown": "I have a json file test.json with the content:\r\n\r\n    [\r\n    {\r\n      &quot;name&quot;: &quot;Akshay&quot;,\r\n      &quot;id&quot;: &quot;234&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Amit&quot;,\r\n      &quot;id&quot;: &quot;28&quot;\r\n    }\r\n    ]\r\nI have a shell script with content: \r\n\r\n    #!/bin/bash\r\n    function display\r\n    {\r\n      echo &quot;name is $1 and id is $2&quot;\r\n    }\r\n\r\n    cat test.json | jq &#39;.[].name,.[].id&#39; | while read line; do display $line; done\r\n\r\nI want name and id of a single item to be passed together as arguments to the function display but the output is something like this : \r\n\r\n    name is &quot;Akshay&quot; and id is \r\n    name is &quot;Amit&quot; and id is   \r\n    name is &quot;234&quot; and id is \r\n    name is &quot;28&quot; and id is \r\n\r\nWhat should be the correct way to implement the code?\r\nPS: I specifically want to use jq so please base the answer in terms of jq",
        "link": "https://stackoverflow.com/questions/70593928/using-jq-how-to-pass-multiple-values-as-arguments-to-a-function",
        "title": "Using jq how to pass multiple values as arguments to a function?"
    },
    {
        "tags": [
            "json",
            "jq",
            "pgbackrest"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641402187,
                "last_edit_date": 1641402187,
                "creation_date": 1641390822,
                "answer_id": 70594060,
                "question_id": 70593955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So, for each object in the top-level array you want to pull in `.name` into each of its `.backup` array&#39;s elements, right? Then try\r\n```sh\r\njq &#39;map(.backup[] += {name} | del(.name))&#39;\r\n```\r\n[Demo](https://jqplay.org/s/22c0CcpVFE)\r\n\r\nThen, generating a CSV output using jq is easy: There is a builtin called @csv which transforms an array into a string of its values with quotes (if they are stringy) and separated by commas. So, all you need to do is to iteratively compose your desired values into arrays. At this point, removing `.name` is not necessary anymore as we are piecing together the array for CSV output anyway. And we&#39;re giving the -r flag to jq in order to make the output raw text rather than JSON.\r\n```sh\r\njq -r &#39;.[]\r\n  | .backup[] + {name}\r\n  | [(.archive | .start, .stop), .name, .info.size, .label, .type]\r\n  | @csv\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/QoGujRNd_n)\r\n\r\n",
                "title": "how to denormalise this json structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1655827033,
                "last_edit_date": 1655827033,
                "creation_date": 1655826734,
                "answer_id": 72703780,
                "question_id": 70593955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First navigate to backup and only then “print” the stuff you’re interested.\r\n\r\n``` \r\n.[].backup[] | .name + &quot;:&quot; + .type\r\n```",
                "title": "how to denormalise this json structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1655827033,
        "creation_date": 1641390417,
        "last_edit_date": 1641392017,
        "question_id": 70593955,
        "body_markdown": "I have a json formatted overview of backups, generated using pgbackrest. For simplicity I removed a lot of clutter so the main structures remain. The list can contain multiple backup structures, I reduced here to just 1 for simplicity.\r\n```\r\n[\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;archive&quot;: {\r\n          &quot;start&quot;: &quot;000000090000000200000075&quot;,\r\n          &quot;stop&quot;: &quot;000000090000000200000075&quot;\r\n        },\r\n        &quot;info&quot;: {\r\n          &quot;size&quot;: 1200934840\r\n        },\r\n        &quot;label&quot;: &quot;20220103-122051F&quot;,\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;archive&quot;: {\r\n          &quot;start&quot;: &quot;00000009000000020000007D&quot;,\r\n          &quot;stop&quot;: &quot;00000009000000020000007D&quot;\r\n        },\r\n        &quot;info&quot;: {\r\n          &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;label&quot;: &quot;20220103-153304F_20220104-081304I&quot;,\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ],\r\n    &quot;name&quot;: &quot;dbname1&quot;\r\n  }\r\n]\r\n```\r\nUsing jq I tried to generate a simpeler format out of this, until now without any luck. \r\n\r\nWhat I would like to see is the backup.archive, backup.info, backup.label, backup.type, name combined in one simple structure, without getting into a cartesian product. I would be very happy to get the following output:\r\n```\r\n[\r\n  {\r\n    &quot;backup&quot;: [\r\n      {\r\n        &quot;archive&quot;: {\r\n          &quot;start&quot;: &quot;000000090000000200000075&quot;,\r\n          &quot;stop&quot;: &quot;000000090000000200000075&quot;\r\n        },\r\n        &quot;name&quot;: &quot;dbname1&quot;,\r\n        &quot;info&quot;: {\r\n          &quot;size&quot;: 1200934840\r\n        },\r\n        &quot;label&quot;: &quot;20220103-122051F&quot;,\r\n        &quot;type&quot;: &quot;full&quot;\r\n      },\r\n      {\r\n        &quot;archive&quot;: {\r\n          &quot;start&quot;: &quot;00000009000000020000007D&quot;,\r\n          &quot;stop&quot;: &quot;00000009000000020000007D&quot;\r\n        },\r\n        &quot;name&quot;: &quot;dbname1&quot;,\r\n        &quot;info&quot;: {\r\n          &quot;size&quot;: 1168586300\r\n        },\r\n        &quot;label&quot;: &quot;20220103-153304F_20220104-081304I&quot;,\r\n        &quot;type&quot;: &quot;incr&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\nwhere name is redundantly added to the list. How can I use jq to convert the shown input to the requested output? In the end I just want to generate a simple csv from the data. Even with the simplified structure using \r\n```\r\n&#39;.[].backup[].name + &quot;:&quot; + .[].backup[].type&#39;\r\n```\r\nI get a cartesian product:\r\n```\r\n&quot;dbname1:full&quot;\r\n&quot;dbname1:full&quot;\r\n&quot;dbname1:incr&quot;\r\n&quot;dbname1:incr&quot;\r\n```\r\nhow to solve that?",
        "link": "https://stackoverflow.com/questions/70593955/how-to-denormalise-this-json-structure",
        "title": "how to denormalise this json structure"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641405663,
                "last_edit_date": 1641405663,
                "creation_date": 1641399572,
                "answer_id": 70596169,
                "question_id": 70594159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No.\r\n\r\nYou&#39;re asking how to collect the outputs of a stream (list) using something of the form `STREAM | ...`. Unfortunately, that&#39;s impossible.\r\n\r\nWhen piping filter `A` into filter `B` as in `A | B`, and `A` happens to output a stream, then `B` is fed with each item of the stream *separately*, i.e. `B` runs as many times as there are items coming from `A`. Therefore no single execution of `B` will be able to see or collect all the (other) items of the stream.&lt;sup&gt;[1]&lt;/sup&gt;\r\n\r\nThe code building the array must necessarily enclose `STREAM`.\r\n\r\n* `[ STREAM ]`\r\n* `reduce STREAM as $_ ( []; .+[$_] )`\r\n* `def array( s ): [ s ]; array( STREAM )`\r\n* `ARRAY | map( STREAM )` (An alternative to `[ ARRAY | STREAM ]`.)\r\n* etc\r\n\r\nFor example,\r\n\r\n```sh\r\njq --slurp .\r\n```\r\n\r\ncan also be written as\r\n\r\n```sh\r\njq --null-input &#39;[ inputs ]&#39;\r\n```\r\n\r\nBut there&#39;s nothing equivalent that has the following form:\r\n\r\n```sh\r\njq &#39;...&#39;\r\n```\r\n\r\nIn short, you have an [XY Problem](https://www.perlmonks.org/?node_id=542341).\r\n\r\n---\r\n\r\n1. Courtesy of @pmf\r\n",
                "title": "Transform a list of json value into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1641405663,
        "creation_date": 1641391222,
        "question_id": 70594159,
        "body_markdown": "Is there a way to transform / slurp a list of JSON values into an array ?\r\n\r\nThe idea is to replicate the functionality of -s / --slurp but for &quot;internal&quot; use.\r\n\r\nWhen we iterate over the values of an array, we get a list of value. I would like to have a way to transform the list back into an array but without enclosing the expression with [ ], without using the array constructor.\r\n\r\nI would like it to have the form of a filter. I already tried various things with reduce, foreach and bindings but it doesn&#39;t work",
        "link": "https://stackoverflow.com/questions/70594159/transform-a-list-of-json-value-into-an-array",
        "title": "Transform a list of json value into an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641406061,
                "post_id": 70595878,
                "comment_id": 124798811,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641407645,
                "last_edit_date": 1641407645,
                "creation_date": 1641402812,
                "answer_id": 70596904,
                "question_id": 70595878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To merge two objects, one can use `obj1 + obj2`. From this, it follows that `obj1 += obj2` can be used to merge an object (`obj2`) into another existing object (`obj1`).\r\n\r\nMaybe that&#39;s what you trying to use. If so, you were missing parens around the expression producing the object to merge into (causing the code to be misparsed), you have the operands to `+=` backwards, you don&#39;t actually produce the correct objects on each side of `+=` (or even objects at all), and you didn&#39;t narrow down your output (accidentally including jqtest in the output).\r\n\r\nFixed:\r\n\r\n```sh\r\njq -s &#39;\r\n    ( .[1].item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += .[0] | .[1]\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/62dEYxs2dD) on jqplay\r\n\r\nI find the following clearer (less mental overhead):\r\n\r\n```sh\r\njq -s &#39;\r\n   .[0] as $to_insert |\r\n   .[1] | ( .item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += $to_insert\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/BZyHjPEcCW)\r\n\r\nThat said, I would avoid slurping in favour of `--argfile`.\r\n\r\n```sh\r\njq --argfile to_insert jqtest.json &#39;\r\n    ( .item[] | select( .name == &quot;accounts&quot; ) | .item[] ) += $to_insert\r\n&#39; collection.json\r\n```\r\n\r\n[Demo](https://jqplay.org/s/i2vtE6YEH-) on jqplay\r\n",
                "title": "Merging 2 JSON documents using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641407645,
        "creation_date": 1641398285,
        "last_edit_date": 1641402489,
        "question_id": 70595878,
        "body_markdown": "I&#39;m using JQ CLI to merge JSON from document to another. The issue I am facing is that I have select by the value of a property, rather than by a numeric array index \r\n\r\nThe first file contains a chunk of  JSON jqtest.json: \r\n\r\n```json\r\n{\r\n  &quot;event&quot;: [\r\n    {\r\n      &quot;listen&quot;: &quot;test&quot;,\r\n      &quot;script&quot;: {\r\n        &quot;exec&quot;: [],\r\n        &quot;type&quot;: &quot;text/javascript&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe second file is where I want to merge the JSON into under &quot;accounts&quot; collection.json:\r\n\r\n```json\r\n{\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;accounts&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;accounts mapped&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of AccountMapped resources.&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat i am trying to do is merge it under &quot;accounts&quot; and under &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot; I use the command:\r\n\r\n```sh\r\njq -s &#39;\r\n   .[0].event += .[1].item |\r\n   map(select(.name==&quot;accounts&quot;)) |\r\n   .[].item\r\n&#39; jqtest.json collection.json\r\n```\r\n\r\nBut when executed nothing is outputted. What am doing wrong with JQ or is there another tool i can use to accomplish this?\r\n\r\n```json\r\n{\r\n  &quot;item&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;accounts&quot;,\r\n      &quot;item&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Retrieves the collection of Account resources.&quot;,\r\n          &quot;event&quot;: [\r\n            {\r\n              &quot;listen&quot;: &quot;test&quot;,\r\n              &quot;script&quot;: {\r\n                &quot;exec&quot;: [],\r\n                &quot;type&quot;: &quot;text/javascript&quot;\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;accounts mapped&quot;,\r\n          &quot;item&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Retrieves the collection of AccountMapped resources.&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/70595878/merging-2-json-documents-using-jq",
        "title": "Merging 2 JSON documents using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641412141,
                "creation_date": 1641412141,
                "answer_id": 70598833,
                "question_id": 70598749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Sure, change your pipeline to\r\n```sh\r\njq -r &#39;.SecurityGroups[0].IpPermissions[0].IpRanges[].CidrIp&#39;\r\n```\r\n[Demo](https://jqplay.org/s/cCqn6gXGz7)\r\n\r\nNote that I also added the `-r` flag which makes the output raw text instead of JSON.",
                "title": "Print specific element of json object of an array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641412234,
                "creation_date": 1641412234,
                "answer_id": 70598849,
                "question_id": 70598749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.SecurityGroups[0].IpPermissions[0].IpRanges | values[].CidrIp&#39;\r\n```\r\n\r\nthis seemed to work as well.",
                "title": "Print specific element of json object of an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641412234,
        "creation_date": 1641411734,
        "question_id": 70598749,
        "body_markdown": "I am describing a AWS security group and passing the output by `jq` in order to get all the CIDRs of the inbound rules.\r\n\r\nI have reached so far:\r\n\r\n```\r\n▶ aws ec2 describe-security-groups --group-ids sg-123456789 | jq &#39;.SecurityGroups[0].IpPermissions[0].IpRanges&#39;\r\n[\r\n  {\r\n    &quot;CidrIp&quot;: &quot;11.22.33.44/32&quot;,\r\n    &quot;Description&quot;: &quot;Something&quot;\r\n  },\r\n  {\r\n    &quot;CidrIp&quot;: &quot;22.33.44.12/32&quot;,\r\n    &quot;Description&quot;: &quot;Something else&quot;\r\n  },\r\n  {\r\n    &quot;CidrIp&quot;: &quot;22.11.33.55/32&quot;,\r\n    &quot;Description&quot;: &quot;Something different&quot;\r\n  },\r\n]\r\n```\r\n\r\nI know I can `grep` but is there a way to get just the `CidrIp` from each `json` element of this array?",
        "link": "https://stackoverflow.com/questions/70598749/print-specific-element-of-json-object-of-an-array-using-jq",
        "title": "Print specific element of json object of an array using jq"
    },
    {
        "tags": [
            "kubernetes",
            "jq",
            "prometheus"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12671520,
                    "reputation": 20972,
                    "user_id": 9208887,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c4bf119024165bb1121e77fbd4115df?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "The Fool",
                    "link": "https://stackoverflow.com/users/9208887/the-fool"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1641412168,
                "post_id": 70598827,
                "comment_id": 124801016,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641412382,
                "post_id": 70598827,
                "comment_id": 124801104,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1641415933,
                "last_edit_date": 1641415933,
                "creation_date": 1641415532,
                "answer_id": 70599375,
                "question_id": 70598827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could convert your file to JSON using https://github.com/prometheus/prom2json\r\n\r\nThen it&#39;s jq all the way down, if you wish.  E.g. with your input:\r\n```\r\nprom2json sample.prom | jq &#39;\r\n  .[] | .metrics |= map(select(.labels.container==&quot;coredns&quot;) )&#39;\r\n```\r\nyields\r\n```\r\n{\r\n  &quot;name&quot;: &quot;container_memory_working_set_bytes&quot;,\r\n  &quot;help&quot;: &quot;[ALPHA] Current working set of the container in bytes&quot;,\r\n  &quot;type&quot;: &quot;GAUGE&quot;,\r\n  &quot;metrics&quot;: [\r\n    {\r\n      &quot;labels&quot;: {\r\n        &quot;container&quot;: &quot;coredns&quot;,\r\n        &quot;namespace&quot;: &quot;kube-system&quot;,\r\n        &quot;pod&quot;: &quot;coredns-64897985d-qzvj8&quot;\r\n      },\r\n      &quot;timestamp_ms&quot;: &quot;1641411355244&quot;,\r\n      &quot;value&quot;: &quot;1.5364096e+07&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;container_cpu_usage_seconds_total&quot;,\r\n  &quot;help&quot;: &quot;[ALPHA] Cumulative cpu time consumed by the container in core-seconds&quot;,\r\n  &quot;type&quot;: &quot;COUNTER&quot;,\r\n  &quot;metrics&quot;: [\r\n    {\r\n      &quot;labels&quot;: {\r\n        &quot;container&quot;: &quot;coredns&quot;,\r\n        &quot;namespace&quot;: &quot;kube-system&quot;,\r\n        &quot;pod&quot;: &quot;coredns-64897985d-qzvj8&quot;\r\n      },\r\n      &quot;timestamp_ms&quot;: &quot;1641411355244&quot;,\r\n      &quot;value&quot;: &quot;1075.30302335&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Filter kubernetes file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1641421326,
        "creation_date": 1641412101,
        "last_edit_date": 1641421326,
        "question_id": 70598827,
        "body_markdown": "I have the following file:\r\n\r\n```\r\n# HELP container_cpu_usage_seconds_total [ALPHA] Cumulative cpu time consumed by the container in core-seconds\r\n# TYPE container_cpu_usage_seconds_total counter\r\ncontainer_cpu_usage_seconds_total{container=&quot;coredns&quot;,namespace=&quot;kube-system&quot;,pod=&quot;coredns-64897985d-qzvj8&quot;} 1075.30302335 1641411355244\r\ncontainer_cpu_usage_seconds_total{container=&quot;etcd&quot;,namespace=&quot;kube-system&quot;,pod=&quot;etcd-minikube&quot;} 7948.244422673 1641411341787\r\ncontainer_cpu_usage_seconds_total{container=&quot;kindnet-cni&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kindnet-v9rn4&quot;} 253.401092815 1641411342227\r\ncontainer_cpu_usage_seconds_total{container=&quot;kube-apiserver&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-apiserver-minikube&quot;} 21314.526032702 1641411341706\r\ncontainer_cpu_usage_seconds_total{container=&quot;kube-controller-manager&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-controller-manager-minikube&quot;} 9960.616171401 1641411346752\r\ncontainer_cpu_usage_seconds_total{container=&quot;kube-proxy&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-proxy-ktclh&quot;} 220.17024815 1641411352327\r\ncontainer_cpu_usage_seconds_total{container=&quot;kube-scheduler&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-scheduler-minikube&quot;} 1216.162832124 1641411355059\r\ncontainer_cpu_usage_seconds_total{container=&quot;metrics-server&quot;,namespace=&quot;kube-system&quot;,pod=&quot;metrics-server-6b76bd68b6-lpx4q&quot;} 715.97119974 1641411344274\r\ncontainer_cpu_usage_seconds_total{container=&quot;storage-provisioner&quot;,namespace=&quot;kube-system&quot;,pod=&quot;storage-provisioner&quot;} 47.685435216 1641411354429\r\n# HELP container_memory_working_set_bytes [ALPHA] Current working set of the container in bytes\r\n# TYPE container_memory_working_set_bytes gauge\r\ncontainer_memory_working_set_bytes{container=&quot;coredns&quot;,namespace=&quot;kube-system&quot;,pod=&quot;coredns-64897985d-qzvj8&quot;} 1.5364096e+07 1641411355244\r\ncontainer_memory_working_set_bytes{container=&quot;etcd&quot;,namespace=&quot;kube-system&quot;,pod=&quot;etcd-minikube&quot;} 5.9752448e+07 1641411341787\r\ncontainer_memory_working_set_bytes{container=&quot;kindnet-cni&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kindnet-v9rn4&quot;} 1.0326016e+07 1641411342227\r\ncontainer_memory_working_set_bytes{container=&quot;kube-apiserver&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-apiserver-minikube&quot;} 2.66002432e+08 1641411341706\r\ncontainer_memory_working_set_bytes{container=&quot;kube-controller-manager&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-controller-manager-minikube&quot;} 5.9129856e+07 1641411346752\r\ncontainer_memory_working_set_bytes{container=&quot;kube-proxy&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-proxy-ktclh&quot;} 2.00704e+07 1641411352327\r\ncontainer_memory_working_set_bytes{container=&quot;kube-scheduler&quot;,namespace=&quot;kube-system&quot;,pod=&quot;kube-scheduler-minikube&quot;} 2.3130112e+07 1641411355059\r\ncontainer_memory_working_set_bytes{container=&quot;metrics-server&quot;,namespace=&quot;kube-system&quot;,pod=&quot;metrics-server-6b76bd68b6-lpx4q&quot;} 2.6923008e+07 1641411344274\r\ncontainer_memory_working_set_bytes{container=&quot;storage-provisioner&quot;,namespace=&quot;kube-system&quot;,pod=&quot;storage-provisioner&quot;} 1.4209024e+07 1641411354429\r\n```\r\n\r\nA few questions:\r\n- What format is this? I know it isn&#39;t JSON.\r\n- Can I use jq to parse/filter this data? I would like to get all metrics on the `coredns` container:\r\n\r\n```\r\ncontainer_cpu_usage_seconds_total{container=&quot;coredns&quot;,namespace=&quot;kube-system&quot;,pod=&quot;coredns-64897985d-qzvj8&quot;} 1075.30302335 1641411355244\r\ncontainer_memory_working_set_bytes{container=&quot;coredns&quot;,namespace=&quot;kube-system&quot;,pod=&quot;coredns-64897985d-qzvj8&quot;} 1.5364096e+07 1641411355244\r\n```",
        "link": "https://stackoverflow.com/questions/70598827/filter-kubernetes-file",
        "title": "Filter kubernetes file"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "performance",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641461512,
                "post_id": 70604732,
                "comment_id": 124811803,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641476472,
                "post_id": 70604732,
                "comment_id": 124817197,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641478291,
                "post_id": 70604732,
                "comment_id": 124817895,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641478353,
                "post_id": 70604732,
                "comment_id": 124817915,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641479047,
                "post_id": 70604732,
                "comment_id": 124818204,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641479240,
                "post_id": 70604732,
                "comment_id": 124818271,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641479992,
                "post_id": 70604732,
                "comment_id": 124818571,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4639276,
                    "reputation": 3,
                    "user_id": 3759598,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nhso0.jpg?s=256",
                    "display_name": "pr3c0g",
                    "link": "https://stackoverflow.com/users/3759598/pr3c0g"
                },
                "reply_to_user": {
                    "account_id": 2578132,
                    "reputation": 1921,
                    "user_id": 2235381,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0061f9bd5384a544637692774a6e108f?s=256&d=identicon&r=PG",
                    "display_name": "lojza",
                    "link": "https://stackoverflow.com/users/2235381/lojza"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489381,
                "post_id": 70604732,
                "comment_id": 124822621,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4639276,
                    "reputation": 3,
                    "user_id": 3759598,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nhso0.jpg?s=256",
                    "display_name": "pr3c0g",
                    "link": "https://stackoverflow.com/users/3759598/pr3c0g"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489530,
                "post_id": 70604732,
                "comment_id": 124822678,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4639276,
                    "reputation": 3,
                    "user_id": 3759598,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nhso0.jpg?s=256",
                    "display_name": "pr3c0g",
                    "link": "https://stackoverflow.com/users/3759598/pr3c0g"
                },
                "reply_to_user": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489600,
                "post_id": 70604732,
                "comment_id": 124822716,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489688,
                "post_id": 70604732,
                "comment_id": 124822748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4639276,
                    "reputation": 3,
                    "user_id": 3759598,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Nhso0.jpg?s=256",
                    "display_name": "pr3c0g",
                    "link": "https://stackoverflow.com/users/3759598/pr3c0g"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489988,
                "post_id": 70604732,
                "comment_id": 124822890,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641491494,
                "last_edit_date": 1641491494,
                "creation_date": 1641473478,
                "answer_id": 70607379,
                "question_id": 70604732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Update\r\n\r\nA few things to consider:\r\n\r\n* You can avoid using `jq` inside the `while` loop:\r\n\r\n``` bash\r\n#!/bin/bash\r\n\r\nwhile IFS=&#39;,&#39; read -r key user path\r\ndo\r\n#   rsync_backup &quot;$key&quot; &quot;$user&quot; &quot;$path&quot;\r\n    echo &quot;key=$key user=$user path=$path&quot;\r\ndone &lt; &lt;(\r\n    jq -cr &#39;.[] | &quot;\\(.key),\\(.user),\\(.path)&quot;&#39; &lt;&lt;&lt; &quot;$backups_to_perform&quot;\r\n)\r\n```\r\n\r\n* You should safeguard against typos in the JSON that will lead to `null` values (for example if you typed `&quot;usr&quot;:` instead of `&quot;user&quot;:`).\r\n\r\n* You should allow the use of commas in `&quot;key&quot;:` and `&quot;user&quot;:`, and of any character (but the `NULL BYTE`) in `&quot;path&quot;:`.\r\n\r\n---\r\n\r\nWith all that in mind, I would choose the TSV format as `jq` output:\r\n\r\n``` bash\r\n#!/bin/bash\r\n\r\n# safety check\r\nif $(jq &#39;any(.[]; .key and .user and .path | not)&#39; &lt;&lt;&lt; &quot;$backups_to_perform&quot;)\r\nthen\r\n    jq -c &#39;.[] |select(.key and .user and .path |not)&#39; &lt;&lt;&lt; &quot;$backups_to_perform&quot; |\r\n    awk -v prefix=&quot;[WARNING] missing attribute in record: &quot; &#39;{print prefix $0}&#39;\r\nfi\r\n\r\n# doing the backups\r\nwhile IFS=$&#39;\\t&#39; read -r key user path\r\ndo\r\n    # unescape TSV values\r\n    printf -v key  %b &quot;$key&quot;\r\n    printf -v user %b &quot;$user&quot;\r\n    printf -v path %b &quot;$path&quot;\r\n#   rsync_backup &quot;$key&quot; &quot;$user&quot; &quot;$path&quot;\r\n    echo &quot;key=$key user=$user path=$path&quot;\r\ndone &lt; &lt;(\r\n    jq -r &#39;.[] | select(.key and .user and .path) | [.key,.user,.path] | @tsv&#39; &lt;&lt;&lt; &quot;$backups_to_perform&quot;\r\n)\r\n```\r\n\r\nYou can test it with this input:\r\n```\r\nIFS=&#39;&#39; read -r -d &#39;&#39; backups_to_perform &lt;&lt;&#39;EOJ&#39;\r\n[\r\n  {\r\n    &quot;__comment__&quot;: &quot;comma in key value&quot;,\r\n    &quot;key&quot;: &quot;key,1&quot;,\r\n    &quot;user&quot;: &quot;user1&quot;,\r\n    &quot;path&quot;: &quot;path1&quot;\r\n  },\r\n  {\r\n    &quot;__comment__&quot;: &quot;newline in key value&quot;,\r\n    &quot;key&quot;: &quot;key\\n2&quot;,\r\n    &quot;user&quot;: &quot;user2&quot;,\r\n    &quot;path&quot;: &quot;path2&quot;\r\n  },\r\n  {\r\n    &quot;__comment__&quot;: &quot;mispelled user attribute&quot;,\r\n    &quot;key&quot;: &quot;key3&quot;,\r\n    &quot;usr&quot;: &quot;user3&quot;,\r\n    &quot;path&quot;: &quot;path3&quot;\r\n  },\r\n  {\r\n    &quot;__comment__&quot;: &quot;path containing ascii range [0x01-0x7f]&quot;,\r\n    &quot;key&quot;: &quot;key4&quot;,\r\n    &quot;user&quot;: &quot;user4&quot;,\r\n    &quot;path&quot;: &quot;\\u0001\\u0002\\u0003\\u0004\\u0005\\u0006\\u0007\\b\\t\\n\\u000b\\f\\r\\u000e\\u000f\\u0010\\u0011\\u0012\\u0013\\u0014\\u0015\\u0016\\u0017\\u0018\\u0019\\u001a\\u001b\\u001c\\u001d\\u001e\\u001f !\\&quot;#$%&amp;&#39;()*+,-./0123456789:;&lt;=&gt;?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\\u007f&quot;\r\n  }\r\n]\r\nEOJ\r\n```\r\n\r\n\r\n",
                "title": "BASH How to improve performance of JSON parsing with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641491494,
        "creation_date": 1641459851,
        "question_id": 70604732,
        "body_markdown": "Context: I have a scenario where I need to perform copies of backups from one system to another. I want the backups list to be configurable, so I went with a JSON approach inside the script itself. \r\n\r\nThe list contains key (name of the backup to show in output), user to ssh with, and path to get the backup from.\r\n\r\nExample:\r\n\r\n```sh\r\nbackups_to_perform=&#39;[\r\n  {\r\n    &quot;key&quot;: &quot;key1&quot;,\r\n    &quot;user&quot;: &quot;user1&quot;,\r\n    &quot;path&quot;: &quot;path1&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;key2&quot;,\r\n    &quot;user&quot;: &quot;user2&quot;,\r\n    &quot;path&quot;: &quot;path2&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;key3&quot;,\r\n    &quot;user&quot;: &quot;user3&quot;,\r\n    &quot;path&quot;: &quot;path3&quot;\r\n  },\r\n]&#39;\r\n```\r\n\r\nThe reason I&#39;m going with JSON, is that I wanted to have a similar structure to a python dictionary, since associative arrays can only have `key:pair`, instead of `key{key:pair; key:pair}` (Please correct me if I&#39;m wrong)\r\n\r\nThis is how I&#39;m parsing the JSON:\r\n```sh\r\n  while read -r backup; do\r\n    IFS=, read -r key user path &lt;&lt;&lt;&quot;$(jq -cr &#39;&quot;\\(.key),\\(.user),\\(.path)&quot;&#39; &lt;&lt;&lt;&quot;$backup&quot;)&quot;\r\n    rsync_backup &quot;$key&quot; &quot;$user&quot; &quot;$path&quot;\r\n  done &lt; &lt;(jq -cr &#39;.[]&#39; &lt;&lt;&lt;&quot;$backups_to_perform&quot;)\r\n```\r\n\r\nrsync_backup is just a function to perform rsync that accepts those args.\r\n\r\nIt possible there&#39;s a better solution to achieve the backup copies that what I want, but I&#39;d like to improve this type of code so I can better apply it next time.\r\n\r\nMy problem is that this seems to take some time when the JSON is big (I&#39;ve cut back to 3 for this post). It also looks like my way of parsing the JSON is very convoluted but I couldn&#39;t make it work any other way.\r\n\r\nIt&#39;s probably bad that I&#39;m calling `jq` once to feed the loop, and then call it again for each iteration.",
        "link": "https://stackoverflow.com/questions/70604732/bash-how-to-improve-performance-of-json-parsing-with-jq",
        "title": "BASH How to improve performance of JSON parsing with jq"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq",
            "inverse"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641489508,
                "post_id": 70610489,
                "comment_id": 124822668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641491232,
                "post_id": 70610489,
                "comment_id": 124823410,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641580647,
                "last_edit_date": 1641580647,
                "creation_date": 1641491509,
                "answer_id": 70611433,
                "question_id": 70610489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if this is elegant, but it works for your sample data\r\n\r\n```sh\r\necho &quot;[$X,$Z]&quot; | jq &#39;\r\n  . as [$x,$z]\r\n  | map([paths(scalars)])\r\n  | .[0] |= map(select(. as $p | [$x, $z | getpath($p)] | .[1] == .[0]))\r\n  | reduce (.[1] - .[0])[] as $p (null; setpath($p; $z | getpath($p)))  \r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;a&quot;: 3,\r\n  &quot;c&quot;: {\r\n    &quot;x&quot;: 10,\r\n    &quot;y&quot;: 11\r\n  },\r\n  &quot;d&quot;: 2\r\n}\r\n````\r\n[Demo](https://jqplay.org/s/Y5rEaeFWaU)",
                "title": "jq: how to perform unmerge / multi-level object subtraction i.e. given X and Y, find Z such that X * Z = Y"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641498966,
                "last_edit_date": 1641498966,
                "creation_date": 1641493163,
                "answer_id": 70611775,
                "question_id": 70610489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\ndef remove($o2):\r\n   reduce ( to_entries[] | [ .key, .value ] ) as [ $k, $v1 ] (\r\n      {};\r\n      if $o2 | has($k) | not then\r\n         # Keep existing value if $o2 doesn&#39;t have the key.\r\n         .[$k] = $v1\r\n      else\r\n         $o2[$k] as $v2 |\r\n         if $v1 | type == &quot;object&quot; then\r\n            # We&#39;re comparing objects.\r\n            ( $v1 | remove($o2[$k]) ) as $v_diff |\r\n            if $v_diff | length == 0 then\r\n               # Discard identical values.\r\n               .\r\n            else\r\n               # Keep the differences of the values.\r\n               .[$k] = $v_diff\r\n            end\r\n         else\r\n            # We&#39;re comparing non-objects.\r\n            if $v1 == $v2 then\r\n               # Discard identical values.\r\n               .\r\n            else\r\n               # Keep existing value if different.\r\n               .[$k] = $v1\r\n            end\r\n         end\r\n      end\r\n   );\r\n\r\n. as [ $Z, $X ] | $Z | remove($X)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/ySwGC2FClo) on jqplay\r\n\r\nor\r\n\r\n```jq\r\ndef sub($v2):\r\n   (       type ) as $t1 |\r\n   ( $v2 | type ) as $t2 |\r\n   if $t1 == $t2 then\r\n      if $t1 == &quot;object&quot; then\r\n         with_entries(\r\n            .key as $k |\r\n            .value = (\r\n               .value |\r\n               if $v2 | has($k) then sub( $v2[$k] ) else . end\r\n            )\r\n         ) |\r\n         select( length != 0 )\r\n      else\r\n         select( . != $v2 )\r\n      end\r\n   else\r\n      .\r\n   end;\r\n\r\n. as [ $Z, $X ] | $Z | sub($X)\r\n```\r\n\r\n[Demo](https://jqplay.org/s/p8QNzPMv2_) on jqplay\r\n",
                "title": "jq: how to perform unmerge / multi-level object subtraction i.e. given X and Y, find Z such that X * Z = Y"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641610193,
        "creation_date": 1641487173,
        "last_edit_date": 1641610193,
        "question_id": 70610489,
        "body_markdown": "Using `jq` we can easily merge two multi-level objects X and Y using `*`:\r\n```\r\nX=&#39;{\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 5,\r\n    &quot;c&quot;: {\r\n      &quot;a&quot;: 3\r\n    }\r\n  }&#39; Y=&#39;{\r\n    &quot;d&quot;: 2,\r\n    &quot;a&quot;: 3,\r\n    &quot;c&quot;: {\r\n      &quot;x&quot;: 10,\r\n      &quot;y&quot;: 11\r\n    }\r\n  }&#39; &amp;&amp; Z=`echo &quot;[$X,$Y]&quot;|jq &#39;.[0] * .[1]&#39;` &amp;&amp; echo &quot;Z=&#39;$Z&#39;&quot;\r\n```\r\n\r\ngives us:\r\n```\r\nZ=&#39;{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: 5,\r\n  &quot;c&quot;: {\r\n    &quot;a&quot;: 3,\r\n    &quot;x&quot;: 10,\r\n    &quot;y&quot;: 11\r\n  },\r\n  &quot;d&quot;: 2\r\n}&#39;\r\n```\r\n\r\nBut in my case, I&#39;m starting with X and Z and want to calculate Y (such that X * Y = Z). If we only have objects with scalar properties, then `jq X + Y` equals `Z`, and we can also calculate `Y` as `jq Z - X`. However, this fails if X or Y contain properties with object values such as in the above example:\r\n```\r\nX=&#39;{\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 5,\r\n    &quot;c&quot;: {\r\n      &quot;a&quot;: 3\r\n    }\r\n  }&#39; Z=&#39;{\r\n  &quot;a&quot;: 3,\r\n  &quot;b&quot;: 5,\r\n  &quot;c&quot;: {\r\n    &quot;a&quot;: 3,\r\n    &quot;x&quot;: 10,\r\n    &quot;y&quot;: 11\r\n  },\r\n  &quot;d&quot;: 2\r\n}&#39; &amp;&amp; echo &quot;[$X,$Z]&quot; | jq &#39;.[1] - .[0]&#39;\r\n```\r\n\r\nthrows an error `jq: error (at &lt;stdin&gt;:16): object ({&quot;a&quot;:3,&quot;b&quot;:...) and object ({&quot;a&quot;:1,&quot;b&quot;:...) cannot be subtracted`\r\n\r\nIs there an elegant solution to this problem with jq?\r\n\r\nUPDATE: I&#39;ve accepted the answer that I found easier to read / maintain and with superior performance. In addition, I found a wrinkle in my need which was that if X contained a key K that was not present in Z, I needed the output (Y) to nullify it by containing the key K with a value of null.\r\n\r\nThe best way I could come up with to do this was to pre-process Z to add the missing keys using the below:\r\n```\r\ndef add_null($y):\r\n    reduce (to_entries[] | [ .key, .value ] ) as [ $k, $v ] (\r\n       $y;\r\n       if $y | has($k) | not then\r\n          .[$k] = null\r\n       elif $v | type == &quot;object&quot; then\r\n          .[$k] = ($v | add_null($y[$k]))\r\n       else\r\n          .[$k] = $v\r\n       end\r\n    );\r\n```\r\n\r\nso we end up with:\r\n```\r\ndef add_null(...);\r\n\r\ndef remove(...);\r\n\r\n. as [ $X, $Z ] | ($X | add_null($Z)) | remove($X)\r\n```\r\n\r\nAny better suggestions to this variation are still appreciated!",
        "link": "https://stackoverflow.com/questions/70610489/jq-how-to-perform-unmerge-multi-level-object-subtraction-i-e-given-x-and-y",
        "title": "jq: how to perform unmerge / multi-level object subtraction i.e. given X and Y, find Z such that X * Z = Y"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1641503963,
                "creation_date": 1641503963,
                "answer_id": 70613745,
                "question_id": 70613566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s literally called `map_values`. Use it like this\r\n```\r\nmap_values({innerkey:.})\r\n```\r\n[Demo](https://jqplay.org/s/PKfmo-D8Jf)",
                "title": "jq: mapping all values of an object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641532620,
                "creation_date": 1641532620,
                "answer_id": 70616905,
                "question_id": 70613566,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use the fact that iterating over an object iterates its values. So you could update those values on the object.\r\n\r\n```\r\n.[] |= {innerkey:.}\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/arV_7YXzQr)",
                "title": "jq: mapping all values of an object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641532620,
        "creation_date": 1641502853,
        "question_id": 70613566,
        "body_markdown": "Say I have an object like so:\r\n```\r\n{\r\n  &quot;key1&quot;: &quot;value1&quot;,\r\n  &quot;key2&quot;: &quot;value2&quot;,\r\n  &quot;key3&quot;: &quot;value3&quot;\r\n}\r\n```\r\n\r\nI want to use `jq` to convert this to:\r\n```\r\n{\r\n  &quot;key1&quot;: {\r\n    &quot;innerkey&quot;: &quot;value1&quot;\r\n  },\r\n  &quot;key2&quot;: {\r\n    &quot;innerkey&quot;: &quot;value2&quot;\r\n  },\r\n  &quot;key3&quot;: {\r\n    &quot;innerkey&quot;: &quot;value3&quot;\r\n  }\r\n}\r\n```\r\n\r\ni.e. I want to apply a mapping to every value in the object, that converts `$value` to `{&quot;innerkey&quot;: $value}`. How can I achieve this with `jq`?",
        "link": "https://stackoverflow.com/questions/70613566/jq-mapping-all-values-of-an-object",
        "title": "jq: mapping all values of an 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": 1641541356,
                "post_id": 70617932,
                "comment_id": 124835274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19442881,
                    "reputation": 31,
                    "user_id": 17849041,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GjLR-aq25N35pFeIxmiATdCEnS7wan-R6bo5wVrvw=k-s256",
                    "display_name": "Rubavathi",
                    "link": "https://stackoverflow.com/users/17849041/rubavathi"
                },
                "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": 1,
                "creation_date": 1641542206,
                "post_id": 70617932,
                "comment_id": 124835491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1641542258,
                "post_id": 70617932,
                "comment_id": 124835508,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1641651865,
                "last_edit_date": 1641651865,
                "creation_date": 1641541218,
                "answer_id": 70618007,
                "question_id": 70617932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `+=` operator such as\r\n```\r\njq &#39;.student1 += { &quot;Phone2&quot;: &quot;1267345980&quot;, &quot;Phone3&quot;: &quot;9865432130&quot; }&#39;\r\n```\r\nand rename existing key `Phone` to `Phone1` by using\r\n```\r\njq --sort-keys &#39;.student1 += { &quot;Phone2&quot;: &quot;1267345980&quot;, &quot;Phone3&quot;: &quot;9865432130&quot; }| .[] | .[&quot;Phone1&quot;] = .Phone | del(.Phone) | {&quot;Student1&quot; : . }&#39;\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/y3372pSPgO)&lt;/kbd&gt;\r\n\r\n**Edit**( *due to your last edit* ): Considering you have an array `VALUES` such as \r\n```\r\n$ declare -p VALUES\r\ndeclare -a VALUES=&#39;([0]=&quot;\\&quot;1267345980\\&quot;&quot; [1]=&quot;\\&quot;9865432130\\&quot;&quot;)&#39;\r\n```\r\nand have a JSON file named `Students.json`, then use \r\n```\r\nm=2\r\nfor i in &quot;${VALUES[@]}&quot; \r\ndo  \r\n  cat &lt;&lt;&lt; $(jq &#39;.student1 += { &quot;Phone&#39;&quot;${m}&quot;&#39;&quot; : &#39;&quot;${i}&quot;&#39;}&#39; Students.json) &gt; Students.json\r\n  let &quot;m += 1&quot;   \r\ndone\r\n```\r\nin order to add the elements with keys `Phone2` and `Phone3` taken from the array\r\n\r\nP.S.: *tested on GNU/Linux*",
                "title": "Bash script to Add a new key value pair dynamically in Json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1641854560,
        "creation_date": 1641540817,
        "last_edit_date": 1641558967,
        "question_id": 70617932,
        "body_markdown": "\r\nMy JSON file is,\r\n```json\r\n{\r\n  &quot;student1&quot;: {\r\n    &quot;Name&quot;: &quot;Caroline&quot;,\r\n    &quot;Age&quot;: &quot;24&quot;,\r\n    &quot;email&quot;: &quot;Caroline123@gmail.com&quot;,\r\n    &quot;Phone&quot;: &quot;1234567890&quot;,\r\n    &quot;Blood group&quot;: &quot;O+ve&quot;\r\n  }\r\n}\r\n```\r\nMy desired output is,\r\n```json\r\n{\r\n  &quot;student1&quot;: {\r\n    &quot;Name&quot;: &quot;Caroline&quot;,\r\n    &quot;Age&quot;: &quot;24&quot;,\r\n    &quot;email&quot;: &quot;Caroline123@gmail.com&quot;,\r\n    &quot;Phone1&quot;: &quot;1234567890&quot;,\r\n    &quot;Phone2&quot;: &quot;1267345980&quot;,\r\n    &quot;Phone3&quot;: &quot;9865432130&quot;,\r\n    &quot;Blood group&quot;: &quot;O+ve&quot;\r\n  }\r\n}\r\n```\r\nThe new key-value pairs **Phone1**, **Phone2** and **Phone3** , whose values are stored in the array called VALUES, needs to be added in the place of the key **Phone**\r\n```\r\nm=1\r\nfor i in ${VALUES[@]}\r\ndo\r\n  jq --arg newval &quot;$i&quot; &#39;.student1 += { VALUES$m: $newval }&#39; &lt;&lt;&lt;&quot;$filepath&quot;\r\n  let &quot;m += 1&quot;\r\ndone\r\n```\r\nAbove is my code, But it&#39;s not working!\r\nCan anyone please help me to get the desired output!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70617932/bash-script-to-add-a-new-key-value-pair-dynamically-in-json",
        "title": "Bash script to Add a new key value pair dynamically in Json"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641546171,
                "creation_date": 1641546171,
                "answer_id": 70618865,
                "question_id": 70618659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Evidently the element `id` is nested within an object such like the other ones by wrapper curly braces, then call that as\r\n```\r\njq &#39;.[].id&#39;\r\n```\r\nin order to get the value `4738245`",
                "title": "How to parse data from a no-name array json using jq in linux command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1641561538,
        "creation_date": 1641545081,
        "last_edit_date": 1641561538,
        "question_id": 70618659,
        "body_markdown": "```json\r\n[\r\n  {\r\n    &quot;id&quot;: 4738245,\r\n    &quot;project_id&quot;: 25486,\r\n    &quot;sha&quot;: &quot;871c0484c3a7e72deea96fbcd48djdgh2&quot;,\r\n    &quot;ref&quot;: &quot;&quot;,\r\n    &quot;status&quot;: &quot;success&quot;,\r\n    &quot;created_at&quot;: &quot;2022-01-06T04:44:40.372Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2022-01-06T04:50:36.663Z&quot;,\r\n    &quot;web_url&quot;: &quot;&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe above is the json response I get from an gitlab API. I am trying to use ``jq &#39;.id&#39;`` to parse the id from the json response. \r\n\r\nThe error I get is :``jq: error (at &lt;stdin&gt;:0): Cannot index array with string &quot;id&quot;\r\n``\r\n\r\nI understand that it should be ``jq &#39;.&lt;arrayName&gt; .id&#39;`` to parse it. However, the response does not give any arrayName so I cannot use that method.",
        "link": "https://stackoverflow.com/questions/70618659/how-to-parse-data-from-a-no-name-array-json-using-jq-in-linux-command",
        "title": "How to parse data from a no-name array json using jq in linux command?"
    },
    {
        "tags": [
            "json",
            "stream",
            "extract",
            "jq"
        ],
        "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": 1641570731,
                "post_id": 70623635,
                "comment_id": 124846036,
                "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": 1641570835,
                "post_id": 70623635,
                "comment_id": 124846092,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23861249,
                    "reputation": 103,
                    "user_id": 17864167,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4666759dd1f40c4b6cce03862edb6504?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sander",
                    "link": "https://stackoverflow.com/users/17864167/sander"
                },
                "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": 1641570938,
                "post_id": 70623635,
                "comment_id": 124846135,
                "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": 1641571269,
                "post_id": 70623635,
                "comment_id": 124846259,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23861249,
                    "reputation": 103,
                    "user_id": 17864167,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4666759dd1f40c4b6cce03862edb6504?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sander",
                    "link": "https://stackoverflow.com/users/17864167/sander"
                },
                "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": 1641572898,
                "post_id": 70623635,
                "comment_id": 124847030,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1641591474,
                "last_edit_date": 1641591474,
                "creation_date": 1641573225,
                "answer_id": 70624380,
                "question_id": 70623635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should use the `--stream` flag in combination with the `fromstream` builtin\r\n\r\n```sh\r\njq --stream --null-input &#39;\r\n  fromstream(inputs | select(.[0][0] == &quot;items&quot;))[]\r\n&#39; file.json \r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;code&quot;: &quot;AA&quot;,\r\n    &quot;name&quot;: &quot;Example 1&quot;,\r\n    &quot;prices&quot;: [\r\n      &quot;other&quot;,\r\n      &quot;content&quot;,\r\n      &quot;here&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;code&quot;: &quot;BB&quot;,\r\n    &quot;name&quot;: &quot;Example 2&quot;,\r\n    &quot;prices&quot;: [\r\n      &quot;other&quot;,\r\n      &quot;content&quot;,\r\n      &quot;here&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/rJsqlK30oH) not for the efficiency or memory consumption but rather for the syntax (as I had to stream your original input using `tostream` for the lack of the `--stream` option on jqplay.org)\r\n\r\n---\r\n\r\nNote: Although it works for the sample data, do not try to shortcut using\r\n```sh\r\njq --stream --null-input &#39;fromstream(inputs).items&#39; file.json\r\n```\r\ndirectly on your large JSON file, as it only\r\n&gt; reconstructs the entire input JSON entity, thus defeating the purpose of using `--stream`\r\n\r\n(clarified by [@peak](https://stackoverflow.com/questions/70623635/extract-top-level-key-and-contents-from-large-json-using-stream/70624380?noredirect=1#comment124852874_70624380))",
                "title": "Extract top-level key and contents from large JSON using stream"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1641590041,
                "creation_date": 1641590041,
                "answer_id": 70627258,
                "question_id": 70623635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If a stream of the {code, name, prices} objects is acceptable, then you could go with:\r\n```\r\n&lt; input.json jq --stream -n &#39;\r\n   fromstream( 2 | truncate_stream(inputs | select(.[0][0] == &quot;items&quot;)) )&#39;\r\n```\r\n\r\nThis would have minimal memory requirements, which may or may not be significant depending on the value of `.items|length`\r\n\r\n",
                "title": "Extract top-level key and contents from large JSON using stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1653515382,
        "creation_date": 1641569815,
        "last_edit_date": 1653515382,
        "question_id": 70623635,
        "body_markdown": "One procedure in a system is to &#39;extract&#39; one key and its (object) value to a dedicated file to subsequently process it in some way in a (irrelevant) script.\r\n\r\nA representative subset of the original JSON file looks like:\r\n```json\r\n{\r\n  &quot;version&quot; : null,\r\n  &quot;produced&quot; : &quot;2021-01-01T00:00:00+0000&quot;,\r\n  &quot;other&quot;: &quot;content here&quot;,\r\n  &quot;items&quot; : [\r\n    {\r\n      &quot;code&quot; : &quot;AA&quot;,\r\n      &quot;name&quot; : &quot;Example 1&quot;,\r\n      &quot;prices&quot; : [ &quot;other&quot;, &quot;content&quot;, &quot;here&quot; ]\r\n    }, \r\n    {\r\n      &quot;code&quot; : &quot;BB&quot;,\r\n      &quot;name&quot; : &quot;Example 2&quot;,\r\n      &quot;prices&quot; : [ &quot;other&quot;, &quot;content&quot;, &quot;here&quot; ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd the current output, given that subset as input, simply equals:\r\n\r\n```json\r\n[\r\n    {\r\n      &quot;code&quot; : &quot;AA&quot;,\r\n      &quot;name&quot; : &quot;Example 1&quot;,\r\n      &quot;prices&quot; : [ &quot;other&quot;, &quot;content&quot;, &quot;here&quot; ],\r\n    }, \r\n    {\r\n      &quot;code&quot; : &quot;BB&quot;,\r\n      &quot;name&quot; : &quot;Example 2&quot;,\r\n      &quot;prices&quot; : [ &quot;other&quot;, &quot;content&quot;, &quot;here&quot; ],\r\n    }, \r\n    ...\r\n]\r\n```\r\n\r\n\r\nPreviously, we would extract the whole portion of &quot;items&quot; using `jq` with a very straightforward command (which worked fine):\r\n\r\n```\r\ncat file.json | jq &#39;.items&#39; &gt; file.items.json\r\n```\r\n\r\nHowever, recently the size of the original json file has increased drastically in size, causing the script to fail due to a **Out of memory** error. One obvious solution is to use jq&#39;s &#39;stream&#39; option. However, I am kind of stuck on how to convert above command to a valid filter in jq&#39;s stream syntax.\r\n\r\n```\r\ncat file.json | jq --stream &#39;...&#39; &gt; file.items.json\r\n```\r\n\r\nAny advice on what to use as a filter for this command would be greatly appreciated. Thanks in advance!",
        "link": "https://stackoverflow.com/questions/70623635/extract-top-level-key-and-contents-from-large-json-using-stream",
        "title": "Extract top-level key and contents from large JSON using stream"
    },
    {
        "tags": [
            "json",
            "arguments",
            "parameter-passing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1641578359,
                "creation_date": 1641578359,
                "answer_id": 70625347,
                "question_id": 70625307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson`, not `--arg`.\r\n\r\n    $ jq --null-input --argjson tst null &#39;.xxx=$tst&#39;\r\n    {\r\n      &quot;xxx&quot;: null\r\n    }\r\n\r\n`--arg` always treats the assigned value as a string, while `--argjson` treats it as a JSON value.",
                "title": "Pass NULL argument with JQ --arg"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641590775,
                "creation_date": 1641590775,
                "answer_id": 70627347,
                "question_id": 70625307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Three other simple possibilities, shortest first:\r\n```\r\njq -n &#39;{xxx: .}&#39;\r\n```\r\n\r\n```\r\necho null | jq  &#39;{xxx: .}&#39;\r\n```\r\n\r\n```\r\njq -n --argjson xxx null  &#39;{$xxx}&#39;\r\n```",
                "title": "Pass NULL argument with JQ --arg"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641590775,
        "creation_date": 1641578081,
        "question_id": 70625307,
        "body_markdown": "My desired end state is a JSON file like this:\r\n```\r\n{\r\n   &quot;xxx&quot;: null\r\n}\r\n```\r\nbut the command `jq --null-input --arg tst null &#39;.xxx=$tst&#39;` produces:\r\n```\r\n{\r\n  &quot;xxx&quot;: &quot;null&quot;\r\n}\r\n```\r\n\r\nand `jq --null-input --arg tst &quot;&quot; &#39;.xxx=$tst&#39;` produces:\r\n```\r\n{\r\n  &quot;xxx&quot;: &quot;&quot;\r\n}\r\n```\r\nHow can I pass a value that becomes the value `null` and not string `&quot;null&quot;`?\r\n ",
        "link": "https://stackoverflow.com/questions/70625307/pass-null-argument-with-jq-arg",
        "title": "Pass NULL argument with JQ --arg"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1641590585,
                "post_id": 70627285,
                "comment_id": 124852944,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5378845,
                    "reputation": 156,
                    "user_id": 4284762,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c78719da00041cc8539e9c570a24582b?s=256&d=identicon&r=PG",
                    "display_name": "esahmo",
                    "link": "https://stackoverflow.com/users/4284762/esahmo"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641590828,
                "post_id": 70627285,
                "comment_id": 124853011,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641590910,
                "post_id": 70627285,
                "comment_id": 124853033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5378845,
                    "reputation": 156,
                    "user_id": 4284762,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c78719da00041cc8539e9c570a24582b?s=256&d=identicon&r=PG",
                    "display_name": "esahmo",
                    "link": "https://stackoverflow.com/users/4284762/esahmo"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591129,
                "post_id": 70627285,
                "comment_id": 124853082,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591184,
                "post_id": 70627285,
                "comment_id": 124853099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591226,
                "post_id": 70627285,
                "comment_id": 124853112,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 347033,
                    "reputation": 70181,
                    "user_id": 680920,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/2fa160ca7a85db04bcb02a13f92bfd92?s=256&d=identicon&r=PG",
                    "display_name": "quickshiftin",
                    "link": "https://stackoverflow.com/users/680920/quickshiftin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591428,
                "post_id": 70627285,
                "comment_id": 124853167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5378845,
                    "reputation": 156,
                    "user_id": 4284762,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c78719da00041cc8539e9c570a24582b?s=256&d=identicon&r=PG",
                    "display_name": "esahmo",
                    "link": "https://stackoverflow.com/users/4284762/esahmo"
                },
                "reply_to_user": {
                    "account_id": 347033,
                    "reputation": 70181,
                    "user_id": 680920,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/2fa160ca7a85db04bcb02a13f92bfd92?s=256&d=identicon&r=PG",
                    "display_name": "quickshiftin",
                    "link": "https://stackoverflow.com/users/680920/quickshiftin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591663,
                "post_id": 70627285,
                "comment_id": 124853224,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 347033,
                    "reputation": 70181,
                    "user_id": 680920,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/2fa160ca7a85db04bcb02a13f92bfd92?s=256&d=identicon&r=PG",
                    "display_name": "quickshiftin",
                    "link": "https://stackoverflow.com/users/680920/quickshiftin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641591748,
                "post_id": 70627285,
                "comment_id": 124853243,
                "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": 1641592299,
                "post_id": 70627285,
                "comment_id": 124853388,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641603537,
                "post_id": 70627285,
                "comment_id": 124855636,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1641610809,
                "post_id": 70627285,
                "comment_id": 124856428,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1641634978,
                "last_edit_date": 1641634978,
                "creation_date": 1641593910,
                "answer_id": 70627767,
                "question_id": 70627285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### Update\r\n\r\nI may have misunderstood what OP wanted. If it&#39;s a CSV with only one record then you can do:\r\n\r\n``` bash\r\ny=Rule\r\nx=$(aws s3api get-bucket-lifecycle-configuration --bucket test | jq &#39;.Rules[]&#39;)\r\njq -nr --arg y &quot;$y&quot; --arg x &quot;$x&quot; &#39;[$y, $x] | @csv&#39; &gt; sample.csv\r\n```\r\nPlease take notice that the JSON stored in the second column of the CSV is not strictly valid as it&#39;s composed of a stack of objects instead of an array.\r\n\r\n---\r\n#### Prior answer\r\n\r\nYou can use `jq`:\r\n\r\n``` sh\r\naws s3api get-bucket-lifecycle-configuration --bucket test |\r\njq -r &#39;.Rules[] | [ (. | tostring) ] | @csv&#39;\r\n```\r\n\r\nCSV output:\r\n\r\n``` csv\r\n&quot;{&quot;&quot;Expiration&quot;&quot;:{&quot;&quot;Days&quot;&quot;:7},&quot;&quot;ID&quot;&quot;:&quot;&quot;Expire after 7 days&quot;&quot;,&quot;&quot;Filter&quot;&quot;:{&quot;&quot;Prefix&quot;&quot;:&quot;&quot;&quot;&quot;},&quot;&quot;Status&quot;&quot;:&quot;&quot;Enabled&quot;&quot;}&quot;\r\n&quot;{&quot;&quot;Expiration&quot;&quot;:{&quot;&quot;Days&quot;&quot;:1},&quot;&quot;ID&quot;&quot;:&quot;&quot;Remove after 1 day&quot;&quot;,&quot;&quot;Filter&quot;&quot;:{},&quot;&quot;Status&quot;&quot;:&quot;&quot;Enabled&quot;&quot;}&quot;\r\n```\r\n\r\nBut as @ZachYoung pointed out, as of now `jq` doesn&#39;t have any easy way to generate pretty strings with `tostring` or `tojson`.\r\n\r\nPersonally I would stick to the compact version, but if the pretty formatting is really necessary then I would switch to `ruby` instead of `jq` (python is also an option but it lacks the one-liner thingy^^):\r\n\r\n``` sh\r\naws s3api get-bucket-lifecycle-configuration --bucket test |\r\nruby -rjson -rcsv -e &#39;puts &quot;Rules&quot;, JSON.parse(ARGF.read)[&quot;Rules&quot;].map{|rule| [JSON.pretty_generate(rule)].to_csv}&#39;\r\n```\r\n\r\nCSV output:\r\n``` csv\r\nRules\r\n&quot;{\r\n  &quot;&quot;Expiration&quot;&quot;: {\r\n    &quot;&quot;Days&quot;&quot;: 7\r\n  },\r\n  &quot;&quot;ID&quot;&quot;: &quot;&quot;Expire after 7 days&quot;&quot;,\r\n  &quot;&quot;Filter&quot;&quot;: {\r\n    &quot;&quot;Prefix&quot;&quot;: &quot;&quot;&quot;&quot;\r\n  },\r\n  &quot;&quot;Status&quot;&quot;: &quot;&quot;Enabled&quot;&quot;\r\n}&quot;\r\n&quot;{\r\n  &quot;&quot;Expiration&quot;&quot;: {\r\n    &quot;&quot;Days&quot;&quot;: 1\r\n  },\r\n  &quot;&quot;ID&quot;&quot;: &quot;&quot;Remove after 1 day&quot;&quot;,\r\n  &quot;&quot;Filter&quot;&quot;: {\r\n  },\r\n  &quot;&quot;Status&quot;&quot;: &quot;&quot;Enabled&quot;&quot;\r\n}&quot;\r\n```\r\n\r\n\r\n\r\n",
                "title": "Bash store JSON output to CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1641634978,
        "creation_date": 1641590229,
        "last_edit_date": 1641593285,
        "question_id": 70627285,
        "body_markdown": "I have a bash script in which I am trying to store the aws command output (which is a JSON) to CSV file.\r\nThis is the JSON output of the aws s3 command.\r\n\r\n    {\r\n      &quot;Expiration&quot;: {\r\n        &quot;Days&quot;: 7\r\n      },\r\n      &quot;ID&quot;: &quot;Expire after 7 days&quot;,\r\n      &quot;Filter&quot;: {\r\n        &quot;Prefix&quot;: &quot;&quot;\r\n      },\r\n      &quot;Status&quot;: &quot;Enabled&quot;\r\n    }\r\n    {\r\n      &quot;Expiration&quot;: {\r\n        &quot;Days&quot;: 1\r\n      },\r\n      &quot;ID&quot;: &quot;Remove after 1 day&quot;,\r\n      &quot;Filter&quot;: {},\r\n      &quot;Status&quot;: &quot;Enabled&quot;\r\n    }\r\n\r\n\r\nHere is my script\r\n\r\n    #!/bin/bash\r\n    y=&quot;Rule&quot;\r\n    x=$(aws s3api get-bucket-lifecycle-configuration --bucket test | jq -r &#39;.Rules[]&#39;)\r\n    echo  ${y}, ${x} &gt;&gt; sample.csv\r\n\r\nThe JSON response is getting saved to sample.csv but in separate columns. I want it to be in 1 column and in pretty JSON format.\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/dCRTv.png\r\n\r\nIs there a way to do this?",
        "link": "https://stackoverflow.com/questions/70627285/bash-store-json-output-to-csv",
        "title": "Bash store JSON output to CSV"
    },
    {
        "tags": [
            "json",
            "linux",
            "split",
            "sh",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1641598471,
                "creation_date": 1641598471,
                "answer_id": 70628313,
                "question_id": 70627447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In this response, which calls jq just once, I&#39;m going to assume your computer has enough memory to read the entire JSON.  I&#39;ll also assume you want to create separate files for each slice, and that you want the JSON to be pretty-printed in each file.\r\n\r\nAssuming a chunk size of 2, and that the output files are to be named using the template part-N.json, you could write:\r\n```\r\n&lt; input.json jq -r --argjson size 2 &#39;\r\n  del(.add) as $object\r\n  | (.add|_nwise($size) | (&quot;\\t&quot;, $object + {add:.} ))\r\n&#39; | awk &#39;\r\n      /^\\t/ {fn++; next}\r\n      { print &gt;&gt; &quot;part-&quot; fn &quot;.json&quot;}&#39;\r\n```\r\n\r\nThe trick being used here is that valid JSON cannot contain a tab character.",
                "title": "Split/Slice large JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1641600006,
                "creation_date": 1641600006,
                "answer_id": 70628468,
                "question_id": 70627447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes the input JSON is too large to read into memory and therefore uses jq&#39;s `--stream` command-line option.  \r\n\r\nTo keep things simple, I&#39;ll focus on the &quot;slicing&quot;  of the `.add` array, and won&#39;t worry about the other keys, or pretty-printing, and other details, as you can easily adapt the following according to your needs:\r\n```\r\n&lt; input.json jq -nc --stream --argjson size 2 &#39;\r\n  def regroup(stream; $n):\r\n    foreach (stream, null) as $x ({a:[]};\r\n      if $x == null then .emit = .a\r\n      elif .a|length == $n then .emit = .a | .a = [$x]\r\n      else .emit=null | .a += [$x] end;\r\n      select(.emit).emit);\r\n\r\n    regroup(fromstream( 2 | truncate_stream(inputs | select(.[0][0] == &quot;add&quot;)) );\r\n            $size)&#39; |\r\n  awk &#39;{fn++; print &gt; fn &quot;.json&quot;}&#39;\r\n```\r\n\r\nThis writes the arrays to files with filenames of the form N.json\r\n\r\n",
                "title": "Split/Slice large JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1641654369,
        "creation_date": 1641591485,
        "last_edit_date": 1641654369,
        "question_id": 70627447,
        "body_markdown": "Would like to SLICE a huge json file ~20GB into smaller chunk of data based on array size (10000/50000 etc).. \r\n\r\nInput:\r\n\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,\r\n     &quot;country&quot;:&quot;US&quot;,\r\n     &quot;name&quot;:&quot;ABC&quot;,\r\n     &quot;number&quot;:&quot;9828&quot;,\r\n     &quot;add&quot;: [\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;1&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;2&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77832&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;3&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77831&quot;},\r\n         {&quot;evnCd&quot;:&quot;O&quot;,&quot;rngNum&quot;:&quot;4&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77834&quot;}\r\n     ]\r\n    }\r\n\r\nCurrently running in a loop to get the desire output by incrementing x/y value, but performance is very slow and takes very 8-20 seconds for a iteration depends on size of the file to complete the split process. Currently using 1.6 version, is there any alternates for getting below result\r\n\r\nExpected Output: for Slice of 2 objects in array\r\n\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,&quot;country&quot;:&quot;US&quot;,&quot;name&quot;:&quot;ABC&quot;,&quot;number&quot;:&quot;9828&quot;,&quot;add&quot;:[{&quot;rngNum&quot;:&quot;1&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77830&quot;},{&quot;rngNum&quot;:&quot;2&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77832&quot;}]}\r\n    {&quot;recDt&quot;:&quot;2021-01-05&quot;,&quot;country&quot;:&quot;US&quot;,&quot;name&quot;:&quot;ABC&quot;,&quot;number&quot;:&quot;9828&quot;,&quot;add&quot;:[{&quot;rngNum&quot;:&quot;3&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77831&quot;},{&quot;rngNum&quot;:&quot;4&quot;,&quot;state&quot;:&quot;TX&quot;,&quot;city&quot;:&quot;ANDERSON&quot;,&quot;postal&quot;:&quot;77834&quot;}]}\r\n\r\nTried with \r\n\r\n    cat $inFile | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; | jq --arg x $x --arg y $y -c &#39;{recDt: .recDt, country: .country, name: .name, number: .number, add: .add[$x|tonumber:$y|tonumber]}&#39; &gt;&gt; $outFile\r\n\r\n    cat $inFile | jq --arg x $x --arg y $y -c &#39;{recDt: .recDt, country: .country, name: .name, number: .number, add: .add[$x|tonumber:$y|tonumber]}&#39; &gt;&gt; $outFile  \r\n\r\nPlease share if there are any alternate available.. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/70627447/split-slice-large-json-using-jq",
        "title": "Split/Slice large JSON using jq"
    }
]