[
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "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": 1667219120,
                "post_id": 74242504,
                "comment_id": 131111110,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667012703,
                "creation_date": 1667012703,
                "answer_id": 74242541,
                "question_id": 74242504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `..`, e.g. along the lines of:\r\n\r\n    jq &#39;.. | objects | .z // empty&#39;\r\n\r\nIf `.z` can take the value `null`, then adjust according to your requirements.",
                "title": "How to get the value of json field when its parent object key is dynamic using a jq expression?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667012735,
                "creation_date": 1667012735,
                "answer_id": 74242543,
                "question_id": 74242504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the name is dynamic but the position is known, you can iterate over field candidates using `.[]` and check if a subfield &quot;z&quot; exists using `select` and `has`:\r\n~~~sh\r\n.f[][] | select(has(&quot;z&quot;)?).z\r\n~~~\r\n[Demo](https://jqplay.org/s/EQaS8WHBQkU)\r\n\r\nAlternatively, if the depths are also unknown, you can traverse the whole document using `..`:\r\n~~~sh\r\n.. | select(has(&quot;z&quot;)?).z\r\n~~~\r\n[Demo](https://jqplay.org/s/NKow2v1Ipll)",
                "title": "How to get the value of json field when its parent object key is dynamic using a jq expression?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1667012735,
        "creation_date": 1667011912,
        "question_id": 74242504,
        "body_markdown": "Example json:\r\n\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;c&quot;: {\r\n        &quot;ca&quot;: 1.1\r\n      },\r\n      &quot;d&quot;: {},\r\n      &quot;e&quot;: [1,2,3],\r\n      &quot;f&quot;: [\r\n        {\r\n          &quot;fa&quot;: &quot;vf1&quot;,\r\n          &quot;fb&quot;: &quot;vf2&quot;,\r\n          &quot;fc&quot;: [],\r\n          &quot;fffs232/232&quot;: {\r\n            &quot;z&quot;: 1\r\n          }\r\n        },\r\n        {\r\n          &quot;fa&quot;: &quot;vf3&quot;,\r\n          &quot;fb&quot;: &quot;vf4&quot;,\r\n          &quot;fc&quot;: [1.1,2.3],\r\n          &quot;fffs232/232&quot;: {\r\n            &quot;z&quot;: 2\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nI want a full path jq expression that gives me the values of &quot;z&quot;. Such expression should not explicitly mention  &quot;fffs232/232&quot; since that key is dynamic.\r\n\r\nIs this possible with jq? \r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/74242504/how-to-get-the-value-of-json-field-when-its-parent-object-key-is-dynamic-using-a",
        "title": "How to get the value of json field when its parent object key is dynamic using a jq expression?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1667066874,
                "creation_date": 1667066874,
                "answer_id": 74247656,
                "question_id": 74247476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.data.repository.releases.nodes | map({tagName, date} + .releaseAssets.nodes[])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/UiNoFUdxIx-)&lt;/sup&gt;",
                "title": "How can I map/add field(s) from a node&#39;s parent into specific child leaves?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667066874,
        "creation_date": 1667065301,
        "question_id": 74247476,
        "body_markdown": "Given the following example JSON object (modeled after GitHub GraphQL query result):\r\n\r\n### Example\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;repository&quot;: {\r\n      &quot;releases&quot;: {\r\n        &quot;nodes&quot;: [\r\n          {\r\n            &quot;tagName&quot;: &quot;v2.0.0&quot;,\r\n            &quot;date&quot;: &quot;2022-10-26T14:22:15Z&quot;,\r\n            &quot;releaseAssets&quot;: {\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;foo-2.0.0.tar.gz&quot;,\r\n                  &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0.tar.gz&quot;\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;foo-2.0.0-arm64.AppImage&quot;,\r\n                  &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0-arm64.AppImage&quot;\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;tagName&quot;: &quot;v1.3.0&quot;,\r\n            &quot;date&quot;: &quot;2021-03-10T07:10:41Z&quot;,\r\n            &quot;releaseAssets&quot;: {\r\n              &quot;nodes&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;foo-1.3.0.tar.gz&quot;,\r\n                  &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0.tar.gz&quot;\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;foo-1.3.0-arm64.AppImage&quot;,\r\n                  &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0-arm64.AppImage&quot;\r\n                }\r\n              ]\r\n            }\r\n          },\r\n          {\r\n            &quot;tagName&quot;: &quot;v0.9.9&quot;,\r\n            &quot;releaseAssets&quot;: {\r\n              &quot;nodes&quot;: []\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nCan someone tell me what jq-fu will map the `tagName` and the `date` fields into each item in `nodes[]` and skip the empty `nodes` array to produce the following desired output?\r\n\r\n### Desired Output\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo-2.0.0.tar.gz&quot;,\r\n    &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0.tar.gz&quot;,\r\n    &quot;tagName&quot;: &quot;v2.0.0&quot;,\r\n    &quot;date&quot;: &quot;2022-10-26T14:22:15Z&quot;,\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;foo-2.0.0-arm64.AppImage&quot;,\r\n    &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v2.0.0/foo-2.0.0-arm64.AppImage&quot;\r\n    &quot;tagName&quot;: &quot;v2.0.0&quot;,\r\n    &quot;date&quot;: &quot;2022-10-26T14:22:15Z&quot;,\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;foo-1.3.0.tar.gz&quot;,\r\n    &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0.tar.gz&quot;\r\n    &quot;tagName&quot;: &quot;v1.3.0&quot;,\r\n    &quot;date&quot;: &quot;2021-03-10T07:10:41Z&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;foo-1.3.0-arm64.AppImage&quot;,\r\n    &quot;downloadUrl&quot;: &quot;https://github.com/foo/foo-releases/releases/download/v1.3.0/foo-1.3.0-arm64.AppImage&quot;\r\n    &quot;tagName&quot;: &quot;v1.3.0&quot;,\r\n    &quot;date&quot;: &quot;2021-03-10T07:10:41Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nHow can I obtain the above output in the most efficient manner?\r\n",
        "link": "https://stackoverflow.com/questions/74247476/how-can-i-map-add-fields-from-a-nodes-parent-into-specific-child-leaves",
        "title": "How can I map/add field(s) from a node&#39;s parent into specific child leaves?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667128572,
                "creation_date": 1667128572,
                "answer_id": 74252567,
                "question_id": 74252532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`any/1`](https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)).\r\n```\r\nany(.login == &quot;bar&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/WFJPJgoiXuo)&lt;/sup&gt;",
                "title": "Find if item with specific property is in JSON array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667134170,
        "creation_date": 1667128258,
        "last_edit_date": 1667134170,
        "question_id": 74252532,
        "body_markdown": "I have the following JSON array\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;login&quot;: &quot;foo&quot;,\r\n    &quot;id&quot;: 111\r\n  },\r\n  {\r\n    &quot;login&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: 222\r\n  },\r\n  {\r\n    &quot;login&quot;: &quot;foobar&quot;,\r\n    &quot;id&quot;: 333\r\n  }\r\n]\r\n```\r\n\r\nHow can I leverage the `jq` (preferrably) to check whether the object with `&quot;login&quot;: &quot;bar&quot;` is member of this array?",
        "link": "https://stackoverflow.com/questions/74252532/find-if-item-with-specific-property-is-in-json-array",
        "title": "Find if item with specific property is in JSON array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667196965,
                "post_id": 74259218,
                "comment_id": 131104933,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667196937,
                "creation_date": 1667196937,
                "answer_id": 74259377,
                "question_id": 74259218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just delete the old field using `del`, and add another one using [object construction](https://stedolan.github.io/jq/manual/#ObjectConstruction%3A%7B%7D):\r\n~~~sh\r\njq &#39;.item[]  | select(.closed == false and .id == &quot;1234&quot;) | del(.id) + {item_id: .id}&#39; data.json\r\n~~~\r\n\r\nOr use `with_entries` to &quot;rename&quot; the old field:\r\n~~~sh\r\njq &#39;.item[]  | select(.closed == false and .id == &quot;1234&quot;) | with_entries(select(.key == &quot;id&quot;).key = &quot;item_id&quot;)&#39; data.json\r\n~~~",
                "title": "jq JSON key change assignment not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667196937,
        "creation_date": 1667195528,
        "question_id": 74259218,
        "body_markdown": "jq key assignment is not working.\r\n\r\nI tried what was here for my use case.\r\nhttps://stackoverflow.com/questions/43522133/using-jq-how-can-i-replace-the-name-of-a-key-with-something-else\r\n\r\nin this case I want to change `id` to item_id`.\r\n\r\n```\r\njq &#39;.item[]  | select(.closed == false) | select(.id == &quot;1234&quot;) |  .[&quot;id&quot;] = .[&quot;item_id&quot;] | .&#39; data.json | less\r\n```\r\n\r\nthe result does not error but &quot;id&quot; gets a value of `null` and there is not key called `item_id`. so there is something I am not getting right about assignment of the key.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74259218/jq-json-key-change-assignment-not-working",
        "title": "jq JSON key change assignment not working"
    },
    {
        "tags": [
            "jq",
            "variable-assignment"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1667218724,
                "post_id": 74262719,
                "comment_id": 131110959,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667224804,
                "post_id": 74262719,
                "comment_id": 131113242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667226783,
                "post_id": 74262719,
                "comment_id": 131114052,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667232780,
                "last_edit_date": 1667232780,
                "creation_date": 1667225446,
                "answer_id": 74264590,
                "question_id": 74262719,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please show:\r\n\r\n* Your input JSON\r\n* Your function definition\r\n* Your full jq program\r\n* Your expected output JSON\r\n\r\nBecause I don&#39;t know what you are trying to do or what&#39;s not working. The following jq program works just fine:\r\n\r\n```sh\r\n$ printf &#39;{&quot;months&quot;: 5}&#39; | jq &#39;def to_days: . * 30; # a very simple dummy impl\r\n(.months|to_days) as $calculated_days # store in variable\r\n| { days: $calculated_days }  # use variable&#39;\r\n```\r\n\r\nVariables are explained in [Variable / Symbolic Binding Operator: ... as $identifier | ...](https://stedolan.github.io/jq/manual/v1.6/#Variable/SymbolicBindingOperator:...as$identifier|...) in the jq manual.",
                "title": "How can I store a functions output into a variable in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667299729,
        "creation_date": 1667216400,
        "last_edit_date": 1667299729,
        "question_id": 74262719,
        "body_markdown": "I have been trying to convert months into days in my script. I managed to make a function that  turns an amount of months into days. I now want to store these days into a variable to be used in other functions later on. \r\nI have tried:\r\n\r\n```\r\ndays: .months|Months_to_Days\r\n```\r\nI have also tried to include it in an object with the month variable:\r\n\r\n```\r\n{\r\n months: &quot;12&quot;,\r\n days: .months|Months_to_Days\r\n}\r\n```\r\nThis also doesn&#39;t work because when I did:\r\n\r\n```\r\nmonths: &quot;12&quot;\r\ndays: months\r\n```\r\nas a test, the days returned `null`. How can I do it?\r\n\r\nI have tried:\r\n```\r\ndays: .months|Months_to_Days\r\n```\r\nThis returns:\r\n\r\n```\r\njq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 65:\r\n days: .months|Months_to_Days \r\n\r\n```\r\n\r\nThe function Months_to_Days is:\r\n\r\n    eif .|tonumber &gt; 8 then\r\n         ((.|tonumber - 1) * 30) + ((.|tonumber - 1)/2) + 1 - 2|floor\r\n        else\r\n              if  .|tonumber &lt; 3 then\r\n\r\n           ((.|tonumber - 1) * 30) + (.|tonumber/2)| floor\r\n        else\r\n         ((.|tonumber - 1) * 30) + (.|tonumber/2) - 2| floor end| debug         \r\n        end| debug\r\n\r\nThere is no input and it only uses the variables in the script.\r\nThe variables were:\r\n\r\n    {\r\n     months: &quot;12&quot;\r\n    }\r\nBefore I wanted to make the variable storing the output of the function, I would run it with:\r\n\r\n    .months|Months_to_Days\r\n\r\nThere isn&#39;t an expected output just to store the output of the function to use in other functions.",
        "link": "https://stackoverflow.com/questions/74262719/how-can-i-store-a-functions-output-into-a-variable-in-jq",
        "title": "How can I store a functions output into a variable in jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "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": 1667228048,
                "post_id": 74265057,
                "comment_id": 131114562,
                "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": 0,
                "creation_date": 1667228335,
                "post_id": 74265057,
                "comment_id": 131114670,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "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": 1667228486,
                "post_id": 74265057,
                "comment_id": 131114739,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1667229133,
                "last_edit_date": 1667229133,
                "creation_date": 1667228280,
                "answer_id": 74265206,
                "question_id": 74265057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get all strings containing the substring &quot;hi&quot;:\r\n~~~sh\r\njq &#39;..|select(contains(&quot;hi&quot;)?)&#39;\r\n~~~\r\n~~~json\r\n&quot;hi there&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/q2zmDUqiWMK)\r\n\r\nNote: Use the `-r` option to get raw strings instead of JSON strings.\r\n\r\n---\r\nTo get all objects with at least one field containing the substring &quot;hi&quot;:\r\n~~~sh\r\njq &#39;..|objects|select(any(contains(&quot;hi&quot;)?))&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/gTXxGIj1OPK)\r\n\r\nTo get all objects as many times as it has fields containing the substring &quot;hi&quot;:\r\n~~~sh\r\njq &#39;..|objects|select(.[]|contains(&quot;hi&quot;)?)&#39;\r\n~~~\r\n[Demo](https://jqplay.org/s/G7m9ZWXXaRO)\r\n\r\nGiven your example, both cases evaluate to\r\n~~~json\r\n{\r\n  &quot;a&quot;: &quot;hi there&quot;\r\n}\r\n~~~\r\n",
                "title": "jq, recursive descent, finding substring in value of any subkey"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667228553,
                "creation_date": 1667228553,
                "answer_id": 74265266,
                "question_id": 74265057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `..` will also encounter the strings so I&#39;d use an `if/else` to only catch the `type == &quot;object&quot;` and then loop over those values and `select()` those who `contains(&quot;hi&quot;)`:\r\n```\r\n.. | if type == &quot;object&quot; then select(.[] | contains(&quot;hi&quot;)) else empty end\r\n```\r\n\r\n",
                "title": "jq, recursive descent, finding substring in value of any subkey"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667241309,
                "last_edit_date": 1667241309,
                "creation_date": 1667228562,
                "answer_id": 74265267,
                "question_id": 74265057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .. | objects|with_entries(select(.value|strings|test(&quot;hi&quot;)))\r\n\r\nproduces the output shown as wanted in the Q:\r\n\r\n    { &quot;a&quot;: &quot;hi there&quot; }\r\n",
                "title": "jq, recursive descent, finding substring in value of any subkey"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1667241309,
        "creation_date": 1667227622,
        "last_edit_date": 1667231432,
        "question_id": 74265057,
        "body_markdown": "How can I change .a? to &quot;any key&quot;?  Like I wish I could put * instead of a.\r\n```\r\n&#39;[[{&quot;a&quot;:&quot;hi there&quot;}]]&#39; | jq &#39;..|select(.a?|contains(&quot;hi&quot;))&#39;\r\n\r\n{\r\n  &quot;a&quot;: &quot;hi there&quot;\r\n}\r\n```\r\nOr this nested object input?\r\n```\r\n&#39;[[{&quot;a&quot;:&quot;hi there&quot;,&quot;b&quot;:{&quot;c&quot;:&quot;hi again&quot;}}]]&#39; | jq &#39;..|select(.a?|contains(&quot;hi&quot;))&#39;\r\n\r\n{\r\n  &quot;a&quot;: &quot;hi there&quot;,\r\n  &quot;b&quot;: {\r\n    &quot;c&quot;: &quot;hi again&quot;\r\n  }\r\n}\r\njq: error (at &lt;stdin&gt;:1): null (null) and string (&quot;hi&quot;) cannot have their containment checked\r\n```",
        "link": "https://stackoverflow.com/questions/74265057/jq-recursive-descent-finding-substring-in-value-of-any-subkey",
        "title": "jq, recursive descent, finding substring in value of any subkey"
    },
    {
        "tags": [
            "line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667729478,
                "post_id": 74265651,
                "comment_id": 131231925,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667235562,
                "last_edit_date": 1667235562,
                "creation_date": 1667231592,
                "answer_id": 74265888,
                "question_id": 74265651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Build the string you want to output, then use the `-r` command-line to emit that string as-is (instead of as a JSON literal).\r\n\r\n```sh\r\njq -r &#39;\r\n   .result[] |\r\n   [\r\n      .id,\r\n      .redirect.source_url,\r\n      .redirect.target_url,\r\n      .cursors_after\r\n   ] |\r\n   @csv\r\n&#39; json\r\n```\r\n\r\noutputs\r\n\r\n```csv\r\n&quot;fcf9728ed6e94078bae9ffe200bf1054&quot;,&quot;www.1234.com/acssurgerynews/article/248345/transgender-health/detransitioners-received-poor-evaluation-when&quot;,&quot;https://www.1234.com/viewarticle/962270&quot;,\r\n&quot;fac3ab84691b44219c270a5dd073e374&quot;,&quot;www.1234.com/advanced-and-metastatic-breast-cancer/article/248363/breast-cancer/liquid-biopsy-metastatic-breast&quot;,&quot;https://www.1234.com/viewarticle/942277&quot;,\r\n&quot;0ae189027c574eedac22f854b4676568&quot;,&quot;www.1234.com/advanced-and-metastatic-breast-cancer/article/249807/breast-cancer/evolving-her2-metastatic-breast&quot;,&quot;https://www.1234.com/viewarticle/963856&quot;,\r\n```\r\n\r\n[Demo](https://jqplay.org/s/clXEI-BF05P) on jqplay",
                "title": "JQ Outputting different elements on the same line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667727749,
                "creation_date": 1667727749,
                "answer_id": 74334706,
                "question_id": 74265651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can build a new array per entry containing your values and then use `join(&quot;,&quot;)` to join all values on a single line. `-r`/`--raw-output` omits the quotes around top-level strings:\r\n\r\n```\r\njq -r &#39;.result[]\r\n| [.id,.redirect.source_url,.redirect.target_url,.cursors_after]\r\n| join(&quot;,&quot;)&#39;\r\n``\r\n\r\nThe difference between `join/1` and `@csv` filters is that `@csv` will escape any embedded commas in the value and automatically wrap all strings in quotes. `join` does not do any escaping and does not add quotes around strings.",
                "title": "JQ Outputting different elements on the same line"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1667727749,
        "creation_date": 1667230522,
        "last_edit_date": 1667235453,
        "question_id": 74265651,
        "body_markdown": "Json output:\r\n\r\n```\r\n{\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;fcf9728ed6e94078bae9ffe200bf1054&quot;,\r\n      &quot;redirect&quot;: {\r\n        &quot;source_url&quot;: &quot;www.1234.com/acssurgerynews/article/248345/transgender-health/detransitioners-received-poor-evaluation-when&quot;,\r\n        &quot;include_subdomains&quot;: false,\r\n        &quot;target_url&quot;: &quot;https://www.1234.com/viewarticle/962270&quot;,\r\n        &quot;status_code&quot;: 301,\r\n        &quot;preserve_query_string&quot;: false,\r\n        &quot;subpath_matching&quot;: false,\r\n        &quot;preserve_path_suffix&quot;: false\r\n      },\r\n      &quot;created_on&quot;: &quot;2022-09-07T17:12:21Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2022-09-07T17:12:21Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;fac3ab84691b44219c270a5dd073e374&quot;,\r\n      &quot;redirect&quot;: {\r\n        &quot;source_url&quot;: &quot;www.1234.com/advanced-and-metastatic-breast-cancer/article/248363/breast-cancer/liquid-biopsy-metastatic-breast&quot;,\r\n        &quot;include_subdomains&quot;: false,\r\n        &quot;target_url&quot;: &quot;https://www.1234.com/viewarticle/942277&quot;,\r\n        &quot;status_code&quot;: 301,\r\n        &quot;preserve_query_string&quot;: false,\r\n        &quot;subpath_matching&quot;: false,\r\n        &quot;preserve_path_suffix&quot;: false\r\n      },\r\n      &quot;created_on&quot;: &quot;2022-09-07T17:12:21Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2022-09-07T17:12:21Z&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;0ae189027c574eedac22f854b4676568&quot;,\r\n      &quot;redirect&quot;: {\r\n        &quot;source_url&quot;: &quot;www.1234.com/advanced-and-metastatic-breast-cancer/article/249807/breast-cancer/evolving-her2-metastatic-breast&quot;,\r\n        &quot;include_subdomains&quot;: false,\r\n        &quot;target_url&quot;: &quot;https://www.1234.com/viewarticle/963856&quot;,\r\n        &quot;status_code&quot;: 301,\r\n        &quot;preserve_query_string&quot;: false,\r\n        &quot;subpath_matching&quot;: false,\r\n        &quot;preserve_path_suffix&quot;: false\r\n      },\r\n      &quot;created_on&quot;: &quot;2022-09-07T17:12:21Z&quot;,\r\n      &quot;modified_on&quot;: &quot;2022-09-07T17:12:21Z&quot;\r\n    }\r\n  ],\r\n  &quot;success&quot;: true,\r\n  &quot;errors&quot;: [],\r\n  &quot;messages&quot;: [],\r\n  &quot;result_info&quot;: {\r\n    &quot;cursors&quot;: {\r\n      &quot;after&quot;: &quot;equIy9ku2FDvBVLy0avqNewCdepOQiaIaSilEIhBNwhHDIkcF5EjJkYqPwqeewvR5Rb6UO4LB5moBKoO9puoiyJ9QY_bidbcFtbpp60QzYEl_9Hls0jD_2oINTM_CWJPCBTvzmVu7LlUCNTB_UxXE-Ox6h8vuhE&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nWhat I&#39;m looking to output on the same line such as:\r\n\r\n**.id,.redirect.source_url,.redirect.target_url,.cursors_after** \r\n\r\nfcf9728ed6e94078bae9ffe200bf1054,www.123.com/123,https://www.123.com/xxx\r\nfcf9728ed6e94078bae9ffe200bf1054,www.123.com/123,https://www.123.com/xxx\r\nfcf9728ed6e94078bae9ffe200bf1054,www.123.com/123,https://www.123.com/xxx\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74265651/jq-outputting-different-elements-on-the-same-line",
        "title": "JQ Outputting different elements on the same line"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1667236918,
                "post_id": 74266931,
                "comment_id": 131117871,
                "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": 1,
                "creation_date": 1667236993,
                "post_id": 74266931,
                "comment_id": 131117905,
                "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": 0,
                "creation_date": 1667237184,
                "post_id": 74266931,
                "comment_id": 131117959,
                "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": 0,
                "creation_date": 1667237235,
                "post_id": 74266931,
                "comment_id": 131117969,
                "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": 1,
                "creation_date": 1667237256,
                "post_id": 74266931,
                "comment_id": 131117979,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11535657,
                    "reputation": 23,
                    "user_id": 8453197,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/71b420ce11320247f49c7f69e92f49ca?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nick",
                    "link": "https://stackoverflow.com/users/8453197/nick"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667237702,
                "post_id": 74266931,
                "comment_id": 131118101,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667255009,
                "last_edit_date": 1667255009,
                "creation_date": 1667242027,
                "answer_id": 74267869,
                "question_id": 74266931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might find it easier to construct the `for` loop along the following lines:\r\n```\r\nfor uri in $( echo &quot;$json&quot; | jq &#39;.children[].uri&#39;) ; do \r\n  echo curl ... ${uri}...\r\ndone   \r\n```",
                "title": "Iterate through the json object and run curl command as variable from json output using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667243204,
                "creation_date": 1667243204,
                "answer_id": 74268068,
                "question_id": 74266931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`curl` can read URLs to fetch from a file, which you can generate with `jq`. Something like\r\n\r\n    base=https://artifactory.com/api/releases/baseimage\r\n    curl -k -s --user user:password -X GET &quot;$base/&quot; |\r\n       jq -r --arg b &quot;$base&quot; &#39;.children[].uri | &quot;url = \\&quot;\\($b)/\\(.)\\&quot;&quot;&#39; |\r\n       curl -k -s --user user:password -X GET --config -\r\n\r\nJust one `curl` process to fetch all the individual images, and no shell loop needed.",
                "title": "Iterate through the json object and run curl command as variable from json output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667255009,
        "creation_date": 1667236693,
        "last_edit_date": 1667253965,
        "question_id": 74266931,
        "body_markdown": "I would like to filter the json object while iterating through it and run curl command over each item from the output.\r\n\r\nJSON object. \r\n```\r\n{\r\n  &quot;repo&quot;: &quot;releases&quot;,\r\n  &quot;path&quot;: &quot;/apps/releases&quot;,\r\n  &quot;created&quot;: &quot;2021-04-01T10:12:23.496-01:00&quot;,\r\n  &quot;children&quot;: [\r\n    {\r\n      &quot;uri&quot;: &quot;/Image1&quot;,\r\n      &quot;folder&quot;: true,\r\n      &quot;created&quot;: 2022-08-09T17.12.22.987.04.000\r\n    },\r\n    {\r\n      &quot;uri&quot;: &quot;/Image2&quot;,\r\n      &quot;folder&quot;: true,\r\n      &quot;created&quot;: 2022-06-10T10.12.22.412.10.000\r\n    },\r\n    {\r\n      &quot;uri&quot;: &quot;/Image3&quot;,\r\n      &quot;folder&quot;: true,\r\n      &quot;created&quot;: 2022-10-10T07.03.14.742.01.000\r\n    },\r\n    {\r\n      &quot;uri&quot;: &quot;/Image4&quot;,\r\n      &quot;folder&quot;: true,\r\n      &quot;created&quot;: 2022-10-10T07.010.11.542.08.000\r\n    }\r\n  ]\r\n}\r\n```\r\nLooking for some logic that will iterate through the uri under children and that is passed through curl command as $i which would be Image1, Image2 and Image3. \r\n\r\n    curl -k -s --user user:password -X GET &quot;https://artifactory.com/api/releases/baseimage/${i}&quot;\r\n\r\nWhile I was running this below command and the output is as follows\r\n\r\n```\r\nfor i in $(curl -k -s --user user:password -X GET      &quot;https://artifactory.com/api/releases/baseimage/&quot; | jq -c &quot;.children[] |.uri)\r\n```\r\nOutput: [&quot;/Image1&quot;, &quot;/Image2&quot;, &quot;/Image3&quot;]\r\n\r\nI tried the following command but in the output it replaces ${i} with only Image3, somehow it is not taking Image1 and Image2.  \r\n\r\n```\r\nfor i in $(curl -k -s --user user:password -X GET &quot;https://artifactory.com/api/releases/baseimage/&quot; | jq -r &quot;.children[] |.uri); do curl -k -s --user user:password -X GET &quot;https://artifactory.com/api/releases/baseimage/${i}&quot;; done\r\n```\r\n\r\nI tried the following command but in the output it replaces ${i} with only Image3, somehow it is not taking Image1 and Image2. ",
        "link": "https://stackoverflow.com/questions/74266931/iterate-through-the-json-object-and-run-curl-command-as-variable-from-json-outpu",
        "title": "Iterate through the json object and run curl command as variable from json output using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667319629,
                "last_edit_date": 1667319629,
                "creation_date": 1667248060,
                "answer_id": 74268796,
                "question_id": 74268555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over the top-level key-value pairs obtained by `to_entries` to get access to the key names, then once again over its content array in `.value` to get the array items. Also note that newlines as present in the sample&#39;s last `.Match` value cannot be used as is in a line-oriented format such as CSV. Here, I chose to replace them with the literal string `\\n` using `gsub`.\r\n~~~sh\r\njq -r &#39;\r\n  to_entries[] | . as {$key} | .value[] | [$key,\r\n    (.Setting | .SettingA, .SettingB),\r\n    .Rule // .Check, .Description, .Line, .Link,\r\n    .Message, .Severity, .Span[], .Match\r\n    | strings |= gsub(&quot;\\n&quot;; &quot;\\\\n&quot;)\r\n  ] | @csv\r\n&#39;\r\n~~~\r\n~~~csv\r\n&quot;dir/file1.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule15&quot;,&quot;&quot;,11,&quot;www.sample.com&quot;,&quot;Some message&quot;,&quot;error&quot;,1,3,&quot;[id&quot;\r\n&quot;dir/file1.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule16&quot;,&quot;&quot;,27,&quot;www.sample.com&quot;,&quot;Fix the rule&quot;,&quot;error&quot;,1,3,&quot;[id&quot;\r\n&quot;dir/file2.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule17&quot;,&quot;&quot;,51,&quot;www.example.com&quot;,&quot;Fix anoher &#39;rule&#39;?&quot;,&quot;error&quot;,1,18,&quot;[source,terminal]\\n----\\n&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/2ttxAPnOzKk)\r\n\r\n---\r\nIf you just want to dump all the values in the order they appear, you can simplify this by using `.. | scalars` to traverse the levels of the document:\r\n~~~sh\r\njq -r &#39;\r\n  to_entries[] | . as {$key} | .value[] | [$key,\r\n    (.. | scalars) | strings |= gsub(&quot;\\n&quot;; &quot;\\\\n&quot;)\r\n  ] | @csv\r\n&#39;\r\n~~~\r\n~~~csv\r\n&quot;dir/file1.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule15&quot;,&quot;&quot;,11,&quot;www.sample.com&quot;,&quot;Some message&quot;,&quot;error&quot;,1,3,&quot;[id&quot;\r\n&quot;dir/file1.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule16&quot;,&quot;&quot;,27,&quot;www.sample.com&quot;,&quot;Fix the rule&quot;,&quot;error&quot;,1,3,&quot;[id&quot;\r\n&quot;dir/file2.txt&quot;,&quot;&quot;,,&quot;Rulechecker.Rule17&quot;,&quot;&quot;,51,&quot;www.example.com&quot;,&quot;Fix anoher &#39;rule&#39;?&quot;,&quot;error&quot;,1,18,&quot;[source,terminal]\\n----\\n&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/09gCLewD8Gj)\r\n\r\n---\r\nAs for the column headings, for the first case I&#39;d add them manually, as you spell out each value path anyways. For the latter case it will be a little complicated as not all coulmns have immediate names (what should the items of array `Span` be called?), and some seem to change (in the second record, column `Rule` is called `Check`). You could, however, stick to the names of the first record, and taking the deepest field name either as is or add the array indices. Something along these lines would do:\r\n~~~sh\r\njq -r &#39;\r\n  to_entries[0].value[0] | [&quot;Filename&quot;, (\r\n    path(..|scalars) | .[.[[map(strings)|last]]|last:] | join(&quot;.&quot;)\r\n  )] | @csv\r\n&#39;\r\n~~~\r\n~~~csv\r\n&quot;Filename&quot;,&quot;SettingA&quot;,&quot;SettingB&quot;,&quot;Rule&quot;,&quot;Description&quot;,&quot;Line&quot;,&quot;Link&quot;,&quot;Message&quot;,&quot;Severity&quot;,&quot;Span.0&quot;,&quot;Span.1&quot;,&quot;Match&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/e9IHfaLRYBL)",
                "title": "How to transform nested JSON to csv using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1667319629,
        "creation_date": 1667246323,
        "question_id": 74268555,
        "body_markdown": "I have tried to transform json in the following format to csv using jq on Linux cmd line, but with no success. Any help of guidance would be appreciated. \r\n\r\n\r\n    {\r\n        &quot;dir/file1.txt&quot;: [\r\n          {\r\n            &quot;Setting&quot;: {\r\n              &quot;SettingA&quot;: &quot;&quot;,\r\n              &quot;SettingB&quot;: null\r\n            },\r\n            &quot;Rule&quot;: &quot;Rulechecker.Rule15&quot;,\r\n            &quot;Description&quot;: &quot;&quot;,\r\n            &quot;Line&quot;: 11,\r\n            &quot;Link&quot;: &quot;www.sample.com&quot;,\r\n            &quot;Message&quot;: &quot;Some message&quot;,\r\n            &quot;Severity&quot;: &quot;error&quot;,\r\n            &quot;Span&quot;: [\r\n              1,\r\n              3\r\n            ],\r\n            &quot;Match&quot;: &quot;[id&quot;\r\n          },\r\n          {\r\n            &quot;Setting&quot;: {\r\n              &quot;SettingA&quot;: &quot;&quot;,\r\n              &quot;SettingB&quot;: null\r\n            },\r\n            &quot;Check&quot;: &quot;Rulechecker.Rule16&quot;,\r\n            &quot;Description&quot;: &quot;&quot;,\r\n            &quot;Line&quot;: 27,\r\n            &quot;Link&quot;: &quot;www.sample.com&quot;,\r\n            &quot;Message&quot;: &quot;Fix the rule&quot;,\r\n            &quot;Severity&quot;: &quot;error&quot;,\r\n            &quot;Span&quot;: [\r\n              1,\r\n              3\r\n            ],\r\n            &quot;Match&quot;: &quot;[id&quot;\r\n          }\r\n        ],\r\n        &quot;dir/file2.txt&quot;: [\r\n          {\r\n            &quot;Setting&quot;: {\r\n              &quot;SettingA&quot;: &quot;&quot;,\r\n              &quot;SettingB&quot;: null\r\n            },\r\n            &quot;Rule&quot;: &quot;Rulechecker.Rule17&quot;,\r\n            &quot;Description&quot;: &quot;&quot;,\r\n            &quot;Line&quot;: 51,\r\n            &quot;Link&quot;: &quot;www.example.com&quot;,\r\n            &quot;Message&quot;: &quot;Fix anoher &#39;rule&#39;?&quot;,\r\n            &quot;Severity&quot;: &quot;error&quot;,\r\n            &quot;Span&quot;: [\r\n              1,\r\n              18\r\n            ],\r\n            &quot;Match&quot;: &quot;[source,terminal]\\n----\\n&quot;\r\n          }\r\n        ]\r\n    }\r\n\r\n\r\n\r\n\r\nUltimately, I want to present a matrix with **dir/file1.txt**, **dir/file2.txt** as rows on the left of the matrix, and all the keys to be presented as column headings, with the corresponding values.\r\n\r\n````\r\n| Filename  | SettingA | SettingB | Rule | More columns... |\r\n| -------- | -------------- | -------------- | -------------- | -------------- |\r\n| dir/file1.txt    |             | null | Rulechecker.Rule15 | |\r\n| dir/file1.txt   |             | null | Rulechecker.Rule16 | |\r\n| dir/file2.txt   |             | null | Rulechecker.Rule17  | |                       \r\n````\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74268555/how-to-transform-nested-json-to-csv-using-jq",
        "title": "How to transform nested JSON to csv using jq"
    },
    {
        "tags": [
            "jq",
            "amazon-iam"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1589223,
                    "reputation": 607,
                    "user_id": 1472936,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1610615254/picture?type=large",
                    "display_name": "Michael Quale",
                    "link": "https://stackoverflow.com/users/1472936/michael-quale"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667253719,
                "post_id": 74269324,
                "comment_id": 131122172,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667253994,
                "creation_date": 1667253994,
                "answer_id": 74269584,
                "question_id": 74269324,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It should be doable with `INDEX` and `JOIN` in a two-level nesting:\r\n~~~sh\r\njq --slurpfile users UserIds.json --slurpfile groups GroupsID.json &#39;\r\n  JOIN($groups | INDEX(.ID);\r\n    JOIN($users | INDEX(.ID); .; .Member; add);\r\n  .GroupID; add) | {Name, GroupName}\r\n&#39; GroupsMembers.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;Name&quot;: &quot;first.last@example.com&quot;,\r\n  &quot;GroupName&quot;: &quot;sso-aws-zone-role-CloudCoreOps&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;last.first@example.com&quot;,\r\n  &quot;GroupName&quot;: &quot;sso-aws-zone-role-CloudCoreRO&quot;\r\n}\r\n~~~",
                "title": "How to extrapolate values in one AWS CLI output with values from two separate CLI outputs as input files?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667254040,
        "creation_date": 1667252053,
        "last_edit_date": 1667254040,
        "question_id": 74269324,
        "body_markdown": "I am trying to build an audit/compliance report from IAM identity center. We need a list of groups and the respective group members. At current count we have 1,500+ users and 700+ Groups across 120 accounts in AWS.\r\n\r\nThere isn&#39;t an API command to spit this data out, so I&#39;m putting a few commands together to extract the groups to files in Cloudshell. Then I need to cross-reference and throw everything into a CSV for filtering in Excel for the auditors.\r\n\r\n- Retrieve UserName and UserID - store in `UserID.json`\r\n\r\n    ```\r\n    aws identitystore list-users --identity-store-id d-123456789| jq &#39;.Users[] | {Name: .UserName, ID:.UserId}&#39; &gt; UsersIds.json\r\n    ```\r\n\r\n\r\n- Retrieve Groups and GroupIDs - store in `GroupsID.json`\r\n\r\n    ```\r\n    aws identitystore list-groups --identity-store-id d-123456789| jq &#39;.Groups[] | {GroupName: .DisplayName, ID:.GroupId}&#39; &gt; GroupsID.json\r\n    ```\r\n\r\n- Retrieve list of All Users per Group - store in `GroupMembers.json`\r\n\r\n    ```\r\n    result=$(aws identitystore list-groups --identity-store-id d-123456789| jq -r &#39;.Groups[].GroupId&#39;)\r\n    \r\n    for val in $result; do\r\n        aws identitystore list-group-memberships --identity-store-id d-123456789--group-id $val | jq -r &#39;.GroupMemberships[] | \\\r\n        {GroupID: .GroupId, Member:User.Id} &#39; &gt;&gt; GroupMembers.json\r\n    done\r\n    ```\r\n\r\nExample output from `UserIds.json`:\r\n\r\n```json\r\n{\r\n  &quot;Name&quot;: &quot;first.last@example.com&quot;,\r\n  &quot;ID&quot;: &quot;123456789-9876543210-ABCD-4321-1234&quot;\r\n}\r\n{\r\n  &quot;Name&quot;: &quot;last.first@example.com&quot;,\r\n  &quot;ID&quot;: &quot;12345678-4321-1234-2233-9876543210&quot;\r\n}\r\n```\r\n\r\nExample output from `GroupsID.json`:\r\n\r\n\r\n```json\r\n{\r\n  &quot;GroupName&quot;: &quot;sso-aws-zone-role-CloudCoreOps&quot;,\r\n  &quot;ID&quot;: &quot;123456789-55668877-1234-5522-2255-987654321&quot;\r\n}\r\n{\r\n  &quot;GroupName&quot;: &quot;sso-aws-zone-role-CloudCoreRO&quot;,\r\n  &quot;ID&quot;: &quot;1234567890-11224455-2255-5522-1343-9876543210&quot;\r\n}\r\n```\r\n\r\nExample Output from `GroupsMembers.json`:\r\n\r\n```json\r\n{\r\n  &quot;GroupID&quot;: &quot;123456789-55668877-1234-5522-2255-987654321&quot;,\r\n  &quot;Member&quot;: &quot;123456789-9876543210-ABCD-4321-1234&quot;\r\n}\r\n{\r\n  &quot;GroupID&quot;: &quot;1234567890-11224455-2255-5522-1343-9876543210&quot;,\r\n  &quot;Member&quot;: &quot;12345678-4321-1234-2233-9876543210&quot;\r\n}\r\n```\r\n\r\nNow I just need to correlate and I have read you can use JQ like SED. So, that means I should be able to replace the key values in `GroupMembers.json`. First is to replace the GroupID with the correct GroupName matched from the `GroupsID.json` file and the Member with the User Name that matches the ID from the `UserID.json` file.\r\n\r\nI think this can be done in a loop, but I want need to learn not only how to do this, but the best way. ",
        "link": "https://stackoverflow.com/questions/74269324/how-to-extrapolate-values-in-one-aws-cli-output-with-values-from-two-separate-cl",
        "title": "How to extrapolate values in one AWS CLI output with values from two separate CLI outputs as input files?"
    },
    {
        "tags": [
            "regex",
            "bash",
            "sed",
            "grep",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667263801,
                "post_id": 74270304,
                "comment_id": 131123898,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26790053,
                    "reputation": 1,
                    "user_id": 20383615,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/171bffe7f5422d3b67b3b105da53aabc?s=256&d=identicon&r=PG",
                    "display_name": "schmilk",
                    "link": "https://stackoverflow.com/users/20383615/schmilk"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667264962,
                "post_id": 74270304,
                "comment_id": 131124060,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667265113,
                "post_id": 74270304,
                "comment_id": 131124075,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667272099,
                "last_edit_date": 1667272099,
                "creation_date": 1667271705,
                "answer_id": 74271080,
                "question_id": 74270304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not clear what you mean exactly by &quot;exporting the dummy value and original value&quot;, but the following should be sufficient for you to figure out that detail, since the result contains the information necessary to create the table:\r\n```\r\n  def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .;\r\n\r\n  . as $in\r\n  | ([length|tostring|length, 5]|max) as $width\r\n  | [range(0; length) as $i\r\n     | $in[$i] \r\n     | . + {computer_name: (&quot;Dummy&quot; + ($i | lpad($width;&quot;0&quot;))), \r\n            original_name: .computer_name}]\r\n```\r\n\r\nYou could use this to create your table, and then remove `original_name` \r\ne.g., by running:\r\n\r\n    map(del(.original_name))\r\n\r\nOf course there are other ways to achieve your stated goal, but if leaving the original names in the file is an option, then that might be worth considering, since it might obviate the need to maintain a separate table.",
                "title": "How can I replace every matching JSON field&#39;s value with incremental value?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667299068,
                "creation_date": 1667299068,
                "answer_id": 74274618,
                "question_id": 74270304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would first generate a master table containing both the clear and the obfuscated names,\r\nthen extract from it as needed either the protected version by removing the clear names,\r\nor a table with the matchings. You can even perform direct lookups on it:\r\n\r\n~~~sh\r\njq &#39;with_entries(.key |= &quot;Dummy\\(&quot;\\(.)&quot; | &quot;0&quot;*(5-length) + .)&quot; | .value += {\r\n  clear_name: .value.computer_name,\r\n  computer_name: .key\r\n})&#39; file.json &gt; master.json\r\n~~~\r\n\r\n~~~sh\r\ncat master.json\r\n{\r\n  &quot;Dummy00000&quot;: {\r\n    &quot;id&quot;: 1,\r\n    &quot;uptime&quot;: 0,\r\n    &quot;computer_name&quot;: &quot;Dummy00000&quot;,\r\n    &quot;clear_name&quot;: &quot;Computer01&quot;\r\n  },\r\n  &quot;Dummy00001&quot;: {\r\n    &quot;id&quot;: 2,\r\n    &quot;uptime&quot;: 0,\r\n    &quot;computer_name&quot;: &quot;Dummy00001&quot;,\r\n    &quot;clear_name&quot;: &quot;Computer02&quot;\r\n  }\r\n}\r\n~~~\r\n\r\n~~~sh\r\njq &#39;map(del(.clear_name))&#39; master.json\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;uptime&quot;: 0,\r\n    &quot;computer_name&quot;: &quot;Dummy00000&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;uptime&quot;: 0,\r\n    &quot;computer_name&quot;: &quot;Dummy00001&quot;\r\n  }\r\n]\r\n~~~\r\n\r\n~~~sh\r\njq -r &#39;.[] | [.clear_name, .computer_name] | @tsv&#39; master.json\r\nComputer01  Dummy00000\r\nComputer02  Dummy00001\r\n~~~\r\n\r\n~~~sh\r\njq --arg lookup &quot;Dummy00001&quot; &#39;.[$lookup]&#39; master.json\r\n{\r\n  &quot;id&quot;: 2,\r\n  &quot;uptime&quot;: 0,\r\n  &quot;computer_name&quot;: &quot;Dummy00001&quot;,\r\n  &quot;clear_name&quot;: &quot;Computer02&quot;\r\n}\r\n~~~\r\n\r\n~~~sh\r\njq -r --arg lookup &quot;Dummy00001&quot; &#39;.[$lookup].clear_name&#39; master.json\r\nComputer02\r\n~~~",
                "title": "How can I replace every matching JSON field&#39;s value with incremental value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667299068,
        "creation_date": 1667262253,
        "question_id": 74270304,
        "body_markdown": "So I have a large json file (approximately 20k hosts) and for each host, I need to find FieldA and replace it&#39;s value with a unique value which I can then swap back later.\r\n\r\nFor instance:\r\n\r\n`root&gt; cat file.json | jq .\r\n`\r\n```\r\n\r\n[\r\n   {\r\n   &quot;id&quot;: 1,\r\n   &quot;uptime&quot;: 0\r\n   &quot;computer_name&quot;: &quot;Computer01&quot;\r\n   },\r\n   {\r\n   &quot;id&quot;: 2,\r\n   &quot;uptime&quot;: 0\r\n   &quot;computer_name&quot;: &quot;Computer02&quot;\r\n   }\r\n]\r\n\r\n```\r\n\r\nI need to iterate through this list of 20k hosts, replace every computer_name with a dummy value:\r\n\r\n```\r\n[\r\n   {\r\n   &quot;id&quot;: 1,\r\n   &quot;uptime&quot;: 0\r\n   &quot;computer_name&quot;: &quot;Dummy01&quot;\r\n   },\r\n   {\r\n   &quot;id&quot;: 2,\r\n   &quot;uptime&quot;: 0\r\n   &quot;computer_name&quot;: &quot;Dummy02&quot;\r\n   }\r\n]\r\n```\r\n\r\nAnd if possible, export the dummy value and original value to a table side by side linking them up. \r\n\r\nThe dummy values I want to generate automatically such as:\r\nfor each computer_name replace value with Dummy?????? where ????? is a number from 00000 to 99999 and it just iterates through this.\r\n\r\nI attempted to use: `cat file.json | jq .computer_name` OR `jq.computer_name file.json` to filter this down and then work on replacing the values, but when I use .computer_name as the value, I get this error:\r\n\r\njq: error : Cannot index array with string &quot;computer_name&quot;.\r\n\r\nThanks in advance.",
        "link": "https://stackoverflow.com/questions/74270304/how-can-i-replace-every-matching-json-fields-value-with-incremental-value",
        "title": "How can I replace every matching JSON field&#39;s value with incremental value?"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq",
            "etl"
        ],
        "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": 3,
                "creation_date": 1667280242,
                "post_id": 74271654,
                "comment_id": 131126015,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1667283120,
                "post_id": 74271654,
                "comment_id": 131126463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667297108,
                "post_id": 74271654,
                "comment_id": 131129769,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4610729,
                    "reputation": 986,
                    "user_id": 3738936,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/243e6594a90e494d104cc567efe1c866?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Don M",
                    "link": "https://stackoverflow.com/users/3738936/don-m"
                },
                "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": 1667335877,
                "post_id": 74271654,
                "comment_id": 131142606,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4610729,
                    "reputation": 986,
                    "user_id": 3738936,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/243e6594a90e494d104cc567efe1c866?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Don M",
                    "link": "https://stackoverflow.com/users/3738936/don-m"
                },
                "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": 1667335896,
                "post_id": 74271654,
                "comment_id": 131142613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667339537,
                "creation_date": 1667339537,
                "answer_id": 74282202,
                "question_id": 74271654,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Could something like this be what you are looking for?\r\n~~~sh\r\n.cards | map(\r\n  select(.closed == false) | {trello_id: .id, desc, name} + ([\r\n    .checklists[] | select(.name == &quot;Acct Information&quot;)\r\n    | .checkItems[].name | select(contains(&quot;Location&quot;))\r\n    | capture(&quot;(?&lt;key&gt;[^:]*):\\\\s*(?&lt;value&gt;.*)&quot;)\r\n    | .key |= (gsub(&quot;\\\\s+&quot;; &quot;_&quot;) | ascii_downcase)\r\n    | .value |= gsub(&quot;\\\\*&quot;; &quot;&quot;)\r\n  ] | from_entries)\r\n)\r\n~~~\r\n~~~json\r\n[\r\n  {\r\n    &quot;trello_id&quot;: &quot;1234&quot;,\r\n    &quot;desc&quot;: &quot;*Important Notes* &quot;,\r\n    &quot;name&quot;: &quot;Housing - Lawrence&quot;,\r\n    &quot;location_address&quot;: &quot;123 Hopscotch Way&quot;\r\n  }\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/o4JkIhWNdGz)\r\n",
                "title": "Append JSON from deep nested value to top level with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667339537,
        "creation_date": 1667278140,
        "last_edit_date": 1667335812,
        "question_id": 74271654,
        "body_markdown": "Here is some sample data:\r\n  https://gist.github.com/dmc2015/19fc41aa677ba02a3bc49c53057ce408\r\n\r\nEvery script I have below should work, but I don&#39;t know how to combine them.\r\nI need to do the following:\r\n- change a key name\r\n- be able to select specific keys to return, I don&#39;t need them all\r\n- be able to select and parse values\r\n- turn parsed values in to key value pairs and add them back in to the json\r\n\r\n## Change a key name\r\n\r\n```\r\njq &#39;.cards[] | select(.closed == false) | with_entries(if .key == &quot;id&quot; then .key = &quot;trello_id&quot; else . end) | .&#39; data.json\r\n```\r\n\r\nreturns:\r\n```\r\n{\r\n  &quot;trello_id&quot;: &quot;1234&quot;,\r\n  ...\r\n  ..\r\n}\r\n\r\n```\r\n\r\n## Select specific keys to return\r\n```\r\njq &#39;.cards[] | with_entries(select([.key] | inside([&quot;name&quot;, &quot;description&quot;]) ) ) | .&#39; data.json\r\n```\r\n\r\nreturns:\r\n```\r\n{\r\n  &quot;desc&quot;: &quot;*Important Notes* &quot;,\r\n  &quot;name&quot;: &quot;Housing - Lawrence&quot;\r\n}\r\n```\r\n\r\n## Query &amp; Parse Values to create my own keys\r\n\r\n```\r\njq &#39;.cards[] |\r\n.checklists[] | select(.name == &quot;Acct Information&quot;) |\r\n  .checkItems[] | select(.name | contains (&quot;Location&quot;)) |\r\n  .name | .&#39;  data.json |\r\n    cut -d &quot;:&quot; -f 1 |  sed &#39;s/&quot;//g&#39; |  sed -e &#39;s/\\(.*\\)/\\L\\1/&#39; | sed -r &#39;s/\\s+/_/g&#39;\r\n\r\n```\r\nreturns: `location_address`\r\n\r\n```\r\njq &#39;.cards[] | .checklists[] | select(.name == &quot;Acct Information&quot;) |\r\n.checkItems[] | select(.name | contains (&quot;Location&quot;)) |\r\n  .name | .&#39;  data.json |\r\n  cut -d &quot;:&quot; -f 2 |\r\n    sed -e &#39;s/\\&quot;//g&#39; -e &#39;s/*//g&#39;\r\n```\r\n\r\nreturns `&quot;123 Hopscotch Way&quot;`\r\n\r\nI can do most parts individually but I am struggling to see a way to do it all in one query.\r\nThis is something close to the end result that I want.\r\n```\r\n\r\n    [\r\n      {\r\n        &quot;trello_id&quot;: &quot;1234&quot;,\r\n        &quot;desc&quot;: &quot;*Important Notes* &quot;,\r\n        &quot;name&quot;: &quot;Housing - Lawrence&quot;\r\n        &quot;location_address&quot;: &quot;123 Hopscotch Way&quot;\r\n      }\r\n    ]\r\n\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74271654/append-json-from-deep-nested-value-to-top-level-with-jq",
        "title": "Append JSON from deep nested value to top level with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1667362970,
                "creation_date": 1667362970,
                "answer_id": 74284331,
                "question_id": 74284275,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "All you need is `+=` to add up arrays while retaining the context, and `input` to access the second file:\r\n~~~sh\r\njq &#39;.evidences += input&#39; file1.json file2.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;version&quot;: &quot;2&quot;,\r\n  &quot;run_id&quot;: &quot;1&quot;,\r\n  &quot;crn&quot;: &quot;crn&quot;,\r\n  &quot;date&quot;: &quot;2022-11-02T02:09:30.629Z&quot;,\r\n  &quot;evidences&quot;: [\r\n    {\r\n      &quot;version&quot;: &quot;2&quot;,\r\n      &quot;id&quot;: &quot;2d&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;2&quot;,\r\n      &quot;id&quot;: &quot;3e&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;3&quot;,\r\n      &quot;id&quot;: &quot;3d&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;2&quot;,\r\n      &quot;id&quot;: &quot;3f&quot;\r\n    }\r\n  ]\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/bGPUwiQJFyw)",
                "title": "jq to merge two files with different formats"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667362970,
        "creation_date": 1667362378,
        "last_edit_date": 1667362816,
        "question_id": 74284275,
        "body_markdown": "I have two files \r\n\r\n`file 1`\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;2&quot;,\r\n    &quot;run_id&quot;: &quot;1&quot;,\r\n    &quot;crn&quot;: &quot;crn&quot;,\r\n    &quot;date&quot;: &quot;2022-11-02T02:09:30.629Z&quot;,\r\n    &quot;evidences&quot;: [\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;2d&quot;\r\n        },\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;3e&quot;\r\n        }  \r\n]\r\n\r\n```\r\n`file 2`\r\n\r\n```\r\n[\r\n        {\r\n            &quot;version&quot;: &quot;3&quot;,\r\n            &quot;id&quot;: &quot;3d&quot;\r\n        },\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;3f&quot;\r\n        }    \r\n]\r\n```\r\ncan we use `jq` to merge contents from `file 2` into `evidences` section of `file 1`? which the result should like below\r\n\r\n`file 1`\r\n\r\n```\r\n{\r\n    &quot;version&quot;: &quot;2&quot;,\r\n    &quot;run_id&quot;: &quot;1&quot;,\r\n    &quot;crn&quot;: &quot;crn&quot;,\r\n    &quot;date&quot;: &quot;2022-11-02T02:09:30.629Z&quot;,\r\n    &quot;evidences&quot;: [\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;2d&quot;\r\n        },\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;3e&quot;\r\n        },\r\n        {\r\n            &quot;version&quot;: &quot;3&quot;,\r\n            &quot;id&quot;: &quot;3d&quot;\r\n        },\r\n        {\r\n            &quot;version&quot;: &quot;2&quot;,\r\n            &quot;id&quot;: &quot;3f&quot;\r\n        }    \r\n]\r\n\r\n``` ",
        "link": "https://stackoverflow.com/questions/74284275/jq-to-merge-two-files-with-different-formats",
        "title": "jq to merge two files with different formats"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1667398791,
                "post_id": 74290395,
                "comment_id": 131157877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17405550,
                    "reputation": 335,
                    "user_id": 18148705,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/11d12c7a595758f0724aae86bddb2f82?s=256&d=identicon&r=PG",
                    "display_name": "user18148705",
                    "link": "https://stackoverflow.com/users/18148705/user18148705"
                },
                "reply_to_user": {
                    "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": 1,
                "creation_date": 1667399045,
                "post_id": 74290395,
                "comment_id": 131157997,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9902617,
                    "reputation": 4727,
                    "user_id": 7332147,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e4GFL.png?s=256",
                    "display_name": "linuxfan says Reinstate Monica",
                    "link": "https://stackoverflow.com/users/7332147/linuxfan-says-reinstate-monica"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667401556,
                "post_id": 74290395,
                "comment_id": 131159086,
                "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": 1667420510,
                "post_id": 74290395,
                "comment_id": 131165913,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17405550,
                    "reputation": 335,
                    "user_id": 18148705,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/11d12c7a595758f0724aae86bddb2f82?s=256&d=identicon&r=PG",
                    "display_name": "user18148705",
                    "link": "https://stackoverflow.com/users/18148705/user18148705"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667464595,
                "post_id": 74290395,
                "comment_id": 131174113,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667399034,
                "creation_date": 1667399034,
                "answer_id": 74290780,
                "question_id": 74290395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is your json structure immutable? If you have to use it, consider the following\r\n```bash\r\n┌──[root@vms83.liruilongs.github.io]-[~]\r\n└─$cat abc.json  | awk -F: &#39;{print $NF}&#39; | grep -o &#39;[[:digit:]]&#39;\r\n5\r\n```",
                "title": "Fetch json data using Regex on linux"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667399562,
                "creation_date": 1667399562,
                "answer_id": 74290920,
                "question_id": 74290395,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think your problem was you had a space between `data` and `=`. There can&#39;t be a space there.\r\n\r\nThis works as you want it to (I removed the unnecessary `cat`)\r\n\r\n    data1=$(jq -r &#39;.value4.value41.value411&#39; abc.json)\r\n    echo $data1",
                "title": "Fetch json data using Regex on linux"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667452016,
        "creation_date": 1667397470,
        "last_edit_date": 1667452016,
        "question_id": 74290395,
        "body_markdown": "I know we should use JQ for parsing json data, but I want to parse it using regex. I want to fetch the value of a json key into a variable in my shell script. As of now, I am using  JQ for parsing.\r\n\r\nSo my abc.json is \r\n\r\n    {&quot;value1&quot;:5.0,&quot;value2&quot;:2.5,&quot;value3&quot;:&quot;2019-10-24T15:26:00.000Z&quot;,&quot;modifier&quot;:[],&quot;value4&quot;:{&quot;value41&quot;:{&quot;value411&quot;:5}}}\r\n\r\n\r\nCurrently, my XYZ.sh has these lines to fetch the data\r\n\r\ndata1 =$(cat abc.json | jq -r &#39;.value4.value41.value411&#39;)\r\n\r\nI want data1 to have value of value411. How can I achieve this?\r\n\r\nps- The JSON is mutable. The above JSON is just a part of the JSON file that I want to fetch.",
        "link": "https://stackoverflow.com/questions/74290395/fetch-json-data-using-regex-on-linux",
        "title": "Fetch json data using Regex on linux"
    },
    {
        "tags": [
            "json",
            "csv",
            "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": 1667406900,
                "post_id": 74292573,
                "comment_id": 131161206,
                "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": 0,
                "creation_date": 1667406972,
                "post_id": 74292573,
                "comment_id": 131161240,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667441896,
                "last_edit_date": 1667441896,
                "creation_date": 1667407404,
                "answer_id": 74292795,
                "question_id": 74292573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the keys are consistently ordered within the objects:\r\n\r\n```sh\r\njq -r &#39;((first | keys_unsorted), (.[] | to_entries | map(.value))) | @csv&#39; file.json\r\n```\r\n```none\r\n&quot;endpoint&quot;,&quot;date&quot;,&quot;upUsage&quot;,&quot;downUsage&quot;,&quot;upAvgRate&quot;,&quot;downAvgRate&quot;,&quot;upMaxRate&quot;,&quot;downMaxRate&quot;\r\n&quot;APPLE&quot;,&quot;2022-11-02 12:00&quot;,0,18000,0,600,0,800\r\n&quot;BANANA&quot;,&quot;2022-11-02 12:00&quot;,0,17600,0,587,0,693\r\n&quot;CARROT&quot;,&quot;2022-11-02 12:00&quot;,0,8000,0,533,0,533\r\n```",
                "title": "Convert Array of JSON Objects to CSV With Headers"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667441896,
        "creation_date": 1667406347,
        "question_id": 74292573,
        "body_markdown": "I have a JSON payload that I&#39;m looking to convert to CSV that looks like the below:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;endpoint&quot;: &quot;APPLE&quot;,\r\n    &quot;date&quot;: &quot;2022-11-02 12:00&quot;,\r\n    &quot;upUsage&quot;: 0,\r\n    &quot;downUsage&quot;: 18000,\r\n    &quot;upAvgRate&quot;: 0,\r\n    &quot;downAvgRate&quot;: 600,\r\n    &quot;upMaxRate&quot;: 0,\r\n    &quot;downMaxRate&quot;: 800\r\n  },\r\n  {\r\n    &quot;endpoint&quot;: &quot;BANANA&quot;,\r\n    &quot;date&quot;: &quot;2022-11-02 12:00&quot;,\r\n    &quot;upUsage&quot;: 0,\r\n    &quot;downUsage&quot;: 17600,\r\n    &quot;upAvgRate&quot;: 0,\r\n    &quot;downAvgRate&quot;: 587,\r\n    &quot;upMaxRate&quot;: 0,\r\n    &quot;downMaxRate&quot;: 693\r\n  },\r\n  {\r\n    &quot;endpoint&quot;: &quot;CARROT&quot;,\r\n    &quot;date&quot;: &quot;2022-11-02 12:00&quot;,\r\n    &quot;upUsage&quot;: 0,\r\n    &quot;downUsage&quot;: 8000,\r\n    &quot;upAvgRate&quot;: 0,\r\n    &quot;downAvgRate&quot;: 533,\r\n    &quot;upMaxRate&quot;: 0,\r\n    &quot;downMaxRate&quot;: 533\r\n  }\r\n]\r\n```\r\n\r\nI am trying to convert this to a standard CSV file with the appropriate headers via jq, but having difficulties in doing so. Below is my desired output:\r\n\r\n```\r\n&quot;endpoint&quot;,&quot;date&quot;,&quot;upUsage&quot;,&quot;downUsage&quot;,&quot;upAvgRate&quot;,&quot;downAvgRate&quot;,&quot;upMaxRate&quot;,&quot;downMaxRate&quot;\r\n&quot;APPLE&quot;,&quot;2022-11-02 12:00&quot;,0,18000,0,600,0,800\r\n&quot;BANANA&quot;,&quot;2022-11-02 12:00&quot;,0,17600,0,587,0,693\r\n&quot;CARROT&quot;,&quot;2022-11-02 12:00&quot;,0,8000,0,533,0,533\r\n```\r\n\r\nI&#39;ve been able to use the below jq to get close to this output, but my headers are not being included:\r\n\r\n```\r\ncat testJson.json | jq -r &#39;.[] | join(&quot;,&quot;)&#39;\r\n```\r\n\r\n***Note:** - There are also instances in which one of my JSON objects may not include the same number of values, so I need my output file to account for this and simply enter a null value between the commas to keep a consistent number of columns",
        "link": "https://stackoverflow.com/questions/74292573/convert-array-of-json-objects-to-csv-with-headers",
        "title": "Convert Array of JSON Objects to CSV With Headers"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667458727,
                "creation_date": 1667458727,
                "answer_id": 74299079,
                "question_id": 74298936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.parent |=\r\n  reduce paths(strings) as $p (.;\r\n    setpath($p; &quot;$&quot; + ($p | join(&quot;_&quot;)))\r\n  )\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/U6aUeg3oLqb)&lt;/sup&gt;",
                "title": "Recursively replace value with $path in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1668692138,
        "creation_date": 1667457589,
        "last_edit_date": 1668692138,
        "question_id": 74298936,
        "body_markdown": "Assuming that  i have a complex JsonObject \r\n\r\n```json\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;name&quot;: &quot;value&quot;,\r\n    &quot;child&quot;: {\r\n      &quot;child_value1&quot;: &quot;value&quot;,\r\n      &quot;child_value2&quot;: &quot;value&quot;,\r\n      &quot;child_value3&quot;: [&quot;value1&quot;,&quot;value2&quot;],\r\n      &quot;child_value4&quot;: {\r\n         &quot;child_child_value1&quot;:&quot;value&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI want to replace the value of each key, with the name of key prefixed with $\r\n\r\n```json\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;name&quot;: &quot;$name&quot;,\r\n    &quot;child&quot;: {\r\n      &quot;child_value1&quot;: &quot;$child_child_value1&quot;,\r\n      &quot;child_value2&quot;: &quot;$child_child_value2&quot;,\r\n      &quot;child_value3&quot;: [&quot;$child_child_value3_0&quot;,&quot;$child_child_value3_1&quot;],\r\n      &quot;child_value4&quot;: {\r\n         &quot;child_child_value1&quot;:&quot;$child_child_value4_child_child_value1&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\nIs there a way to do it recursively? \r\n\r\n\r\n\r\n**EDIT**\r\n\r\nThis is the currently configuration file that I am using\r\n```json\r\n{\r\n  &quot;apis&quot;: {\r\n    &quot;order&quot;: {\r\n      &quot;base_url&quot;: &quot;$mapping_base_url&quot;\r\n    },\r\n    &quot;payment&quot;: {\r\n      &quot;base_url&quot;: &quot;$admin_base_url&quot;\r\n    }\r\n  },\r\n  &quot;features&quot;: {\r\n    &quot;authentication&quot;: {\r\n      &quot;authProviders&quot;: true,\r\n      &quot;registration&quot;: false\r\n    }\r\n  },\r\n  &quot;availableLocales&quot;:[&quot;en&quot;,&quot;es&quot;]\r\n}\r\n```\r\nThis is the result using the recomended jq expression:\r\n\r\n`. |= reduce paths(strings) as $p (.; setpath($p; &quot;$&quot; + ($p | join(&quot;_&quot;))))`\r\n\r\n```json\r\n{\r\n  &quot;apis&quot;: {\r\n    &quot;order&quot;: {\r\n      &quot;base_url&quot;: &quot;$apis_order_base_url&quot;\r\n    },\r\n    &quot;payment&quot;: {\r\n      &quot;base_url&quot;: &quot;$apis_payment_base_url&quot;\r\n    }\r\n  },\r\n  &quot;features&quot;: {\r\n    &quot;authentication&quot;: {\r\n      &quot;authProviders&quot;: true,\r\n      &quot;registration&quot;: false\r\n    }\r\n  },\r\n  &quot;availableLocales&quot;: [\r\n    &quot;$availableLocales_0&quot;,\r\n    &quot;$availableLocales_1&quot;\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74298936/recursively-replace-value-with-path-in-jq",
        "title": "Recursively replace value with $path in JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1667473978,
                "last_edit_date": 1667473978,
                "creation_date": 1667471703,
                "answer_id": 74301632,
                "question_id": 74301375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This adds (or replaces) a `.summary` field which is calculated by `reduce`ing the `.tests` array to an object, initialized as `{success: 0, failed: 0}`. For each array item, either `.success` or `.failed` is incremented, depending on the current array item&#39;s boolean `.state` field. The `.rating` field is incremented unconditionally, thus counting the total number of items which is later used to calculate the true rating. As for the duration, the array item&#39;s `.duration` field is converted into a number by chopping off the `ms` suffix, and added to the summary&#39;s (numeric) `.duration` field. After the reduction, the rating is corrected by dividing the the success count by it (and multiplied by `100` for convenience). The `? // 0` part catches division by zero issues, in case the `.tests` array was empty. Finally, the `.duration` field is re-equipped with the `ms` suffix.\r\n\r\n~~~sh\r\n.summary = (reduce .tests[] as $t ({success: 0, failed: 0};\r\n  (if $t.status then .success else .failed end, .rating) += 1\r\n  | .duration += ($t.duration | rtrimstr(&quot;ms&quot;) | tonumber)\r\n) | .rating = (100 * (.success / .rating)? // 0) | .duration |= &quot;\\(.//0)ms&quot;)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;testname&quot;: &quot;Behave test&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;some text&quot;,\r\n      &quot;status&quot;: true,\r\n      &quot;duration&quot;: &quot;7ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;some text&quot;,\r\n      &quot;status&quot;: false,\r\n      &quot;duration&quot;: &quot;27ms&quot;\r\n    }\r\n  ],\r\n  &quot;summary&quot;: {\r\n    &quot;success&quot;: 1,\r\n    &quot;failed&quot;: 1,\r\n    &quot;rating&quot;: 50,\r\n    &quot;duration&quot;: &quot;34ms&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/21KEcfHVwOG)\r\n",
                "title": "Calculate values from json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667473978,
        "creation_date": 1667470687,
        "last_edit_date": 1667473078,
        "question_id": 74301375,
        "body_markdown": "I have a script\r\n\r\n\r\n```\r\n#!/bin/bash\r\n\r\n#create path to redirect output.json to same directory as output.txt\r\npath=$(dirname $1)\r\n\r\n#create variables for name line, test lines and result line\r\nfirstline=$(cat $1 | head -n +1 | cut -d &quot;[&quot; -f2 | cut -d &quot;]&quot; -f1)\r\ntestname=$(echo $firstline)\r\n\r\ntests=$(cat $1 | tail -n +3 | head -n -2)\r\n\r\nresults=$(cat $1 | tail -n1)\r\n\r\n#create main JSON variable\r\njson=$(jq -n --arg tn &quot;$testname&quot; &#39;{testname:$tn,tests:[],summary:{}}&#39;)\r\n\r\n#test&#39;s names, status, duration and updating JSON variable\r\nIFS=$&#39;\\n&#39;\r\nfor i in $tests\r\ndo\r\n    if [[ $i == not* ]]\r\n    then\r\n\t    stat=false\r\n    else\r\n\t    stat=true\r\n    fi\r\n\r\n    if [[ $i =~ expecting(.+?)[0-9] ]]\r\n    then\r\n\t    var=${BASH_REMATCH[0]}\r\n\t    name=${var%,*}\r\n    fi\r\n\r\n    if [[ $i =~ [0-9]*ms ]]\r\n    then\r\n\t    test_duration=${BASH_REMATCH[0]}\r\n    fi\r\n\r\n    json=$(echo $json | jq \\\r\n\t    --arg na &quot;$name&quot; \\\r\n\t    --arg st &quot;$stat&quot; \\\r\n\t    --arg dur &quot;$test_duration&quot; \\\r\n\t    &#39;.tests += [{name:$na,status:$st|test(&quot;true&quot;),duration:$dur}]&#39;)\r\ndone\r\n\r\n#final success, failed, rating, duration and finishing JSON variable\r\n\r\nIFS=$&#39;\\n&#39;\r\nfor l in $results\r\ndo\r\n    if [[ $l =~ [0-9]+ ]]\r\n    then\r\n\t    success=${BASH_REMATCH[0]}\r\n    fi\r\n\r\n    if [[ $l =~ ,.[0-9]+ ]]\r\n    then\r\n\t    v=${BASH_REMATCH[0]}\r\n\t    failed=${v:2}\r\n    fi\r\n\r\n    if [[ $l =~ [0-9]+.[0-9]+% ]] || [[ $l =~ [0-9]+% ]]\r\n    then\r\n\t    va=${BASH_REMATCH[0]}\r\n\t    rating=${va%%%}\r\n    fi\r\n\r\n    if [[ $l =~ [0-9]*ms ]]\r\n    then\r\n\t    duration=${BASH_REMATCH[0]}\r\n    fi\r\n\r\n    json=$(echo $json | jq \\\r\n                --arg suc &quot;$success&quot; \\\r\n                --arg fa &quot;$failed&quot; \\\r\n                --arg rat &quot;$rating&quot; \\\r\n\t        --arg dur &quot;$duration&quot; \\\r\n\t        &#39;.summary += {success:$suc|tonumber,failed:$fa|tonumber,rating:$rat|tonumber,duration:$dur}&#39;)\r\ndone\r\n\r\n#redirect variable&#39;s output to file\r\necho $json | jq &quot;.&quot; &gt; $path&quot;/output.json&quot;\r\n```\r\n\r\nOutput.json looks like:\r\n\r\n\r\n```json\r\n{\r\n  &quot;testname&quot;: &quot;Behave test&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;some text&quot;,\r\n      &quot;status&quot;: true,\r\n      &quot;duration&quot;: &quot;7ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;some text&quot;,\r\n      &quot;status&quot;: false,\r\n      &quot;duration&quot;: &quot;27ms&quot;\r\n    }\r\n  ],\r\n  &quot;summary&quot;: {\r\n    &quot;success&quot;: 1,\r\n    &quot;failed&quot;: 1,\r\n    &quot;rating&quot;: 50,\r\n    &quot;duration&quot;: &quot;34ms&quot;\r\n  }\r\n}\r\n```\r\n\r\nOutput is much more than in my example above. My question is, how I can calculate **&quot;summary&quot;** values and put it to json? \r\n\r\n - &quot;success&quot; - tests with status true; \r\n - &quot;failed&quot; - tests with status false; \r\n - &quot;rating&quot; - success / total, and it can be float or int\r\n - &quot;duration&quot; - sum of &quot;duration&quot; field\r\n\r\nI will be very grateful for help.\r\n",
        "link": "https://stackoverflow.com/questions/74301375/calculate-values-from-json-file",
        "title": "Calculate values from json file"
    },
    {
        "tags": [
            "bash",
            "curl",
            "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": 1667475518,
                "post_id": 74302423,
                "comment_id": 131177869,
                "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": 1667475541,
                "post_id": 74302423,
                "comment_id": 131177876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26034583,
                    "reputation": 51,
                    "user_id": 19740219,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AItbvmm_uA6faAC1jAM-3VFHoWwTNXzgCuQdNbaG7sY=k-s256",
                    "display_name": "freshGrad",
                    "link": "https://stackoverflow.com/users/19740219/freshgrad"
                },
                "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": 1667475576,
                "post_id": 74302423,
                "comment_id": 131177886,
                "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": 1667475662,
                "post_id": 74302423,
                "comment_id": 131177916,
                "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": 1667475759,
                "post_id": 74302423,
                "comment_id": 131177947,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667481513,
                "post_id": 74302423,
                "comment_id": 131180073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1667475611,
                "creation_date": 1667475611,
                "answer_id": 74302470,
                "question_id": 74302423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can combine this into a single [tag:JQ] call:\r\n```\r\n.value[] | select(.status == &quot;offline&quot;) | &quot;ipAddress: \\(.name) id: \\(.id)&quot;\r\n```\r\n\r\nGives:\r\n```none\r\n&quot;ipAddress: ip-172-20-94-68 id: 344&quot;\r\n&quot;ipAddress: ip-172-20-95-119 id: 345&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\n#### [Online JqPlay Demo](https://jqplay.org/s/j3xaiGVQuR5)",
                "title": "nested Bash for loop not iterating correctly?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667475611,
        "creation_date": 1667475359,
        "question_id": 74302423,
        "body_markdown": "I am using a curl command to get json data from an application \r\n\r\nthe example curl response\r\n\r\n```\r\n{\r\n    &quot;count&quot;: 2,\r\n    &quot;value&quot;: [\r\n        {\r\n            &quot;id&quot;: 344,\r\n            &quot;name&quot;: &quot;ip-172-20-94-68&quot;,\r\n            &quot;status&quot;: &quot;offline&quot;,\r\n       \r\n        },\r\n        {\r\n            &quot;id&quot;: 345,\r\n            &quot;name&quot;: &quot;ip-172-20-95-119&quot;,\r\n            &quot;status&quot;: &quot;offline&quot;,\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nMy bash script\r\n```\r\n ipAddresses=$(curl -s -X GET &quot;$hostUrl&quot; -u :&quot;$EncodedPAT&quot; | jq -r &quot;.value[] | select(.status==\\&quot;offline\\&quot;).name&quot;)\r\n ids=$(curl -s -X GET &quot;$hostUrl&quot; -u :&quot;$EncodedPAT&quot; | jq -r &quot;.value[] | select(.status==\\&quot;offline\\&quot;).id&quot;)\r\n\r\n        for ipAddress in &quot;${ipAddresses[@]}&quot;\r\n            do\r\n                for id in &quot;${ids[@]}&quot;\r\n                    do\r\n                    echo &quot;ipAddress: ${ipAddress} id: ${id}&quot;\r\n                done\r\n        done\r\n```\r\n\r\noutput\r\n```\r\nipAddress: ip-172-20-94-68\r\nip-172-20-95-119\r\nip-172-20-95-113\r\nip-172-20-94-96\r\nip-172-20-94-86\r\nid: 344\r\n345\r\n346\r\n348\r\n350\r\n```\r\n\r\nSo it looks like it is only iterating through the outermost loop once, and not iterating through the inner loops (just uses first element).\r\n\r\nexpected output\r\n```\r\nipAddress: ip-172-20-94-68 id: 344\r\nipAddress: ip-172-20-95-119 id: 345\r\nipAddress: ip-172-20-95-113 id: 346\r\nipAddress: ip-172-20-94-96 id: 348\r\nipAddress: ip-172-20-94-86 id: 350\r\n```\r\n\r\n\r\nI&#39;ve looked elsewhere on the net but am having trouble finding anything relevant.\r\n\r\nAny guesses as to what might be wrong?\r\n",
        "link": "https://stackoverflow.com/questions/74302423/nested-bash-for-loop-not-iterating-correctly",
        "title": "nested Bash for loop not iterating correctly?"
    },
    {
        "tags": [
            "json",
            "jenkins",
            "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": 0,
                "creation_date": 1667494061,
                "post_id": 74306707,
                "comment_id": 131185328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26820636,
                    "reputation": 11,
                    "user_id": 20410038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74e11ad1d249112735f95328dcbd5d2a?s=256&d=identicon&r=PG",
                    "display_name": "VENKI",
                    "link": "https://stackoverflow.com/users/20410038/venki"
                },
                "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": 1667494226,
                "post_id": 74306707,
                "comment_id": 131185386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26820636,
                    "reputation": 11,
                    "user_id": 20410038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74e11ad1d249112735f95328dcbd5d2a?s=256&d=identicon&r=PG",
                    "display_name": "VENKI",
                    "link": "https://stackoverflow.com/users/20410038/venki"
                },
                "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": 1667494653,
                "post_id": 74306707,
                "comment_id": 131185545,
                "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": 1667494951,
                "post_id": 74306707,
                "comment_id": 131185647,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26820636,
                    "reputation": 11,
                    "user_id": 20410038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74e11ad1d249112735f95328dcbd5d2a?s=256&d=identicon&r=PG",
                    "display_name": "VENKI",
                    "link": "https://stackoverflow.com/users/20410038/venki"
                },
                "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": 1667496520,
                "post_id": 74306707,
                "comment_id": 131186194,
                "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": 2,
                "creation_date": 1667497054,
                "post_id": 74306707,
                "comment_id": 131186372,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667507374,
                "post_id": 74306707,
                "comment_id": 131189377,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26820636,
                    "reputation": 11,
                    "user_id": 20410038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74e11ad1d249112735f95328dcbd5d2a?s=256&d=identicon&r=PG",
                    "display_name": "VENKI",
                    "link": "https://stackoverflow.com/users/20410038/venki"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667531158,
                "post_id": 74306707,
                "comment_id": 131193660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26820636,
                    "reputation": 11,
                    "user_id": 20410038,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/74e11ad1d249112735f95328dcbd5d2a?s=256&d=identicon&r=PG",
                    "display_name": "VENKI",
                    "link": "https://stackoverflow.com/users/20410038/venki"
                },
                "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": 1667533767,
                "post_id": 74306707,
                "comment_id": 131194015,
                "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": 0,
                "creation_date": 1667556140,
                "post_id": 74306707,
                "comment_id": 131198970,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667727510,
                "last_edit_date": 1667727510,
                "creation_date": 1667575106,
                "answer_id": 74319254,
                "question_id": 74306707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Now that the question has been updated with a minimal, reproducible example, the answer is straight forward.\r\nThe program should be:\r\n\r\n```\r\n.taskDefinition |= del(.taskDefinitionArn, .revision, .status, .requiresAttributes, .compatibilities)\r\n```\r\n\r\nIt reassigns the `taskDefinition` object to itself with all specified properties removed.\r\n\r\nThe reason why `map` does not work is that map applies its inner filter to all elements of an array. If you pass in an object, the filter will be applied to all _values_ of the object.\r\n\r\n```sh\r\n$ jq &#39;map(.)&#39; &lt;&lt;JSON\r\n{\r\n    &quot;abc&quot;:1,\r\n    &quot;xyz&quot;:2,\r\n    &quot;more&quot;:3\r\n}\r\nJSON\r\n[\r\n  1,\r\n  2,\r\n  3\r\n]\r\n```\r\n\r\nThis will work as long as your object values are objects themselves, but breaks when you have non-object values. `del` can only be applied to inputs of type objects.\r\n\r\nHere&#39;s the smallest sample input that will break your `map`-based filter:\r\n\r\n```json\r\n{\r\n  &quot;object&quot;: {},\r\n  &quot;array&quot;: []\r\n}\r\n```\r\n\r\nCalling `del` on the value of `object` works: `{} | del(.something)`, but calling it on the value of `array` will break: `[] | del(.something)`.",
                "title": "Cannot index array with string &quot;taskDefinitionArn&quot; using JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667727510,
        "creation_date": 1667493847,
        "last_edit_date": 1667533064,
        "question_id": 74306707,
        "body_markdown": "```\r\n{\r\n  &quot;taskDefinition&quot;: {\r\n    &quot;status&quot;: &quot;ACTIVE&quot;,\r\n    &quot;networkMode&quot;: &quot;bridge&quot;,\r\n    &quot;family&quot;: &quot;decac-DSF-FarmB-BGcore-V7KAEEL71QS8&quot;,\r\n    &quot;placementConstraints&quot;: [],\r\n    &quot;requiresAttributes&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.logging-driver.awslogs&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.ecr-auth&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.19&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.17&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.28&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;ecs.capability.container-health-check&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.18&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;com.amazonaws.ecs.capability.docker-remote-api.1.29&quot;\r\n      }\r\n    ],\r\n    &quot;cpu&quot;: &quot;8192&quot;,\r\n    &quot;compatibilities&quot;: [\r\n      &quot;EXTERNAL&quot;,\r\n      &quot;EC2&quot;\r\n    ],\r\n    &quot;volumes&quot;: [],\r\n    &quot;memory&quot;: &quot;12480&quot;,\r\n    &quot;requiresCompatibilities&quot;: [],\r\n    &quot;taskDefinitionArn&quot;: &quot;arn:aws:ecs:ap-south-1:020627:task-definition/decac-DSF-FarmB-BGcore-V7KAEEL71QS8:640&quot;,\r\n    &quot;containerDefinitions&quot;: [\r\n      {\r\n        &quot;dnsSearchDomains&quot;: [],\r\n        &quot;environment&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;BG_CONFIGURATION_SERVER_URL&quot;,\r\n            &quot;value&quot;: &quot;http://internal-BGDSF-FarmB-pp-int-ALB-1301919556.ap-south-1.elb.amazonaws.com&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;ES_IS_ENABLED_SSL&quot;,\r\n            &quot;value&quot;: &quot;false&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;THINKANALYTICS_ENDPOINT&quot;,\r\n            &quot;value&quot;: &quot;&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;USE_HTTPS&quot;,\r\n            &quot;value&quot;: &quot;false&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;BG_CONFIG_REFRESH_INTERVAL&quot;,\r\n            &quot;value&quot;: &quot;10000&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;DECOUPLE_DCQ_ENABLED&quot;,\r\n            &quot;value&quot;: &quot;true&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;ES_SSL_CERTIFICATE_PATH&quot;,\r\n            &quot;value&quot;: &quot;&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;LOG_LEVEL&quot;,\r\n            &quot;value&quot;: &quot;info&quot;\r\n          }\r\n        ],\r\n        &quot;systemControls&quot;: [],\r\n        &quot;name&quot;: &quot;BG-core-FarmB&quot;,\r\n        &quot;links&quot;: [],\r\n        &quot;mountPoints&quot;: [],\r\n        &quot;healthCheck&quot;: {\r\n          &quot;retries&quot;: 10,\r\n          &quot;interval&quot;: 60,\r\n          &quot;command&quot;: [\r\n            &quot;CMD-SHELL&quot;,\r\n            &quot;/opt/app-root/src/readinessodejs.sh&quot;\r\n          ],\r\n          &quot;startPeriod&quot;: 15,\r\n          &quot;timeout&quot;: 45\r\n        },\r\n        &quot;image&quot;: &quot;020627.dkr.ecr.ap-south-1.amazonaws.com/BG-core:DEE.56.03112022-122711&quot;,\r\n        &quot;hostname&quot;: &quot;BG-core&quot;,\r\n        &quot;essential&quot;: true,\r\n        &quot;portMappings&quot;: [\r\n          {\r\n            &quot;protocol&quot;: &quot;tcp&quot;,\r\n            &quot;containerPort&quot;: 3000,\r\n            &quot;hostPort&quot;: 0\r\n          }\r\n        ],\r\n        &quot;dnsServers&quot;: [],\r\n        &quot;dockerSecurityOptions&quot;: [],\r\n        &quot;entryPoint&quot;: [\r\n          &quot;sh&quot;,\r\n          &quot;-c&quot;\r\n        ],\r\n        &quot;ulimits&quot;: [\r\n          {\r\n            &quot;softLimit&quot;: 51200,\r\n            &quot;name&quot;: &quot;nofile&quot;,\r\n            &quot;hardLimit&quot;: 51200\r\n          }\r\n        ],\r\n        &quot;memory&quot;: 12480,\r\n        &quot;logConfiguration&quot;: {\r\n          &quot;logDriver&quot;: &quot;awslogs&quot;,\r\n          &quot;options&quot;: {\r\n            &quot;awslogs-region&quot;: &quot;ap-south-1&quot;,\r\n            &quot;awslogs-stream-prefix&quot;: &quot;BG-core-FarmB&quot;,\r\n            &quot;awslogs-group&quot;: &quot;decacDSF-PP-ECSInfra-KHM9B7BK1HDE-ECSLogGroup-Q2KC9BCLGILN&quot;,\r\n            &quot;mode&quot;: &quot;non-blocking&quot;\r\n          }\r\n        },\r\n        &quot;command&quot;: [\r\n          &quot;/bin/sh -c \\&quot;/tmp/scripts/run\\&quot;&quot;\r\n        ],\r\n        &quot;cpu&quot;: 8192,\r\n        &quot;volumesFrom&quot;: []\r\n      }\r\n    ],\r\n    &quot;revision&quot;: 640\r\n  },\r\n  &quot;tags&quot;: []\r\n},\r\n```\r\n\r\n\r\nThis has been working earlier by using the below command:\r\n\r\njq &#39;map(del(.taskDefinitionArn, .revision, .status,.requiresAttributes,.compatibilities))&#39;\r\n\r\nBut same command started giving the below error now.\r\n\r\njq: error (at &lt;stdin&gt;:139): Cannot index array with string &quot;taskDefinitionArn&quot;\r\n\r\nI am using JQ version 1.5 did something got changed recently ?\r\n\r\n\r\nwhy it is getting failed like that can someone help in here ?\r\n\r\nPlease find the full JSON code and output which i have replicated in following [link](https://jqplay.org/s/po4ikzuaIwI)",
        "link": "https://stackoverflow.com/questions/74306707/cannot-index-array-with-string-taskdefinitionarn-using-jq",
        "title": "Cannot index array with string &quot;taskDefinitionArn&quot; using JQ"
    },
    {
        "tags": [
            "azure-pipelines",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667502720,
                "last_edit_date": 1667502720,
                "creation_date": 1667500327,
                "answer_id": 74307977,
                "question_id": 74307871,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `find` to get the files, `xargs` to feed them into `jq`, and therein `reduce` to put them together:\r\n~~~sh\r\nfind . -name object.json | xargs jq &#39;reduce inputs as $in (.; \r\n  .parameters.objects.value += $in.parameters.objects.value\r\n)&#39;\r\n~~~\r\n\r\nIf you have more files than would fit into your argument space, you can instruct `find` to just dump their content using `-exec cat`, as `jq` can handle a stream of JSON documents in almost the same manner:\r\n~~~sh\r\nfind . -name object.json -exec cat {} \\; | jq &#39;reduce inputs as $in (.;\r\n  .parameters.objects.value += $in.parameters.objects.value\r\n)&#39;\r\n~~~",
                "title": "How do I use jq to merge an array in a base file from files in subfolders"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667502720,
        "creation_date": 1667499719,
        "question_id": 74307871,
        "body_markdown": "I&#39;ve runto a stumbling block trying to use jq in an Azure Pipeline (I&#39;m sure it&#39;s not helped, because I&#39;m not a Linux guy)\r\n\r\nI have multiple (unknown how many at runtime) subdirectories, each has a file named object.json with the identical structure. All json files in here simplified as much as necessary, and I don&#39;t think any more than that.\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;genericInformation&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;value1&quot;: &quot;Something&quot;,\r\n              &quot;value2&quot;: &quot;Otherthing&quot;\r\n            }\r\n          },\r\n          &quot;objects&quot;: {\r\n            &quot;value&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;Name&quot;: &quot;Object1&quot;,\r\n                &quot;Container&quot;: &quot;Container1&quot;\r\n    \t\t  }\r\n    \t\t]\r\n    \t  }\r\n    \t}\r\n    }\r\n    \r\nI am looking to build a single file at the root level of the structure combining the objects.value array entries from all files into one file. I also have a file with an empty array I can merge them into\r\n\r\n(Desired Output)\r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;genericInformation&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;value1&quot;: &quot;Something&quot;,\r\n              &quot;value2&quot;: &quot;Otherthing&quot;\r\n            }\r\n          },\r\n          &quot;objects&quot;: {\r\n            &quot;value&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;Name&quot;: &quot;Object1&quot;,\r\n                &quot;Container&quot;: &quot;Container1&quot;\r\n    \t\t  },\r\n    \t\t  {\r\n                &quot;id&quot;: 2,\r\n                &quot;Name&quot;: &quot;Object2&quot;,\r\n                &quot;Container&quot;: &quot;Container2&quot;\r\n    \t\t  },\r\n    \t\t  {\r\n                &quot;id&quot;: 3,\r\n                &quot;Name&quot;: &quot;Object3&quot;,\r\n                &quot;Container&quot;: &quot;Container3&quot;\r\n    \t\t  }\r\n    \t\t]\r\n    \t  }\r\n    \t}\r\n    }\r\n\r\nThis loop doesn&#39;t quite get me what I want, instead it seems to be appending the output of each run of the loop to the output file, so I think I&#39;m close.\r\n\r\n    cp noobjects.json allobjects.json\r\n    for objectFile in `ls -d OBJ*/`\r\n    do\r\n      jq -s &quot;.[0].parameters.objects.value += .[1].parameters.objects.value | .[0]&quot; allobjects.json $objectfile/object.json  \r\n    done | jq -s . &gt; allobjects.json\r\n\r\n\r\nMy thinking with the code was to start with an empty array, then loop through all the subfolders (ones that start with OBJ) and Add the objects.value contents from the current file to the allobjects file.\r\n\r\nWith three subdirectories, I ended up with something like this. \r\n\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;genericInformation&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;value1&quot;: &quot;Something&quot;,\r\n              &quot;value2&quot;: &quot;Otherthing&quot;\r\n            }\r\n          },\r\n          &quot;objects&quot;: {\r\n            &quot;value&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;Name&quot;: &quot;Object1&quot;,\r\n                &quot;Container&quot;: &quot;Container1&quot;\r\n    \t\t  }\r\n      \t    ]\r\n    \t  }\r\n    \t}\r\n    }\r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;genericInformation&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;value1&quot;: &quot;Something&quot;,\r\n              &quot;value2&quot;: &quot;Otherthing&quot;\r\n            }\r\n          },\r\n          &quot;objects&quot;: {\r\n            &quot;value&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;Name&quot;: &quot;Object1&quot;,\r\n                &quot;Container&quot;: &quot;Container1&quot;\r\n    \t\t  },\r\n    \t\t  {\r\n                &quot;id&quot;: 2,\r\n                &quot;Name&quot;: &quot;Object2&quot;,\r\n                &quot;Container&quot;: &quot;Container2&quot;\r\n    \t\t  }\r\n    \t\t]\r\n    \t  }\r\n    \t}\r\n    }\r\n    \r\n    {\r\n        &quot;$schema&quot;: &quot;https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#&quot;,\r\n        &quot;contentVersion&quot;: &quot;1.0.0.0&quot;,\r\n        &quot;parameters&quot;: {\r\n          &quot;genericInformation&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;value1&quot;: &quot;Something&quot;,\r\n              &quot;value2&quot;: &quot;Otherthing&quot;\r\n            }\r\n          },\r\n          &quot;objects&quot;: {\r\n            &quot;value&quot;: [\r\n              {\r\n                &quot;id&quot;: 1,\r\n                &quot;Name&quot;: &quot;Object1&quot;,\r\n                &quot;Container&quot;: &quot;Container1&quot;\r\n    \t\t  },\r\n    \t\t  {\r\n                &quot;id&quot;: 2,\r\n                &quot;Name&quot;: &quot;Object2&quot;,\r\n                &quot;Container&quot;: &quot;Container2&quot;\r\n    \t\t  },\r\n    \t\t  {\r\n                &quot;id&quot;: 3,\r\n                &quot;Name&quot;: &quot;Object3&quot;,\r\n                &quot;Container&quot;: &quot;Container3&quot;\r\n    \t\t  }\r\n    \t\t]\r\n    \t  }\r\n    \t}\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74307871/how-do-i-use-jq-to-merge-an-array-in-a-base-file-from-files-in-subfolders",
        "title": "How do I use jq to merge an array in a base file from files in subfolders"
    },
    {
        "tags": [
            "bash",
            "shell",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1667501495,
                "post_id": 74308159,
                "comment_id": 131187708,
                "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": 2,
                "creation_date": 1667502331,
                "post_id": 74308159,
                "comment_id": 131187917,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667502479,
                "post_id": 74308159,
                "comment_id": 131187966,
                "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": 1667511792,
                "post_id": 74308159,
                "comment_id": 131190553,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667550731,
                "post_id": 74308159,
                "comment_id": 131197235,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667551714,
                "post_id": 74308159,
                "comment_id": 131197510,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667526220,
                "creation_date": 1667526220,
                "answer_id": 74311308,
                "question_id": 74308159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    echo &quot;https://www.stackoverflow.com&quot; | sed &#39;s#https\\(.*\\)//.*#\\1#&#39;\r\n    :\r\n\r\n- `sed` operator s/regexp/replacement/\r\n- regexp: `https\\(.*)//.*`.  So &quot;https&quot; followed by something (`.*`), followed by &quot;//&quot;, followed by anything else `.*`\r\n- the parenthesis are back slashed since they are not part of the pattern.  They are used to group a part of the regex for the replacement part of the `s###` operator.\r\n- replacement: \\1, means the first group found in the regex `\\(.*\\)`\r\n- I used `s###`, but the usual form is `s///`.  Any character can take the place of the `/` with the `s` operator.  I used `#` as using `/` would have been confusing since you use `/` in the url.\r\n",
                "title": "Regex: match only string C that is in between string A and string B"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667551568,
                "last_edit_date": 1667551568,
                "creation_date": 1667551202,
                "answer_id": 74314248,
                "question_id": 74308159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that your `sed` substitutions are terribly imprecise. Anyway, you want to do it in `jq` instead, where you have more control over which parts you are substituting, and avoid spawning a separate process for something `jq` quite easily does natively in the first place.\r\n\r\n```\r\ncurl -s url |\r\njq -r &#39;.property.source | to_entries[] |\r\n  &quot;\\(.key)=\\&quot;\\(.value\\)\\&quot;&quot;&#39; &gt; .env.test\r\n```\r\n\r\nTangentially, capturing the output of `curl` into a variable just so you can immediately `cat` it once to standard output is just a waste of memory.",
                "title": "Regex: match only string C that is in between string A and string B"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667551568,
        "creation_date": 1667501258,
        "last_edit_date": 1667551368,
        "question_id": 74308159,
        "body_markdown": "How can I write a regex in a shell script that would target only the targeted substring between two given values? Give the example\r\n```\r\nhttps://www.stackoverflow.com\r\n```\r\nHow can I match only the &quot;:&quot; in between &quot;https&quot; and &quot;//&quot;.\r\nIf possible please also explain the approach.\r\n\r\nThe context is that I need to prepare a file that would fetch a config from the server and append it to the .env file. The response comes as JSON\r\n```\r\n{\r\n  &quot;GRAPHQL_URL&quot;: &quot;https://someurl/xyz&quot;,\r\n  &quot;PUBLIC_TOKEN&quot;: &quot;skml2JdJyOcrVdfEJ3Bj1bs472wY8aSyprO2DsZbHIiBRqEIPBNg9S7yXBbYkndX2Lk8UuHoZ9JPdJEWaiqlIyGdwU6O5&quot;,\r\n  &quot;SUPER_SECRET&quot;: &quot;MY_SUPER_SECRET&quot;\r\n}\r\n```\r\nso I need to adjust it to the `.env` syntax. What I managed to do this far is \r\n```\r\n#!/bin/bash\r\nCURL_RESPONSE=&quot;$(curl -s url)&quot;\r\n\r\ncat &lt;&lt;&lt; ${CURL_RESPONSE} | jq -r &#39;.property.source&#39; | sed -r &#39;s/:/=/g;s/[^a-zA-Z0-9=:_/-]//g&#39; &gt; .env.test\r\n```\r\n\r\nso basically I fetch the data, then extract the key I am after with `jq`, and then I use `sed` to first replace all &quot;:&quot; to &quot;=&quot; and after that I remove all the quotations and semicolons and white spaces that comes from JSON and leave some characters that are necessary.\r\n\r\nI am almost there but the problem is that now my graphql url (and only other) would look like so\r\n```\r\nhttps=//someurl/xyz\r\n```\r\nso I need to replace this = that is in between https and // back with the colon.\r\n\r\nThank you very much @Nic3500 for the response, not sure why but I get error saying that \r\n```\r\nsed: 1: &quot;s/:/=/g;s#https\\(.*\\)// ...&quot;: \\1 not defined in the RE\r\n```\r\nI searched SO and it seems that it should work since the brackets are escaped and I use `-r` flag (tried `-E` but no difference) and I don&#39;t know how to apply it. To be honest I assume that the replacement block is this part\r\n```\r\n#\\1#\r\n```\r\nso how can I let this know to what character should it be replaced?\r\n\r\nThis is how I tried to use it\r\n```\r\n#!/bin/bash\r\nCURL_RESPONSE=&quot;$(curl -s url)&quot;\r\n\r\ncat &lt;&lt;&lt; ${CURL_RESPONSE} | jq -r &#39;.property.source&#39; | sed -r &#39;s/:/=/g;s#https\\(.*\\)//.*#\\1#;s/[^a-zA-Z0-9=:_/-]//g&#39; &gt; .env.test\r\n```\r\nHope with this context you would be able to help me.\r\n",
        "link": "https://stackoverflow.com/questions/74308159/regex-match-only-string-c-that-is-in-between-string-a-and-string-b",
        "title": "Regex: match only string C that is in between string A and string B"
    },
    {
        "tags": [
            "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": 1667508813,
                "post_id": 74309393,
                "comment_id": 131189780,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6561717,
                    "reputation": 45,
                    "user_id": 5072582,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3aa7a6dfe08c949c819f873dd607354a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "girish chalke",
                    "link": "https://stackoverflow.com/users/5072582/girish-chalke"
                },
                "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": 1667829919,
                "post_id": 74309393,
                "comment_id": 131254404,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667579302,
                "creation_date": 1667579302,
                "answer_id": 74320164,
                "question_id": 74309393,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Operator precedence in jq is not always intuitive. Your program is parsed as:\r\n\r\n```\r\n.policyItems[] | (select(.groups[] | IN(&quot;NP01-RO&quot;)).users += [$username])\r\n```\r\n\r\nWhich first streams all policyItems and only then changes them, leaving you with policyItems only in the output.\r\n\r\nYou need to make sure that the stream selects the correct values, which you can then assign:\r\n\r\n```\r\n(.policyItems[] | select(.groups[] | IN(&quot;NP01-RO&quot;)).users) += [$username]\r\n```\r\n\r\nThis will do the assignment, but still return the full input (`.`).",
                "title": "jq array filter for nested array elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667579302,
        "creation_date": 1667508552,
        "question_id": 74309393,
        "body_markdown": "I am trying to add a new user in below json which matches group NP01-RW. i am able to do without NP01-RW but not able to select users under NP01-RW and return updated json.\r\n\r\n\r\n````\r\n{\r\n  &quot;id&quot;: 181,\r\n  &quot;guid&quot;: &quot;c9b7dbde-63de-42cc-9840-1b4a06e13364&quot;,\r\n  &quot;isEnabled&quot;: true,\r\n  &quot;version&quot;: 17,\r\n  &quot;service&quot;: &quot;Np-Hue&quot;,\r\n  &quot;name&quot;: &quot;DATASCIENCE-CUROPT-RO&quot;,\r\n  &quot;policyType&quot;: 0,\r\n  &quot;policyPriority&quot;: 0,\r\n  &quot;isAuditEnabled&quot;: true,\r\n  &quot;resources&quot;: {\r\n    &quot;database&quot;: {\r\n      &quot;values&quot;: [\r\n        &quot;hive_cur_acct_1dev&quot;,\r\n        &quot;hive_cur_acct_1eng&quot;,\r\n        &quot;hive_cur_acct_1rwy&quot;,\r\n        &quot;hive_cur_acct_1stg&quot;,\r\n        &quot;hive_opt_acct_1dev&quot;,\r\n        &quot;hive_opt_acct_1eng&quot;,\r\n        &quot;hive_opt_acct_1stg&quot;,\r\n        &quot;hive_opt_acct_1rwy&quot;\r\n      ],\r\n      &quot;isExcludes&quot;: false,\r\n      &quot;isRecursive&quot;: false\r\n    },\r\n    &quot;column&quot;: {\r\n      &quot;values&quot;: [\r\n        &quot;*&quot;\r\n      ],\r\n      &quot;isExcludes&quot;: false,\r\n      &quot;isRecursive&quot;: false\r\n    },\r\n    &quot;table&quot;: {\r\n      &quot;values&quot;: [\r\n        &quot;*&quot;\r\n      ],\r\n      &quot;isExcludes&quot;: false,\r\n      &quot;isRecursive&quot;: false\r\n    }\r\n  },\r\n  &quot;policyItems&quot;: [\r\n    {\r\n      &quot;accesses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;select&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;update&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;create&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;drop&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;alter&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;index&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;lock&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;all&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;read&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;write&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        }\r\n      ],\r\n      &quot;users&quot;: [\r\n        &quot;user1&quot;,\r\n        &quot;user2&quot;,\r\n        &quot;user3&quot;\r\n      ],\r\n      &quot;groups&quot;: [\r\n        &quot;NP01-RW&quot;\r\n      ],\r\n      &quot;conditions&quot;: [],\r\n      &quot;delegateAdmin&quot;: false\r\n    },\r\n    {\r\n      &quot;accesses&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;select&quot;,\r\n          &quot;isAllowed&quot;: true\r\n        }\r\n      ],\r\n      &quot;users&quot;: [\r\n        &quot;user1&quot;\r\n      ],\r\n      &quot;groups&quot;: [\r\n        &quot;NP01-RO&quot;\r\n      ],\r\n      &quot;conditions&quot;: [],\r\n      &quot;delegateAdmin&quot;: false\r\n    }\r\n  ],\r\n  &quot;denyPolicyItems&quot;: [],\r\n  &quot;allowExceptions&quot;: [],\r\n  &quot;denyExceptions&quot;: [],\r\n  &quot;dataMaskPolicyItems&quot;: [],\r\n  &quot;rowFilterPolicyItems&quot;: [],\r\n  &quot;options&quot;: {},\r\n  &quot;validitySchedules&quot;: [],\r\n  &quot;policyLabels&quot;: [\r\n    &quot;DATASCIENCE-CurOpt-RO_NP01&quot;\r\n  ]\r\n}\r\n````\r\n\r\n\r\n\r\nbelow is what i have tried but it returns part of the JSON matching NP01-RW and not full JSON\r\n\r\njq --arg username &quot;$sync_userName&quot; &#39;.policyItems[] | select(.groups[] | IN(&quot;NP01-RO&quot;)).users += [$username]&#39; &gt; ${sync_policyName}.json\r\n",
        "link": "https://stackoverflow.com/questions/74309393/jq-array-filter-for-nested-array-elements",
        "title": "jq array filter for nested array elements"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1667545606,
                "creation_date": 1667545606,
                "answer_id": 74313312,
                "question_id": 74313225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The issue is that the name of the parameter is colliding with the name of the filter, essentially creating a local that obscures the global. Naming the parameter anything else will fix it:\r\n\r\n``` jq\r\ndef reverseIfTrue($rev):\r\n  if $rev then\r\n    reverse\r\n  else\r\n    .\r\n  end\r\n;\r\n```\r\n\r\nRemember that filter parameters always create their non-variable aliases; `def foo($bar): ...` is documented to be the same as `def foo(bar): bar as $bar | ...`.",
                "title": "jq function with boolean parameter does not reverse input array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1667597666,
        "creation_date": 1667544950,
        "last_edit_date": 1667597666,
        "question_id": 74313225,
        "body_markdown": "I would like to reverse an array with a jq function.\r\n\r\nThe jq function accepts a boolean that tells the function whether or not to reverse the array.\r\n\r\nStrangely enough, this function is returning `true` instead of returning the (possibly sorted) array...\r\n\r\n## jq Filter\r\n```\r\ndef reverseIfTrue($reverse):\r\n  if $reverse then reverse else . end;\r\nreverseIfTrue(true)\r\n```\r\n\r\n## json Input\r\n```\r\n[&quot;a&quot;,&quot;b&quot;]\r\n```\r\n\r\n## jq Output\r\n```\r\ntrue\r\n```\r\n\r\njq snippet: https://jqplay.org/s/DMMUme_Qngi",
        "link": "https://stackoverflow.com/questions/74313225/jq-function-with-boolean-parameter-does-not-reverse-input-array",
        "title": "jq function with boolean parameter does not reverse input array"
    },
    {
        "tags": [
            "gitlab-ci",
            "jq",
            "cicd",
            "vault"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3330925,
                    "reputation": 29318,
                    "user_id": 5343387,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/f459904f745c6646b0ef1ea72ca564cc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matthew Schuchard",
                    "link": "https://stackoverflow.com/users/5343387/matthew-schuchard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667593631,
                "post_id": 74322530,
                "comment_id": 131211755,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12637937,
                    "reputation": 1546,
                    "user_id": 9186499,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/b009234701c9eeb923809d1c6eb19120?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "knowledge20",
                    "link": "https://stackoverflow.com/users/9186499/knowledge20"
                },
                "reply_to_user": {
                    "account_id": 3330925,
                    "reputation": 29318,
                    "user_id": 5343387,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/f459904f745c6646b0ef1ea72ca564cc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Matthew Schuchard",
                    "link": "https://stackoverflow.com/users/5343387/matthew-schuchard"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667593796,
                "post_id": 74322530,
                "comment_id": 131211792,
                "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": 1,
                "creation_date": 1667594767,
                "post_id": 74322530,
                "comment_id": 131212045,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1667758084,
        "creation_date": 1667593049,
        "last_edit_date": 1667758084,
        "question_id": 74322530,
        "body_markdown": "I am trying to integrate vault with gitlab and fetch secrets from vault using jwt authentication. I am able to retrieve the vault token using command.\r\n\r\n    export VAULT_TOKEN = $(curl \\\r\n        --request POST \\\r\n        --data &#39;{&quot;jwt&quot;: &quot;your_jwt&quot;, &quot;role&quot;: &quot;demo&quot;}&#39; \\\r\n        http://127.0.0.1:8200/v1/auth/jwt/login | jq -r .auth.client_token)\r\n\r\nNow I am trying to consume this token to fetch the secret.\r\n\r\n    list_secrets=$(curl -k --header &quot;X-Vault-Token:${VAULT_TOKEN} &lt;vaulturl&gt;)\r\n\r\nI am getting an HTML page in the list_secrets but unable to see the actual secrets in the tags of html code.\r\n\r\non top of this, I am trying to fetch individual secret using below command.\r\n\r\n    Secret_1=$(echo ${list_secrets} | jq -r .data.data&#39;.&quot;dbname.password&quot;&#39;)\r\n    echo $Secret_1\r\n\r\nThis echo command gives me error invalid numeric literal at column 1 line 10\r\n\r\nCan someone guide me please how can I fetch the secret.\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74322530/fetching-secrets-from-vault-using-gitlab",
        "title": "Fetching secrets from vault using gitlab"
    },
    {
        "tags": [
            "jq",
            "json2csv"
        ],
        "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": 1667626068,
                "post_id": 74324886,
                "comment_id": 131216120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667629510,
                "post_id": 74324886,
                "comment_id": 131216435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667651699,
                "creation_date": 1667651699,
                "answer_id": 74327727,
                "question_id": 74324886,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[jq](https://stedolan.github.io/jq/) let&#39;s you do the conversion to CSV easily. The following code produces the desired output:\r\n\r\n```bash\r\njq -r &#39;to_entries\r\n       | map([.key, \r\n              .value.asset_id, .value.referencekey, .value.hostname, .value.fqdn,\r\n              .value.network_zone[0], .value.network_zone[1],\r\n              .value.service.name, .value.service.account, .value.service.billing,\r\n              .value.aws.tags.Name, .value.aws.tags.Service, .value.aws.tags.Usecase, .value.aws.tags.billing, .value.aws.tags.OsVersion,\r\n              .value.aws.instance_type, .value.aws.ami_imageid, .value.aws.state])\r\n       | [&quot;_key&quot;,&quot;asset_id&quot;,&quot;referencekey&quot;,&quot;hostname&quot;,&quot;fqdn&quot;,&quot;network_zone/0&quot;,&quot;network_zone/1&quot;,&quot;service/name&quot;,&quot;service/account&quot;,&quot;service/billing&quot;,&quot;aws/tags/Name&quot;,&quot;aws/tags/Service&quot;,&quot;aws/tags/Usecase&quot;,&quot;aws/tags/billing&quot;,&quot;aws/tags/OsVersion&quot;,&quot;aws/instance_type&quot;,&quot;aws/ami_imageid&quot;,&quot;aws/state&quot;]\r\n         , .[]\r\n       | @csv&#39; &quot;$INPUT&quot;\r\n```\r\n\r\n**Remarks**\r\n\r\n- If some nodes in the input JSON are missing, the code does not break but fills in empty values in the CSV file.\r\n- If more than two network zones are given, only the first two are covered in the CSV file",
                "title": "convert very large custom json to csv using jq bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1667651699,
        "creation_date": 1667619040,
        "last_edit_date": 1667625930,
        "question_id": 74324886,
        "body_markdown": "have a very large JSON data like below\r\n\r\n```\r\n{\r\n    &quot;10.10.10.1&quot;: {\r\n      &quot;asset_id&quot;: 1,\r\n      &quot;referencekey&quot;: &quot;ASSET-00001&quot;,\r\n      &quot;hostname&quot;: &quot;testDev01&quot;,\r\n      &quot;fqdn&quot;: &quot;ip-10-10.10.1.ap-northeast-2.compute.internal&quot;,\r\n      &quot;network_zone&quot;: [\r\n        &quot;DEV&quot;,\r\n        &quot;Dev&quot;\r\n      ],\r\n      &quot;service&quot;: {\r\n        &quot;name&quot;: &quot;TEST_SVC&quot;,\r\n        &quot;account&quot;: &quot;AWS_TEST&quot;,\r\n        &quot;billing&quot;: &quot;Testpay&quot;\r\n      },\r\n      &quot;aws&quot;: {\r\n        &quot;tags&quot;: {\r\n          &quot;Name&quot;: &quot;testDev01&quot;,\r\n          &quot;Service&quot;: &quot;TEST_SVC&quot;,\r\n          &quot;Usecase&quot;: &quot;Dev&quot;,\r\n          &quot;billing&quot;: &quot;Testpay&quot;,\r\n          &quot;OsVersion&quot;: &quot;20.04&quot;\r\n        },\r\n        &quot;instance_type&quot;: &quot;t3.micro&quot;,\r\n        &quot;ami_imageid&quot;: &quot;ami-e000001&quot;,\r\n        &quot;state&quot;: &quot;running&quot;\r\n      }\r\n    },\r\n    &quot;10.10.10.2&quot;: {\r\n      &quot;asset_id&quot;: 3,\r\n      &quot;referencekey&quot;: &quot;ASSET-47728&quot;,\r\n      &quot;hostname&quot;: &quot;Infra_Live01&quot;,\r\n      &quot;fqdn&quot;: &quot;ip-10-10-10-2.ap-northeast-2.compute.internal&quot;,\r\n      &quot;network_zone&quot;: [\r\n        &quot;PROD&quot;,\r\n        &quot;Live&quot;\r\n      ],\r\n      &quot;service&quot;: {\r\n        &quot;name&quot;: &quot;Infra&quot;,\r\n        &quot;account&quot;: &quot;AWS_TEST&quot;,\r\n        &quot;billing&quot;: &quot;infra&quot;\r\n      },\r\n      &quot;aws&quot;: {\r\n        &quot;tags&quot;: {\r\n          &quot;Name&quot;: &quot;Infra_Live01&quot;,\r\n          &quot;Service&quot;: &quot;Infra&quot;,\r\n          &quot;Usecase&quot;: &quot;Live&quot;,\r\n          &quot;billing&quot;: &quot;infra&quot;,\r\n          &quot;OsVersion&quot;: &quot;16.04&quot;\r\n        },\r\n        &quot;instance_type&quot;: &quot;r5.large&quot;,\r\n        &quot;ami_imageid&quot;: &quot;ami-e592398b&quot;,\r\n        &quot;state&quot;: &quot;running&quot;\r\n      }\r\n    }\r\n}\r\n```\r\n\r\nCan I use JQ to make the conversion like below?\r\nOr is there an easier way to solve it?\r\nThank you\r\n\r\nExpected result\r\n```\r\n_key,asset_id,referencekey,hostname,fqdn,network_zone/0,network_zone/1,service/name,service/account,service/billing,aws/tags/Name,aws/tags/Service,aws/tags/Usecase,aws/tags/billing,aws/tags/OsVersion,aws/instance_type,aws/ami_imageid,aws/state\r\n10.10.10.1,1,ASSET-00001,testDev01,ip-10-10.10.1.ap-northeast-2.compute.internal,DEV,Dev,TEST_SVC,AWS_TEST,Testpay,testDev01,TEST_SVC,Dev,Testpay,20.04,t3.micro,ami-e000001,running\r\n10.10.10.2,3,ASSET-47728,Infra_Live01,ip-10-10-10-2.ap-northeast-2.compute.internal,PROD,Live,Infra,AWS_TEST,infra,Infra_Live01,Infra,Live,infra,16.04,r5.large,ami-e592398b,running\r\n```",
        "link": "https://stackoverflow.com/questions/74324886/convert-very-large-custom-json-to-csv-using-jq-bash",
        "title": "convert very large custom json to csv using jq bash"
    },
    {
        "tags": [
            "ansible",
            "jq",
            "jmespath",
            "json-query"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667954368,
                "last_edit_date": 1667954368,
                "creation_date": 1667765117,
                "answer_id": 74339337,
                "question_id": 74339143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The query below\r\n\r\n```yaml\r\ndocker_compose_list: &quot;{{ docker_compose_init_result|\r\n                         json_query(_query) }}&quot;\r\n_query: &#39;services.*.keys(@)&#39;\r\n```\r\ngives\r\n\r\n```yaml\r\ndocker_compose_list:\r\n  - - docker-compose_grafana_1\r\n  - - docker-compose_node-red_1\r\n  - - docker-compose_organizr_1\r\n  - - docker-compose_prometheus_1\r\n```\r\n\r\nSelect *first* items\r\n\r\n```yaml\r\ndocker_compose_list: &quot;{{ docker_compose_init_result|\r\n                         json_query(_query)|\r\n                         map(&#39;first&#39;)|list }}&quot;\r\n```\r\n\r\nor *flatten* the list\r\n\r\n```yaml\r\ndocker_compose_list: &quot;{{ docker_compose_init_result|\r\n                         json_query(_query)|\r\n                         flatten }}&quot;\r\n```\r\n\r\nboth give\r\n\r\n```yaml\r\ndocker_compose_list:\r\n  - docker-compose_grafana_1\r\n  - docker-compose_node-red_1\r\n  - docker-compose_organizr_1\r\n  - docker-compose_prometheus_1\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n&lt;sup&gt;\r\n\r\n**Note**: Be careful how you select or flatten the list. There might be a reason for the second-level keys. For example, if there are more keys in `services.grafana` the result might be\r\n\r\n```yaml\r\ndocker_compose_list:\r\n  - - docker-compose_grafana_1\r\n    - docker-compose_grafana_2\r\n    - docker-compose_grafana_3\r\n  - - docker-compose_node-red_1\r\n  - - docker-compose_organizr_1\r\n  - - docker-compose_prometheus_1\r\n```\r\n\r\nIn this case, taking the first item or flattening the list doesn&#39;t necessarily give the result you want.\r\n\r\n&lt;/sup&gt;\r\n",
                "title": "Getting the values of keys of Ansible JSON output"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1667766954,
                "creation_date": 1667766954,
                "answer_id": 74339561,
                "question_id": 74339143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution using only builtin filters:\r\n\r\n```yaml\r\ndocker_compose_list: &quot;{{ docker_compose_init_result.services | dict2items\r\n  | map(attribute=&#39;value&#39;) | map(&#39;dict2items&#39;)\r\n  | flatten | map(attribute=&#39;key&#39;) }}&quot;\r\n```\r\nwhich gives once expanded:\r\n```json\r\n{\r\n    &quot;docker_compose_list&quot;: [\r\n        &quot;docker-compose_grafana_1&quot;,\r\n        &quot;docker-compose_node-red_1&quot;,\r\n        &quot;docker-compose_organizr_1&quot;,\r\n        &quot;docker-compose_prometheus_1&quot;\r\n    ]\r\n}\r\n```",
                "title": "Getting the values of keys of Ansible JSON output"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1667817743,
                "creation_date": 1667817743,
                "answer_id": 74345312,
                "question_id": 74339143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a pure JMESPath way, you query should be:\r\n\r\n```none\r\ndocker_compose_init_result.services.*.keys(@)[]\r\n```\r\n\r\nWhere:\r\n* `.*` is the notation for an [object project](https://jmespath.org/tutorial.html#object-projections), that will make you get the values under `docker_compose_init_result.services`, whatever the key might be.\r\n* `.keys(@)` is the [`keys()`](https://jmespath.org/specification.html#keys) function, in order to get the keys, mapped to the current node — [`@`](https://jmespath.org/specification.html#current-node), which effectively means that `keys()` is going to be applied to every object which are children of `docker_compose_init_result.services.*`, (e.g.: on `docker_compose_init_result.services.grafana.&quot;docker-compose_grafana_1&quot;`, `docker_compose_init_result.services.&quot;node-red&quot;.&quot;docker-compose_node-red_1&quot;`, and so on)\r\n* `[]` is the [flatten operator](https://jmespath.org/specification.html#flatten-operator), in order to reduce your array of arrays to a single level array",
                "title": "Getting the values of keys of Ansible JSON output"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1667954368,
        "creation_date": 1667763543,
        "last_edit_date": 1667817020,
        "question_id": 74339143,
        "body_markdown": "I have the following JSON data\r\n\r\n```json\r\n{\r\n    &quot;docker_compose_init_result&quot;: {\r\n        &quot;changed&quot;: true,\r\n        &quot;failed&quot;: false,\r\n        &quot;services&quot;: {\r\n            &quot;grafana&quot;: {\r\n                &quot;docker-compose_grafana_1&quot;: {\r\n                    &quot;cmd&quot;: [],\r\n                    &quot;image&quot;: &quot;grafana/grafana:8.5.14&quot;,\r\n                    &quot;labels&quot;: {\r\n                        &quot;com.docker.compose.config-hash&quot;: &quot;4d0b5dd6e697a8fe5bf5074192770285e54da43ad32cc34ba9c56505cb709431&quot;,\r\n                        &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                        &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                        &quot;com.docker.compose.project&quot;: &quot;docker-compose&quot;,\r\n                        &quot;com.docker.compose.project.config_files&quot;: &quot;/appl/docker-compose/docker-compose-init.yml&quot;,\r\n                        &quot;com.docker.compose.project.working_dir&quot;: &quot;/appl/docker-compose&quot;,\r\n                        &quot;com.docker.compose.service&quot;: &quot;grafana&quot;,\r\n                        &quot;com.docker.compose.version&quot;: &quot;1.29.2&quot;\r\n                    },\r\n                    &quot;networks&quot;: {\r\n                        &quot;docker-compose_homeserver-net&quot;: {\r\n                            &quot;IPAddress&quot;: &quot;172.20.0.2&quot;,\r\n                            &quot;IPPrefixLen&quot;: 16,\r\n                            &quot;aliases&quot;: [\r\n                                &quot;3d19f54271b2&quot;,\r\n                                &quot;grafana&quot;\r\n                            ],\r\n                            &quot;globalIPv6&quot;: &quot;&quot;,\r\n                            &quot;globalIPv6PrefixLen&quot;: 0,\r\n                            &quot;links&quot;: null,\r\n                            &quot;macAddress&quot;: &quot;02:42:ac:14:00:02&quot;\r\n                        }\r\n                    },\r\n                    &quot;state&quot;: {\r\n                        &quot;running&quot;: true,\r\n                        &quot;status&quot;: &quot;running&quot;\r\n                    }\r\n                }\r\n            },\r\n            &quot;node-red&quot;: {\r\n                &quot;docker-compose_node-red_1&quot;: {\r\n                    &quot;cmd&quot;: [],\r\n                    &quot;image&quot;: &quot;nodered/node-red:2.2.2&quot;,\r\n                    &quot;labels&quot;: {\r\n                        &quot;authors&quot;: &quot;Dave Conway-Jones, Nick O&#39;Leary, James Thomas, Raymond Mouthaan&quot;,\r\n                        &quot;com.docker.compose.config-hash&quot;: &quot;5610863d4b28b11645acb5651e7bab174125743dc86a265969788cc8ac782efe&quot;,\r\n                        &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                        &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                        &quot;com.docker.compose.project&quot;: &quot;docker-compose&quot;,\r\n                        &quot;com.docker.compose.project.config_files&quot;: &quot;/appl/docker-compose/docker-compose-init.yml&quot;,\r\n                        &quot;com.docker.compose.project.working_dir&quot;: &quot;/appl/docker-compose&quot;,\r\n                        &quot;com.docker.compose.service&quot;: &quot;node-red&quot;,\r\n                        &quot;com.docker.compose.version&quot;: &quot;1.29.2&quot;,\r\n                        &quot;org.label-schema.arch&quot;: &quot;&quot;,\r\n                        &quot;org.label-schema.build-date&quot;: &quot;2022-02-18T21:01:04Z&quot;,\r\n                        &quot;org.label-schema.description&quot;: &quot;Low-code programming for event-driven applications.&quot;,\r\n                        &quot;org.label-schema.docker.dockerfile&quot;: &quot;.docker/Dockerfile.alpine&quot;,\r\n                        &quot;org.label-schema.license&quot;: &quot;Apache-2.0&quot;,\r\n                        &quot;org.label-schema.name&quot;: &quot;Node-RED&quot;,\r\n                        &quot;org.label-schema.url&quot;: &quot;https://nodered.org&quot;,\r\n                        &quot;org.label-schema.vcs-ref&quot;: &quot;&quot;,\r\n                        &quot;org.label-schema.vcs-type&quot;: &quot;Git&quot;,\r\n                        &quot;org.label-schema.vcs-url&quot;: &quot;https://github.com/node-red/node-red-docker&quot;,\r\n                        &quot;org.label-schema.version&quot;: &quot;2.2.2&quot;\r\n                    },\r\n                    &quot;networks&quot;: {\r\n                        &quot;docker-compose_homeserver-net&quot;: {\r\n                            &quot;IPAddress&quot;: &quot;172.20.0.4&quot;,\r\n                            &quot;IPPrefixLen&quot;: 16,\r\n                            &quot;aliases&quot;: [\r\n                                &quot;fc56e973c98d&quot;,\r\n                                &quot;node-red&quot;\r\n                            ],\r\n                            &quot;globalIPv6&quot;: &quot;&quot;,\r\n                            &quot;globalIPv6PrefixLen&quot;: 0,\r\n                            &quot;links&quot;: null,\r\n                            &quot;macAddress&quot;: &quot;02:42:ac:14:00:04&quot;\r\n                        }\r\n                    },\r\n                    &quot;state&quot;: {\r\n                        &quot;running&quot;: true,\r\n                        &quot;status&quot;: &quot;running&quot;\r\n                    }\r\n                }\r\n            },\r\n            &quot;organizr&quot;: {\r\n                &quot;docker-compose_organizr_1&quot;: {\r\n                    &quot;cmd&quot;: [],\r\n                    &quot;image&quot;: &quot;organizr/organizr:linux-amd64&quot;,\r\n                    &quot;labels&quot;: {\r\n                        &quot;base.maintainer&quot;: &quot;christronyxyocum,Roxedus&quot;,\r\n                        &quot;base.s6.arch&quot;: &quot;amd64&quot;,\r\n                        &quot;base.s6.rel&quot;: &quot;2.2.0.3&quot;,\r\n                        &quot;com.docker.compose.config-hash&quot;: &quot;430b338b0c0892a25522e1b641a9e3a08eedd255309b1cd275b22a3362dcac58&quot;,\r\n                        &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                        &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                        &quot;com.docker.compose.project&quot;: &quot;docker-compose&quot;,\r\n                        &quot;com.docker.compose.project.config_files&quot;: &quot;/appl/docker-compose/docker-compose-init.yml&quot;,\r\n                        &quot;com.docker.compose.project.working_dir&quot;: &quot;/appl/docker-compose&quot;,\r\n                        &quot;com.docker.compose.service&quot;: &quot;organizr&quot;,\r\n                        &quot;com.docker.compose.version&quot;: &quot;1.29.2&quot;,\r\n                        &quot;maintainer&quot;: &quot;christronyxyocum,Roxedus&quot;,\r\n                        &quot;org.label-schema.description&quot;: &quot;Baseimage for Organizr&quot;,\r\n                        &quot;org.label-schema.name&quot;: &quot;organizr/base&quot;,\r\n                        &quot;org.label-schema.schema-version&quot;: &quot;1.0&quot;,\r\n                        &quot;org.label-schema.url&quot;: &quot;https://organizr.app/&quot;,\r\n                        &quot;org.label-schema.vcs-url&quot;: &quot;https://github.com/organizr/docker-base&quot;,\r\n                        &quot;org.opencontainers.image.created&quot;: &quot;2022-05-08_15&quot;,\r\n                        &quot;org.opencontainers.image.source&quot;: &quot;https://github.com/Organizr/docker-organizr/tree/master&quot;,\r\n                        &quot;org.opencontainers.image.title&quot;: &quot;organizr/base&quot;,\r\n                        &quot;org.opencontainers.image.url&quot;: &quot;https://github.com/Organizr/docker-organizr/blob/master/README.md&quot;\r\n                    },\r\n                    &quot;networks&quot;: {\r\n                        &quot;docker-compose_homeserver-net&quot;: {\r\n                            &quot;IPAddress&quot;: &quot;172.20.0.3&quot;,\r\n                            &quot;IPPrefixLen&quot;: 16,\r\n                            &quot;aliases&quot;: [\r\n                                &quot;organizr&quot;,\r\n                                &quot;f3f61d8938fe&quot;\r\n                            ],\r\n                            &quot;globalIPv6&quot;: &quot;&quot;,\r\n                            &quot;globalIPv6PrefixLen&quot;: 0,\r\n                            &quot;links&quot;: null,\r\n                            &quot;macAddress&quot;: &quot;02:42:ac:14:00:03&quot;\r\n                        }\r\n                    },\r\n                    &quot;state&quot;: {\r\n                        &quot;running&quot;: true,\r\n                        &quot;status&quot;: &quot;running&quot;\r\n                    }\r\n                }\r\n            },\r\n            &quot;prometheus&quot;: {\r\n                &quot;docker-compose_prometheus_1&quot;: {\r\n                    &quot;cmd&quot;: [\r\n                        &quot;--config.file=/etc/prometheus/prometheus.yml&quot;,\r\n                        &quot;--storage.tsdb.path=/prometheus&quot;,\r\n                        &quot;--web.console.libraries=/etc/prometheus/console_libraries&quot;,\r\n                        &quot;--web.console.templates=/etc/prometheus/consoles&quot;,\r\n                        &quot;--web.enable-lifecycle&quot;\r\n                    ],\r\n                    &quot;image&quot;: &quot;prom/prometheus:v2.35.0&quot;,\r\n                    &quot;labels&quot;: {\r\n                        &quot;com.docker.compose.config-hash&quot;: &quot;7d2ce7deba1a152ebcf4fe5494384018c514f6703b5e906aef6f2e8820733cb2&quot;,\r\n                        &quot;com.docker.compose.container-number&quot;: &quot;1&quot;,\r\n                        &quot;com.docker.compose.oneoff&quot;: &quot;False&quot;,\r\n                        &quot;com.docker.compose.project&quot;: &quot;docker-compose&quot;,\r\n                        &quot;com.docker.compose.project.config_files&quot;: &quot;/appl/docker-compose/docker-compose-init.yml&quot;,\r\n                        &quot;com.docker.compose.project.working_dir&quot;: &quot;/appl/docker-compose&quot;,\r\n                        &quot;com.docker.compose.service&quot;: &quot;prometheus&quot;,\r\n                        &quot;com.docker.compose.version&quot;: &quot;1.29.2&quot;,\r\n                        &quot;maintainer&quot;: &quot;The Prometheus Authors &lt;prometheus-developers@googlegroups.com&gt;&quot;\r\n                    },\r\n                    &quot;networks&quot;: {\r\n                        &quot;docker-compose_homeserver-net&quot;: {\r\n                            &quot;IPAddress&quot;: &quot;172.20.0.5&quot;,\r\n                            &quot;IPPrefixLen&quot;: 16,\r\n                            &quot;aliases&quot;: [\r\n                                &quot;04f346e6694f&quot;,\r\n                                &quot;prometheus&quot;\r\n                            ],\r\n                            &quot;globalIPv6&quot;: &quot;&quot;,\r\n                            &quot;globalIPv6PrefixLen&quot;: 0,\r\n                            &quot;links&quot;: null,\r\n                            &quot;macAddress&quot;: &quot;02:42:ac:14:00:05&quot;\r\n                        }\r\n                    },\r\n                    &quot;state&quot;: {\r\n                        &quot;running&quot;: true,\r\n                        &quot;status&quot;: &quot;running&quot;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nAnd I need an output similar to\r\n\r\n```yaml \r\n- docker-compose_grafana_1\r\n- docker-compose_node-red_1\r\n- docker-compose_organizr_1\r\n- docker-compose_prometheus_1\r\n```\r\n\r\nI can do that with jq easy-peasy: \r\n```shell\r\njq --raw-output &#39;.docker_compose_init_result.services\\[\\] | keys | .\\[\\]&#39; jsondata.json\r\n```\r\n\r\nBut I am not able to do it with Ansible and especially `json_query` (and thus JMESPath).\r\n\r\nI was able to get one key with \r\n```shell\r\njp -f jsondata.json &quot;keys(docker_compose_init_result.services.grafana)&quot;\r\n```\r\n\r\n```json\r\n[ \r\n  &quot;docker-compose_grafana_1&quot;\r\n]\r\n```\r\n\r\nBut have no idea how to get all four. Also sometimes expressions that worked with jp did not work in Ansible with `json_query`, which additionally made me mad.\r\n\r\nIf anyone can give me a solution for this (wether its with `json_query` or not) in the best case explains how it works, I would be very glad.",
        "link": "https://stackoverflow.com/questions/74339143/getting-the-values-of-keys-of-ansible-json-output",
        "title": "Getting the values of keys of Ansible JSON output"
    },
    {
        "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": 1667805112,
                "post_id": 74342977,
                "comment_id": 131246067,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1667806529,
        "creation_date": 1667804555,
        "last_edit_date": 1667806529,
        "question_id": 74342977,
        "body_markdown": "I have a large JSON file (2.7gb) that I would like filter for only the data I&#39;m interested in to make the file smaller. The data consists of an array of objects. The following query works on a small subset of the JSON file, but when I try to run it on the 2.7gb file it doesn&#39;t work. How can I convert this into a stream query so that it can process the entire file?\r\n\r\n\r\n```\r\n.[] | {\r\n    food: .foodClass,\r\n    description: .description,\r\n    foodNutrients: [.foodNutrients[] | { nutrients: .nutrient, amount: .amount}],\r\n    upc: .gtinUpc,\r\n    servingSize: .servingSize,\r\n    servingSizeUnit: .servingSizeUnit,\r\n    ingredients: .ingredients,\r\n    fdcId: .fdcId,\r\n    dataType: .dataType,\r\n    brandOwner: .brandOwner,\r\n    marketCountry: .marketCountry,\r\n    brandedFootCategory: .brandedFoodCategory\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74342977/converting-query-on-large-json-file-to-use-a-stream-jq",
        "title": "Converting query on large JSON file to use a stream - jq"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1667814229,
                "post_id": 74343931,
                "comment_id": 131248821,
                "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": 1,
                "creation_date": 1667831321,
                "post_id": 74343931,
                "comment_id": 131254940,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667842401,
                "post_id": 74343931,
                "comment_id": 131259214,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667898737,
                "post_id": 74343931,
                "comment_id": 131271602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667816057,
                "creation_date": 1667816057,
                "answer_id": 74344940,
                "question_id": 74343931,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can select all `domains` where `adminLock == 1` of the inner array with this code:\r\n\r\n\r\n```bash\r\njq -r &#39;.data.data[] | select(.adminLock == 1) | .domains&#39; &quot;$INPUT&quot;\r\n```\r\n\r\n**Output**\r\n```text\r\nxxx2.com\r\nxxx4.com\r\n```",
                "title": "bash shell JSON JQ if adminLock =1 Take the median &quot;domains&quot;, how do I write"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1667988131,
        "creation_date": 1667810842,
        "last_edit_date": 1667988131,
        "question_id": 74343931,
        "body_markdown": "if `adminLock = 1` Take the median &quot;domains&quot;, how do I write \r\n```\r\n{\r\n  &quot;code&quot;: 0,\r\n  &quot;message&quot;: &quot;成功&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;recordCount&quot;: &quot;128&quot;,\r\n    &quot;pageSize&quot;: 100,\r\n    &quot;page&quot;: 1,\r\n    &quot;pageCount&quot;: 2,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;domainsID&quot;: &quot;173652434&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx1.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 0,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173652434&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx2.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 1,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173205836&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx3.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 0,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173205812&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx4.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 1,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;nextPage&quot;: 2\r\n  }\r\n}\r\n```\r\n\r\n\r\n\r\nI hope to get your help, because I really need it, and the complete crawling code. I am good at using Bash Shell,jq -r code\r\n\r\n---\r\n\r\n**I want to take the value xxx1.com, groupid combination into an array, how should I do\r\nWant to get such a result**\r\n\r\n    now_array=([&quot;173652434&quot;]=&quot;xxx2.com&quot; [&quot;173205812&quot;]=&quot;xxx4.com&quot;)\r\nHow should I do thank you",
        "link": "https://stackoverflow.com/questions/74343931/bash-shell-json-jq-if-adminlock-1-take-the-median-domains-how-do-i-write",
        "title": "bash shell JSON JQ if adminLock =1 Take the median &quot;domains&quot;, how do I write"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1667838515,
                "creation_date": 1667838515,
                "answer_id": 74349824,
                "question_id": 74349759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Outside of strings, your jq filter may have line breaks as you see fit. As for the strings, you can piece the single parts together using `+`:\r\n~~~sh\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;,&quot;boo&quot;:&quot;moo&quot;}&#39; | jq -r &#39;\r\n  &quot;\\(.foo)|&quot; +\r\n  &quot;\\(.boo)&quot;\r\n&#39;\r\n~~~\r\n~~~\r\nbar|moo\r\n~~~\r\n[Demo](https://jqplay.org/s/Tpz5-IWPLOD)\r\n",
                "title": "jq string interpolation with line breaks"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667863136,
                "last_edit_date": 1667863136,
                "creation_date": 1667848832,
                "answer_id": 74351856,
                "question_id": 74349759,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might also wish to consider programmatic approaches, e.g.\r\n```\r\n  map_values( &quot;\\(.)&quot; )\r\n  | join(&quot;|&quot;)\r\n```\r\nor if you need to be picky about which keys to include, you could begin with:\r\n```\r\n  [with_entries(.value |= &quot;\\(.)&quot;)[]]\r\n  | join(&quot;|&quot;)\r\n```\r\nor\r\n\r\n```\r\n  . as $in\r\n  | reduce keys_unsorted[] as $k (&quot;&quot;; . + &quot;\\($in[$k])|&quot; )\r\n  | sub(&quot;[|]$&quot;; &quot;&quot;)\r\n```\r\n\r\nor:\r\n```\r\n  . as $in\r\n  | keys_unsorted as $keys\r\n  | [ &quot;\\(.[$keys[0]])&quot;,\r\n      ($keys[1:][] | &quot;|\\($in[.])&quot; )] \r\n  | add\r\n```",
                "title": "jq string interpolation with line breaks"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1667863136,
        "creation_date": 1667838266,
        "question_id": 74349759,
        "body_markdown": "I have this expression:\r\n```\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;,&quot;boo&quot;:&quot;moo&quot;}&#39; | jq -r &#39;&quot;\\(.foo)|\\(.boo)&quot;&#39;\r\nbar|moo\r\n```\r\n\r\nNow, imagine that the filter is long, so I would like to break it into separate lines for readability while still producing the same output, conceptually like this:\r\n```\r\njq &#39;&quot;\r\n\\(.foo)|\r\n\\(.boo)\r\n&quot;&#39;\r\n```\r\n\r\nThis however is not valid. How to do this?",
        "link": "https://stackoverflow.com/questions/74349759/jq-string-interpolation-with-line-breaks",
        "title": "jq string interpolation with line breaks"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667898787,
                "post_id": 74354631,
                "comment_id": 131271620,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6767185,
                    "reputation": 18202,
                    "user_id": 5211833,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/Pyme2.jpg?s=256",
                    "display_name": "Adriaan",
                    "link": "https://stackoverflow.com/users/5211833/adriaan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1667976096,
                "post_id": 74354631,
                "comment_id": 131293389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667871269,
                "last_edit_date": 1667871269,
                "creation_date": 1667870968,
                "answer_id": 74354750,
                "question_id": 74354631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m not sure if I understand your question correctly, but here&#39;s how to use jq to filter that JSON according to afield value, then format it to create an associative array in Bash:\r\n~~~sh\r\n$ declare -A now_array=&quot;($(jq -r &#39;\r\n    .data.data[] | select(.adminLock == 1) | @sh &quot;[\\(.domainsID)]=\\(.domains)&quot;\r\n  &#39; input.json))&quot;\r\n\r\n$ echo &quot;${now_array[&quot;173205812&quot;]}&quot;\r\nxxx4.com\r\n\r\n$ declare -p now_array\r\ndeclare -A now_array=([173652434]=&quot;xxx2.com&quot; [173205812]=&quot;xxx4.com&quot; )\r\n~~~",
                "title": "if adminLock = 1 take the median &quot;domains&quot;, how do I write, in the stitching array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1667871269,
        "creation_date": 1667869667,
        "question_id": 74354631,
        "body_markdown": "**I want to take the value xxx1.com, the group value of the group into an array, how should I do want to get such a result**\r\n\r\n`{\r\n  &quot;code&quot;: 0,\r\n  &quot;message&quot;: &quot;成功&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;recordCount&quot;: &quot;128&quot;,\r\n    &quot;pageSize&quot;: 100,\r\n    &quot;page&quot;: 1,\r\n    &quot;pageCount&quot;: 2,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;domainsID&quot;: &quot;173652434&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx1.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 0,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173652434&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx2.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 1,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173205836&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx3.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 0,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;domainsID&quot;: &quot;173205812&quot;,\r\n        &quot;nsGroupID&quot;: &quot;199&quot;,\r\n        &quot;groupID&quot;: &quot;78987&quot;,\r\n        &quot;domains&quot;: &quot;xxx4.com&quot;,\r\n        &quot;state&quot;: 3,\r\n        &quot;userLock&quot;: 0,\r\n        &quot;adminLock&quot;: 1,\r\n        &quot;view_type&quot;: &quot;1&quot;\r\n      }\r\n    ],\r\n    &quot;nextPage&quot;: 2\r\n  }\r\n}`\r\n\r\n\r\nI hope to get your help, because I really need it, and the complete crawling code. I am good at using Bash Shell,jq -r code\r\n`\r\nnow_array=([&quot;173652434&quot;]=&quot;xxx2.com&quot; [&quot;173205812&quot;]=&quot;xxx4.com&quot;)\r\n`\r\nThe result I want is like this",
        "link": "https://stackoverflow.com/questions/74354631/if-adminlock-1-take-the-median-domains-how-do-i-write-in-the-stitching-arr",
        "title": "if adminLock = 1 take the median &quot;domains&quot;, how do I write, in the stitching array"
    },
    {
        "tags": [
            "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": 2,
                "creation_date": 1667893280,
                "post_id": 74357065,
                "comment_id": 131269804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26554427,
                    "reputation": 39,
                    "user_id": 20183264,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0aKDxBTwBBdFeEgWlZ_nPqUU2LljEbkwXTDkH3Yg=k-s256",
                    "display_name": "shepi",
                    "link": "https://stackoverflow.com/users/20183264/shepi"
                },
                "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": 1667894693,
                "post_id": 74357065,
                "comment_id": 131270200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1667895187,
                "post_id": 74357065,
                "comment_id": 131270359,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667937290,
                "last_edit_date": 1667937290,
                "creation_date": 1667905869,
                "answer_id": 74359752,
                "question_id": 74357065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An efficient approach that avoids the need to slurp is to use the general utility:\r\n\r\n    def count(s): reduce s as $_ (0; .+1);\r\n\r\nWith this, you can use your filter using jq&#39;s -n option instead of the -s option:\r\n\r\n    count(inputs | select(.orderNumber==2346999 and .workStep==110) | .good)\r\n\r\n---\r\n\r\nNotice that the leading `.` in your filter is unnecessary.",
                "title": "How to sum values from object json jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1667906025,
                "creation_date": 1667906025,
                "answer_id": 74359790,
                "question_id": 74357065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple approach using `add` to get the `sum` of the numbers. \r\n\r\nUse `map()` with `--slurp` to create an array with just the `.good` and apply `add`:\r\n\r\n```none\r\nmap(select(.orderNumber==2346999 and .workStep==110).good) | add\r\n```\r\n\r\nGives: `16`\r\n\r\n\r\n----------\r\n\r\n\r\n#### [Online demo](https://jqplay.org/s/6vQ2qrVc4wC)",
                "title": "How to sum values from object json jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667937290,
        "creation_date": 1667892567,
        "last_edit_date": 1667895628,
        "question_id": 74357065,
        "body_markdown": "How can I sum values from json object with jq\r\n\r\n**Example input JSON object**\r\n\r\n```json\r\n{\r\n  &quot;orderNumber&quot;: 2346999,\r\n  &quot;workStep&quot;: 110,\r\n  &quot;good&quot;: 8,\r\n  &quot;bad&quot;: 0,\r\n  &quot;type&quot;: &quot;1&quot;,\r\n  &quot;date&quot;: &quot;2022-11-08T07:17:09&quot;,\r\n  &quot;time&quot;: 0,\r\n  &quot;result&quot;: 1\r\n}\r\n{\r\n  &quot;orderNumber&quot;: 2346999,\r\n  &quot;workStep&quot;: 110,\r\n  &quot;good&quot;: 8,\r\n  &quot;bad&quot;: 0,\r\n  &quot;type&quot;: &quot;1&quot;,\r\n  &quot;date&quot;: &quot;2022-11-08T07:26:57&quot;,\r\n  &quot;time&quot;: 0,\r\n  &quot;result&quot;: 1\r\n}\r\n```\r\n\r\n**jq condition**\r\n\r\n`. | select(.orderNumber==2346999 and .workStep==110) | .good`\r\n\r\n**result**\r\n\r\n8\r\n8\r\n\r\n**and I liketo have**\r\n\r\n16\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74357065/how-to-sum-values-from-object-json-jq",
        "title": "How to sum values from object json jq"
    },
    {
        "tags": [
            "php",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667902588,
                "creation_date": 1667902588,
                "answer_id": 74359053,
                "question_id": 74359009,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can split the path string by the dots to get a path array, which you can use with `getpath`:\r\n~~~sh\r\njq -r &#39;&quot;a.b&quot; as $key | getpath($key / &quot;.&quot;)&#39;\r\n~~~\r\n~~~\r\naaa\r\n~~~\r\n[Demo](https://jqplay.org/s/PbLp_HWRO1I)\r\n\r\nNote that this works for object fields. If you want it to also work with array indices, you&#39;d need to convert digits to numbers (using `tonumber`), and come up with a solution how to disambiguate field names that only consist of (stringified) numbers.",
                "title": "Use json path as string variable in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668005386,
        "creation_date": 1667902396,
        "last_edit_date": 1668005386,
        "question_id": 74359009,
        "body_markdown": "I have a tiny example:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: &quot;aaa&quot;,\r\n    &quot;c&quot;: &quot;&quot;\r\n  },\r\n  &quot;d&quot;: &quot;bbb&quot;\r\n}\r\n```\r\n\r\nAnd I trying to get the value from `a.b` and this json path is from string.\r\n\r\nI am trying to do as:\r\n\r\n```console\r\n$ echo &#39;{&quot;a&quot;: {&quot;b&quot;: &quot;aaa&quot;, &quot;c&quot;: &quot;&quot;}, &quot;d&quot;: &quot;bbb&quot;}&#39;  | jq &#39;&quot;a.b&quot; as $key | .[$key]&#39;\r\nnull\r\n```\r\n\r\nI don&#39;t know how to.",
        "link": "https://stackoverflow.com/questions/74359009/use-json-path-as-string-variable-in-jq",
        "title": "Use json path as string variable in jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667940220,
                "post_id": 74366843,
                "comment_id": 131287147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667940231,
                "post_id": 74366843,
                "comment_id": 131287153,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1667939987,
                "creation_date": 1667939987,
                "answer_id": 74366918,
                "question_id": 74366843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `input_filename` (and `rtrimstr` to remove the extension):\r\n~~~sh\r\njq &#39;.[input_filename | rtrimstr(&quot;.json&quot;)] = {}&#39; test.json\r\n~~~\r\n\r\nUsing `--arg` and a variable initialized from outside:\r\n~~~sh\r\njq --arg fn &quot;test&quot; &#39;.[$fn] = {}&#39; test.json \r\n~~~\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;test&quot;: {}\r\n}\r\n~~~",
                "title": "how to properly pass arguments to jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1667940051,
                "creation_date": 1667940051,
                "answer_id": 74366927,
                "question_id": 74366843,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t quote them. Things in double quotes are strings. Also make sure your command substitution surrounds the correct expression and avoid useless use of cat. Still (double) quote your shell variables (single quotes prevent expansion).\r\n\r\n```\r\noutput=&quot;$(jq --arg fn &quot;$file_name&quot; &#39;. += {$fn: {}}&#39; $file)&quot;\r\n```\r\n\r\nor even:\r\n\r\n```\r\noutput=&quot;$(jq --arg fn &quot;$file_name&quot; &#39;.[$fn] = {}&#39;)&quot;\r\n```\r\n\r\nThe above assumes that your input file contains more than an empty object. Because if not, then you could simply do `jq -n --arg fn &quot;$file_name&quot; &#39;{$fn:{}}&#39;` without any input or `printf &#39;%s&#39; &quot;$file_name&quot; | jq &#39;{(.): {}}&#39;`",
                "title": "how to properly pass arguments to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1667943961,
        "creation_date": 1667939595,
        "last_edit_date": 1667943961,
        "question_id": 74366843,
        "body_markdown": "I&#39;m trying to add a json file&#39;s name as a key to the file structure itself. For example:\r\n\r\nInput:\r\n\r\n```\r\ntest.json \r\n{}\r\n```\r\n\r\nOutput:\r\n\r\n```\r\ntest.json\r\n{\r\n    &quot;test&quot;: {}\r\n}\r\n```\r\n\r\nThese are the commands I&#39;m trying:\r\n\r\n```\r\noutput=`cat $file` | jq --arg fn &quot;$file_name&quot; &#39;. += {&quot;$fn&quot; : {}}&#39; \r\n\r\nor\r\n\r\n# file_name already contains file name without extension\r\noutput=`cat $file | jq --argjson k &#39;{&quot;$file_name&quot;: {}}&#39; &#39;. += $k&#39;`\r\n\r\necho &quot;$output&quot; &gt; $file\r\n```\r\n\r\nHowever, the outputs are:\r\n\r\n```\r\ntest.json\r\n{\r\n     &quot;$fn&quot;: {}\r\n}\r\n\r\ntest.json\r\n{\r\n     &quot;$file_name&quot;: {}\r\n}\r\n```\r\n\r\nHow do I make sure `jq` can recognize args as a variable and not a string literal ?",
        "link": "https://stackoverflow.com/questions/74366843/how-to-properly-pass-arguments-to-jq",
        "title": "how to properly pass arguments to jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667968668,
                "post_id": 74369542,
                "comment_id": 131292200,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4635648,
                    "reputation": 11,
                    "user_id": 3756981,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f4f86e4676aea3d9bb9a3c2e4f89273?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Yaemish",
                    "link": "https://stackoverflow.com/users/3756981/yaemish"
                },
                "reply_to_user": {
                    "account_id": 58377,
                    "reputation": 271975,
                    "user_id": 174777,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6PnNW.jpg?s=256",
                    "display_name": "John Rotenstein",
                    "link": "https://stackoverflow.com/users/174777/john-rotenstein"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668648602,
                "post_id": 74369542,
                "comment_id": 131459444,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667968529,
                "creation_date": 1667968529,
                "answer_id": 74369969,
                "question_id": 74369542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would appear that the jq expression you&#39;re looking for is:\r\n\r\n```\r\n[.Snapshots[] | select(.StartTime &lt; &quot;2022-09-08&quot;) | .VolumeSize] | add\r\n```\r\n\r\nWithout an illustrative JSON, however, it&#39;s difficult to test this out; that&#39;s one of the reasons for the [mcve guidelines][1].\r\n\r\n\r\n  [1]: http://stackoverflow.com/help/mcve",
                "title": "AWS CLI filtering with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668194512,
                "creation_date": 1668194512,
                "answer_id": 74407229,
                "question_id": 74369542,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution without jq is this:\r\n\r\n```sh\r\naws ec2 describe-snapshots \\\r\n    --owner-ids self \\\r\n    --query &quot;sum(Snapshots[?StartTime &lt; &#39;2022-11-12&#39;].VolumeSize)&quot;\r\n```\r\n\r\nBut note that the comparison is **not** done &quot;by date&quot; but by literally comparing strings like `2016-11-02T01:25:28.000Z` with `2022-11-12`.",
                "title": "AWS CLI filtering with JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668564661,
        "creation_date": 1667963797,
        "last_edit_date": 1668564661,
        "question_id": 74369542,
        "body_markdown": "I&#39;m still trying to understand how to use JQ to get what I want.  I want to get the size of all snapshots in my account older than a specific date and then add them up so that I can calculate cost.  I am able to do this without the date filtering with this.\r\n\r\n```\r\naws ec2 describe-snapshots --profile my_profile_name | jq &quot;[.Snapshots[].VolumeSize] | add&quot;\r\n```\r\nThis returns a numerical value.  Without JQ, I&#39;m also able to get a list of snapshots using &quot;query&quot; but I don&#39;t think that will be applied when using JQ but I could be wrong.\r\n\r\n```\r\naws ec2 describe-snapshots --profile my_profile_name --owner-ids self --query &quot;Snapshots[?(StartTime&lt;=&#39;2022-09-08&#39;)].[SnapshotId]&quot;\r\n```\r\nI tried various arrangements using &quot;select&quot; along with my first example.  However, I haven&#39;t been able to get anything returned yet.  I appreciate any pointers.\r\n\r\nThis is the &quot;select&quot; that doesn&#39;t quite work.\r\n\r\n```\r\naws ec2 describe-snapshots --profile my_profile_name | jq &quot;[.Snapshots[]select(.StartTime &lt; &quot;2022-09-08&quot;)] | [.Snapshots[].VolumeSize] | add&quot;\r\n```\r\n\r\nEdit 11/15/22\r\n\r\nI was able to make progress and I found a site that allows you to test JQ. The example is able to select strings and numbers, but I&#39;m having trouble with the date part. I don&#39;t understand how to interrupt the date in the format that AWS provides.  I can do the add part, I removed it to simplify the example.\r\n\r\nThis the the working &quot;select&quot; for a string.  I can only do greater/less than when I use numbers and remove the quotes from the JSON section.\r\n\r\n    .Snapshots[] | select(.StartTime == &quot;2022-11-14T23:28:39+00:00&quot;) | .VolumeSize\r\n\r\n\r\n[jq play example][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/b1JtVNpivw7",
        "link": "https://stackoverflow.com/questions/74369542/aws-cli-filtering-with-jq",
        "title": "AWS CLI filtering with JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1369386,
                    "reputation": 495,
                    "user_id": 1305062,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ed447178be0c300d51c89837e5d3e6df?s=256&d=identicon&r=PG",
                    "display_name": "toni",
                    "link": "https://stackoverflow.com/users/1305062/toni"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1667980156,
                "post_id": 74371182,
                "comment_id": 131294373,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1667980502,
                "last_edit_date": 1667980502,
                "creation_date": 1667978831,
                "answer_id": 74371254,
                "question_id": 74371182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a straightforward solution to the problem as stated, courtesy of `..`:\r\n```\r\ndef children: objects | select(has(&quot;children&quot;)) | .children[].name;\r\nmap( {(.name) : [..|children]} ) | add\r\n```\r\n\r\nPlease note, though, that the output you show as being expected does not seem to correspond exactly to the stated requirements.\r\n\r\n---\r\n### Output\r\n\r\nHere&#39;s the output produced by the mini-program when run against the sample:\r\n```\r\n{\r\n  &quot;Architektur&quot;: [],\r\n  &quot;Computer&quot;: [\r\n    &quot;Icon&quot;,\r\n    &quot;Pattern&quot;,\r\n    &quot;Button&quot;,\r\n    &quot;gr&#252;n&quot;,\r\n    &quot;braun&quot;\r\n  ],\r\n  &quot;Fahrzeug&quot;: [],\r\n  &quot;Kamera&quot;: [\r\n    &quot;Histogramm&quot;,\r\n    &quot;Wei&#223;ableich&quot;,\r\n    &quot;Sensor&quot;,\r\n    &quot;Auto&quot;,\r\n    &quot;Sonne&quot;,\r\n    &quot;Bew&#246;lkt&quot;,\r\n    &quot;Am Tag&quot;,\r\n    &quot;In der Nacht&quot;\r\n  ]\r\n}\r\n```",
                "title": "jq find all nested children names and flatten json depth"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1667983896,
                "creation_date": 1667983896,
                "answer_id": 74372133,
                "question_id": 74371182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gives exactly the output stated (without &quot;Button&quot; in &quot;Computer&quot; section)\r\n\r\n```\r\njq &#39;\r\ndef get_values:\r\n    if has(&quot;children&quot;) then (.children[]? | get_values) else .name end;\r\nmap({name,value:[.children[]? | get_values]}) | from_entries\r\n&#39; input.json\r\n```",
                "title": "jq find all nested children names and flatten json depth"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1667983896,
        "creation_date": 1667978370,
        "last_edit_date": 1667980119,
        "question_id": 74371182,
        "body_markdown": "I&#39;ve a json looking like\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;Architektur&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Computer&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Icon&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Pattern&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Button&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;gr&#252;n&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;braun&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Fahrzeug&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Kamera&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Histogramm&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Wei&#223;ableich&quot;,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;Auto&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;Sonne&quot;\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;Bew&#246;lkt&quot;,\r\n                &quot;children&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;Am Tag&quot;\r\n                  },\r\n                  {\r\n                    &quot;name&quot;: &quot;In der Nacht&quot;\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Sensor&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI would now need to get the first level *name* (f.e. Computer) as parent and search for all children names of any depth (f.e. Icon, Pattern). Those child names should be added as array to the first level parent value. If there are no children at all (f.e. Architektur) the array should stay empty. This is what it should look like:\r\n\r\n    {\r\n     &quot;Architektur&quot;: [],\r\n     &quot;Computer&quot;: [&quot;Icon&quot;, &quot;Pattern&quot;, &quot;gr&#252;n&quot;, &quot;braun&quot;],\r\n     &quot;Fahrzeug&quot;: [],\r\n     &quot;Kamera&quot;: [&quot;Histogramm&quot;,&quot;Auto&quot;, &quot;Sonne&quot;, &quot;Am Tag&quot;, &quot;In der Nacht&quot;],\r\n     &quot;Sensor&quot;: []\r\n    }\r\n\r\nUnfortunately with jq I could not arrive to somewhere useful, (Missing knowledge), but before diving in python I would like to ask if this is possible?\r\n",
        "link": "https://stackoverflow.com/questions/74371182/jq-find-all-nested-children-names-and-flatten-json-depth",
        "title": "jq find all nested children names and flatten json depth"
    },
    {
        "tags": [
            "arrays",
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1667998699,
                "last_edit_date": 1667998699,
                "creation_date": 1667982634,
                "answer_id": 74371878,
                "question_id": 74371420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This JSON is a bit strange because the information is stored position-based in an array instead of an object.\r\nUsing the first element of an array (&quot;vevent&quot;) to identify its contents is not the best practice.\r\n\r\nBut anyway ... if this is the data source you are dealing with, this code should help you.\r\n\r\n```jq\r\njq -r &#39;..\r\n       | arrays\r\n       | select(.[0] == &quot;vevent&quot;)[1]\r\n       | [\r\n           (.[] | select(.[0] == &quot;dtstart&quot;) | .[3]),\r\n           (.[] | select(.[0] == &quot;dtend&quot;) | .[3]),\r\n           (.[] | select(.[0] == &quot;description&quot;) | .[3])\r\n         ]\r\n       | @csv\r\n      &#39;\r\n```\r\n\r\nAlternatively, the repeating code can be transferred into a function\r\n```jq\r\njq -r &#39;def getField($name; $idx): .[] | select(.[0] == $name) | .[$idx];\r\n       ..\r\n       | arrays\r\n       | select(.[0] == &quot;vevent&quot;)[1]\r\n       | [ getField(&quot;dtstart&quot;; 3), getField(&quot;dtend&quot;; 3), getField(&quot;description&quot;; 3) ]\r\n       | @csv\r\n      &#39;\r\n```\r\n\r\n**Output**\r\n```json\r\n&quot;2015-02-18T10:58:12Z&quot;,&quot;2015-02-18T10:58:44Z&quot;,&quot;Phone call to +49xxxxxxxxxx lasted for 0 seconds.&quot;\r\n&quot;2015-01-09T17:23:16Z&quot;,&quot;2015-01-09T17:24:19Z&quot;,&quot;Phone call to +1xxxxxxxxxx lasted for 39 seconds.&quot;\r\n```\r\n\r\n---------\r\nYou can also extract phone number and duration with the help of regular expressions in `jq`:\r\n\r\n```jq\r\njq -r &#39;def getField($name; $idx): .[] | select(.[0] == $name) | .[$idx];\r\n       ..\r\n       | arrays\r\n       | select(.[0] == &quot;vevent&quot;)[1]\r\n       | [\r\n           getField(&quot;dtstart&quot;; 3),\r\n           getField(&quot;dtend&quot;; 3),\r\n           (getField(&quot;description&quot;; 3) | match(&quot;call to ([^ ]*)&quot;) | .captures[0].string),\r\n           (getField(&quot;description&quot;; 3) | match(&quot;(\\\\d+) seconds&quot;)  | .captures[0].string)\r\n         ]\r\n       | @csv\r\n      &#39;\r\n```\r\n\r\n**Output**\r\n```json\r\n&quot;2015-02-18T10:58:12Z&quot;,&quot;2015-02-18T10:58:44Z&quot;,&quot;+49xxxxxxxxxx&quot;,&quot;0&quot;\r\n&quot;2015-01-09T17:23:16Z&quot;,&quot;2015-01-09T17:24:19Z&quot;,&quot;+1xxxxxxxxxx&quot;,&quot;39&quot;\r\n```\r\n",
                "title": "How to filter jCal with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1746683583,
                "last_edit_date": 1746683583,
                "creation_date": 1668026581,
                "answer_id": 74381163,
                "question_id": 74371420,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not the most efficient solution, but quite understandable by first building an object out of key-value pairs and then filtering and transforming those.\r\n\r\n`.[2][][1]` is a stream of events encoded as arrays.\r\n\r\nWhich means that:\r\n\r\n```\r\n.[2][][1]\r\n  | map({key:.[0], value:.[3]})\r\n  | from_entries\r\n```\r\n\r\ngives you a stream of objects; one object per event:\r\n\r\n```json\r\n{\r\n  &quot;dtstamp&quot;: &quot;2015-04-05T16:42:10Z&quot;,\r\n  &quot;created&quot;: &quot;2015-02-18T16:44:04Z&quot;,\r\n  &quot;uid&quot;: &quot;9b23142b-8d86-3e17-2f44-2bed65b2e471&quot;,\r\n  &quot;last-modified&quot;: &quot;2015-04-05T16:42:10Z&quot;,\r\n  &quot;description&quot;: &quot;Phone call to +49xxxxxxxxxx lasted for 0 seconds.&quot;,\r\n  &quot;summary&quot;: &quot;Outgoing: +49xxxxxxx&quot;,\r\n  &quot;dtstart&quot;: &quot;2015-02-18T10:58:12Z&quot;,\r\n  &quot;dtend&quot;: &quot;2015-02-18T10:58:44Z&quot;,\r\n  &quot;transp&quot;: &quot;OPAQUE&quot;\r\n}\r\n{\r\n  &quot;dtstamp&quot;: &quot;2015-04-05T16:42:10Z&quot;,\r\n  &quot;created&quot;: &quot;2015-01-09T19:12:05Z&quot;,\r\n  &quot;uid&quot;: &quot;c337e092-a012-5f5a-497f-932fbc6159e5&quot;,\r\n  &quot;last-modified&quot;: &quot;2015-04-05T16:42:10Z&quot;,\r\n  &quot;description&quot;: &quot;Phone call to +1xxxxxxxxxx lasted for 39 seconds.&quot;,\r\n  &quot;summary&quot;: &quot;Outgoing: +1xxxxxxxxxx&quot;,\r\n  &quot;dtstart&quot;: &quot;2015-01-09T17:23:16Z&quot;,\r\n  &quot;dtend&quot;: &quot;2015-01-09T17:24:19Z&quot;,\r\n  &quot;transp&quot;: &quot;OPAQUE&quot;\r\n}\r\n```\r\n\r\nNow plug that into the final program: `select` the wanted objects, add CSV headers, build the rows, and ultimately convert to CSV:\r\n\r\n```\r\n[&quot;start&quot;, &quot;end&quot;, &quot;description&quot;],\r\n(\r\n  .[2][][1]\r\n  | map({key:.[0], value:.[3]})\r\n  | from_entries\r\n  | select(.created | startswith(&quot;2015-01&quot;))\r\n  | [.dtstart, .dtend, .description]\r\n)\r\n| @csv\r\n```\r\n\r\nRaw output (`-r`):\r\n\r\n```csv\r\n&quot;start&quot;,&quot;end&quot;,&quot;description&quot;\r\n&quot;2015-01-09T17:23:16Z&quot;,&quot;2015-01-09T17:24:19Z&quot;,&quot;Phone call to +1xxxxxxxxxx lasted for 39 seconds.&quot;\r\n```\r\n\r\nIf you need to further transform `.description`, you can use `split` or [`capture`](https://stedolan.github.io/jq/manual/v1.6/#capture\\(val\\),capture\\(regex;flags\\)) or use a different property, such as `.summary`, in your CSV rows. Only a single line needs to be changed.",
                "title": "How to filter jCal with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1746683597,
        "creation_date": 1667979937,
        "last_edit_date": 1746683597,
        "question_id": 74371420,
        "body_markdown": "I have a jCal JSON array which I&#39;d like to filter with jq. JSON arrays are somewhat new to me and I have been banging my head to the wall on this for hours...\r\n\r\nThe file looks like this:\r\n\r\n```json\r\n[\r\n  &quot;vcalendar&quot;,\r\n  [\r\n    [\r\n      &quot;calscale&quot;,\r\n      {},\r\n      &quot;text&quot;,\r\n      &quot;GREGORIAN&quot;\r\n    ],\r\n    [\r\n      &quot;version&quot;,\r\n      {},\r\n      &quot;text&quot;,\r\n      &quot;2.0&quot;\r\n    ],\r\n    [\r\n      &quot;prodid&quot;,\r\n      {},\r\n      &quot;text&quot;,\r\n      &quot;-//SabreDAV//SabreDAV//EN&quot;\r\n    ],\r\n    [\r\n      &quot;x-wr-calname&quot;,\r\n      {},\r\n      &quot;unknown&quot;,\r\n      &quot;Call log private&quot;\r\n    ],\r\n    [\r\n      &quot;x-apple-calendar-color&quot;,\r\n      {},\r\n      &quot;unknown&quot;,\r\n      &quot;#ffaa00&quot;\r\n    ],\r\n    [\r\n      &quot;refresh-interval&quot;,\r\n      {},\r\n      &quot;duration&quot;,\r\n      &quot;PT4H&quot;\r\n    ],\r\n    [\r\n      &quot;x-published-ttl&quot;,\r\n      {},\r\n      &quot;unknown&quot;,\r\n      &quot;PT4H&quot;\r\n    ]\r\n  ],\r\n  [\r\n    [\r\n      &quot;vevent&quot;,\r\n      [\r\n        [\r\n          &quot;dtstamp&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-04-05T16:42:10Z&quot;\r\n        ],\r\n        [\r\n          &quot;created&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-02-18T16:44:04Z&quot;\r\n        ],\r\n        [\r\n          &quot;uid&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;9b23142b-8d86-3e17-2f44-2bed65b2e471&quot;\r\n        ],\r\n        [\r\n          &quot;last-modified&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-04-05T16:42:10Z&quot;\r\n        ],\r\n        [\r\n          &quot;description&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;Phone call to +49xxxxxxxxxx lasted for 0 seconds.&quot;\r\n        ],\r\n        [\r\n          &quot;summary&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;Outgoing: +49xxxxxxx&quot;\r\n        ],\r\n        [\r\n          &quot;dtstart&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-02-18T10:58:12Z&quot;\r\n        ],\r\n        [\r\n          &quot;dtend&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-02-18T10:58:44Z&quot;\r\n        ],\r\n        [\r\n          &quot;transp&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;OPAQUE&quot;\r\n        ]\r\n      ],\r\n      []\r\n    ],\r\n    [\r\n      &quot;vevent&quot;,\r\n      [\r\n        [\r\n          &quot;dtstamp&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-04-05T16:42:10Z&quot;\r\n        ],\r\n        [\r\n          &quot;created&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-01-09T19:12:05Z&quot;\r\n        ],\r\n        [\r\n          &quot;uid&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;c337e092-a012-5f5a-497f-932fbc6159e5&quot;\r\n        ],\r\n        [\r\n          &quot;last-modified&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-04-05T16:42:10Z&quot;\r\n        ],\r\n        [\r\n          &quot;description&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;Phone call to +1xxxxxxxxxx lasted for 39 seconds.&quot;\r\n        ],\r\n        [\r\n          &quot;summary&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;Outgoing: +1xxxxxxxxxx&quot;\r\n        ],\r\n        [\r\n          &quot;dtstart&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-01-09T17:23:16Z&quot;\r\n        ],\r\n        [\r\n          &quot;dtend&quot;,\r\n          {},\r\n          &quot;date-time&quot;,\r\n          &quot;2015-01-09T17:24:19Z&quot;\r\n        ],\r\n        [\r\n          &quot;transp&quot;,\r\n          {},\r\n          &quot;text&quot;,\r\n          &quot;OPAQUE&quot;\r\n        ]\r\n      ],\r\n      []\r\n    ],\r\n  ]\r\n]\r\n```\r\n\r\nI would like to filter out dtstart, dtend, the target phone number and the connection duration from the description for each vevent which was created e.g. in January 2019 (&quot;2019-01.*&quot;) and output them as a CSV.\r\n",
        "link": "https://stackoverflow.com/questions/74371420/how-to-filter-jcal-with-jq",
        "title": "How to filter jCal with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26805685,
                    "reputation": 3,
                    "user_id": 20397035,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu15TI2VqqBKncU7WybK5QXNGxJtNtJzn7X2u-r7=k-s256",
                    "display_name": "bravo",
                    "link": "https://stackoverflow.com/users/20397035/bravo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668019126,
                "post_id": 74375954,
                "comment_id": 131308494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668003946,
                "creation_date": 1668003946,
                "answer_id": 74376455,
                "question_id": 74375954,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one straightforward way using `with_entries`, which lets you manipulate the `.key` and `.value` fields for each item. Here, we store (iterate over) the items of the `.status.items` array in a variable, and piece together all the fields needed, either from the current `.value` (context) or from the current `$item` (variable).\r\n\r\n~~~sh\r\nwith_entries(\r\n  .value.status.items[] as $item\r\n  | .key += &quot;.\\($item.id)&quot;\r\n  | .value |= {\r\n      name: .status.name,\r\n      state: .status.link.state,\r\n      url: &quot;/link/\\(.status.name)/&quot;,\r\n      item: $item.id,\r\n      item_state: $item.state,\r\n      item_url: &quot;/link/\\(.status.name)/items/\\($item.id)/&quot;,\r\n      log: $item.log\r\n  }\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;realtime.0&quot;: {\r\n    &quot;name&quot;: &quot;realtime&quot;,\r\n    &quot;state&quot;: &quot;RUNNING&quot;,\r\n    &quot;url&quot;: &quot;/link/realtime/&quot;,\r\n    &quot;item&quot;: 0,\r\n    &quot;item_state&quot;: &quot;RUNNING&quot;,\r\n    &quot;item_url&quot;: &quot;/link/realtime/items/0/&quot;,\r\n    &quot;log&quot;: null\r\n  },\r\n  &quot;realtime.1&quot;: {\r\n    &quot;name&quot;: &quot;realtime&quot;,\r\n    &quot;state&quot;: &quot;RUNNING&quot;,\r\n    &quot;url&quot;: &quot;/link/realtime/&quot;,\r\n    &quot;item&quot;: 1,\r\n    &quot;item_state&quot;: &quot;STOPPED&quot;,\r\n    &quot;item_url&quot;: &quot;/link/realtime/items/1/&quot;,\r\n    &quot;log&quot;: null\r\n  },\r\n  &quot;cmx.0&quot;: {\r\n    &quot;name&quot;: &quot;cmx&quot;,\r\n    &quot;state&quot;: &quot;RUNNING&quot;,\r\n    &quot;url&quot;: &quot;/link/cmx/&quot;,\r\n    &quot;item&quot;: 0,\r\n    &quot;item_state&quot;: &quot;FAILED&quot;,\r\n    &quot;item_url&quot;: &quot;/link/cmx/items/0/&quot;,\r\n    &quot;log&quot;: &quot;ErrorMsg&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/PN9eWhcgouf)",
                "title": "JSON transformation -jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668026721,
        "creation_date": 1668001942,
        "last_edit_date": 1668026721,
        "question_id": 74375954,
        "body_markdown": "I am looking to transform a json response from an API call. I came across &#39;jq&#39; and experimented with it, but it kept getting out of hand; was unable to get the desired output.\r\n\r\n**Sample Input JSON:**\r\n\r\n```\r\n{\r\n\t&quot;realtime&quot;: {\r\n\t\t&quot;status&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;realtime&quot;,\r\n\t\t\t&quot;link&quot;: {\r\n\t\t\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t\t\t&quot;link_id&quot;: &quot;09-1&quot;\r\n\t\t\t},\r\n\t\t\t&quot;items&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;id&quot;: 0,\r\n\t\t\t\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t\t\t\t&quot;link_id&quot;: &quot;09-1&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;id&quot;: 1,\r\n\t\t\t\t\t&quot;state&quot;: &quot;STOPPED&quot;,\r\n\t\t\t\t\t&quot;link_id&quot;: &quot;09-1&quot;\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;doc&quot;: &quot;origin&quot;\r\n\t\t}\r\n\t},\r\n\t&quot;cmx&quot;: {\r\n\t\t&quot;status&quot;: {\r\n\t\t\t&quot;name&quot;: &quot;cmx&quot;,\r\n\t\t\t&quot;link&quot;: {\r\n\t\t\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t\t\t&quot;link_id&quot;: &quot;09-1&quot;\r\n\t\t\t},\r\n\t\t\t&quot;items&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;id&quot;: 0,\r\n\t\t\t\t\t&quot;state&quot;: &quot;FAILED&quot;,\r\n\t\t\t\t\t&quot;link_id&quot;: &quot;09-1&quot;,\r\n\t\t\t\t\t&quot;log&quot;: &quot;ErrorMsg&quot;\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\t&quot;doc&quot;: &quot;origin&quot;\r\n\t\t}\r\n\t}\r\n}\r\n```\r\n\r\n\r\n\r\n**Expected JSON Output:**\r\n\r\n```\r\n{\r\n\t&quot;realtime.0&quot;: {\r\n\t\t&quot;name&quot;: &quot;realtime&quot;,\r\n\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t&quot;url&quot;: &quot;/link/realtime/&quot;,\r\n\t\t&quot;item&quot;: 0,\r\n\t\t&quot;item_state&quot;: &quot;RUNNING&quot;,\r\n\t\t&quot;item_url&quot;: &quot;/links/realtime/items/0/&quot;\r\n\t},\r\n\t&quot;realtime.1&quot;: {\r\n\t\t&quot;name&quot;: &quot;realtime&quot;,\r\n\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t&quot;url&quot;: &quot;/link/realtime/&quot;,\r\n\t\t&quot;item&quot;: 1,\r\n\t\t&quot;item_state&quot;: &quot;STOPPED&quot;,\r\n\t\t&quot;item_url&quot;: &quot;/links/realtime/items/1/&quot;x\r\n\t},\r\n\t&quot;cmx.0&quot;: {\r\n\t\t&quot;name&quot;: &quot;cmx&quot;,\r\n\t\t&quot;state&quot;: &quot;RUNNING&quot;,\r\n\t\t&quot;url&quot;: &quot;/links/cmx/&quot;,\r\n\t\t&quot;item&quot;: 0,\r\n\t\t&quot;item_state&quot;: &quot;FAILED&quot;,\r\n\t\t&quot;item_url&quot;: &quot;/links/cmx/items/0/&quot;,\r\n\t\t&quot;log&quot;: &quot;ErrorMsg&quot;\r\n\t}\r\n}\r\n\r\n```\r\n\r\nThe best I got was with command below:\r\n`.[]|.status | .name as $name |.link.state as $state| .items[] | {$name, $state,items:[.]}| del(.items[].link_id)`\r\n\r\n**Which resulted in below (not even close):**\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;realtime&quot;,\r\n  &quot;state&quot;: &quot;RUNNING&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;id&quot;: 0,\r\n      &quot;state&quot;: &quot;RUNNING&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;realtime&quot;,\r\n  &quot;state&quot;: &quot;RUNNING&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;state&quot;: &quot;STOPPED&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;cms&quot;,\r\n  &quot;state&quot;: &quot;RUNNING&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;id&quot;: 0,\r\n      &quot;state&quot;: &quot;FAILED&quot;,\r\n      &quot;log&quot;: &quot;Error&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\nAppreciate the help.\r\nAlso, it will very helpful in understanding the solution if an explanation to the steps / filters applied is given.\r\n\r\nThanks!!\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74375954/json-transformation-jq",
        "title": "JSON transformation -jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668028715,
                "creation_date": 1668028715,
                "answer_id": 74381492,
                "question_id": 74381447,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`keys` sorts the keys, `keys_unsorted` doesn&#39;t.\r\n~~~sh\r\n. as $obj | reduce keys_unsorted[] as $key ({};\r\n  . * setpath($key | split(&quot;:&quot;); $obj[$key])\r\n)\r\n~~~\r\n\r\nHowever, I would rather use `to_entries`:\r\n~~~sh\r\nreduce to_entries[] as {$key, $value} ({}; \r\n  setpath($key / &quot;:&quot;; $value)\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;b&quot;: 1,\r\n  &quot;c&quot;: 2,\r\n  &quot;a&quot;: {\r\n    &quot;e&quot;: 3,\r\n    &quot;d&quot;: 4\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/eoSqANT_j8D)",
                "title": "Avoid reordering of keys when merging JSON objects with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668038052,
        "creation_date": 1668028405,
        "last_edit_date": 1668038052,
        "question_id": 74381447,
        "body_markdown": "Using [jq](https://stedolan.github.io/jq/) I want to unflatten a JSON file.\r\n\r\n**Input**\r\n```json\r\n{\r\n  &quot;b&quot;: 1,\r\n  &quot;c&quot;: 2,\r\n  &quot;a:e&quot;: 3,\r\n  &quot;a:d&quot;: 4\r\n}\r\n```\r\n\r\n**Expected output**\r\n```json\r\n{\r\n  &quot;b&quot;: 1,\r\n  &quot;c&quot;: 2,\r\n  &quot;a&quot;: {\r\n    &quot;e&quot;: 3,\r\n    &quot;d&quot;: 4\r\n  }\r\n}\r\n```\r\n\r\nThis code reorders the keys alphabetically.\r\nWhy is this and how can I keep the insertion order?\r\n\r\n```bash\r\njq &#39;. as $obj\r\n    | reduce keys[] as $key ({}; . * setpath($key | split(&quot;:&quot;); $obj[$key]))&#39;\r\n```\r\n\r\n**Output**\r\n```json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;d&quot;: 4,\r\n    &quot;e&quot;: 3\r\n  },\r\n  &quot;b&quot;: 2,\r\n  &quot;c&quot;: 1\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/74381447/avoid-reordering-of-keys-when-merging-json-objects-with-jq",
        "title": "Avoid reordering of keys when merging JSON objects with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5704377,
                    "reputation": 91,
                    "user_id": 4951263,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b2e65ad5dcb722a816a4a1d42fd0a180?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Robson",
                    "link": "https://stackoverflow.com/users/4951263/robson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668032328,
                "post_id": 74381739,
                "comment_id": 131312402,
                "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": 1668034087,
                "post_id": 74381739,
                "comment_id": 131312771,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1668031024,
                "creation_date": 1668031024,
                "answer_id": 74381841,
                "question_id": 74381739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before converting the attributes to objects, select only those which do not have an `end` property:\r\n\r\n```\r\n.[].attributes\r\n| map(select(has(&quot;end&quot;)|not)) # &lt;- this line is new\r\n| from_entries\r\n| select(has(&quot;JOB_TITLE&quot;) and has(&quot;EMAIL&quot;))\r\n| &quot;\\&quot;\\(.EMAIL)\\&quot;: \\&quot;\\(.JOB_TITLE)\\&quot;&quot;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;john.doe@contoso.com&quot;: &quot;SALESMAN&quot;\r\n&quot;lorraine.doe@contoso.com&quot;: &quot;SECRETARY&quot;\r\n```",
                "title": "Using Select to filter in jq query"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668031046,
                "creation_date": 1668031046,
                "answer_id": 74381844,
                "question_id": 74381739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter them out using a `map` before running `from_entries`:\r\n~~~sh\r\n.[].attributes \r\n| map(select(.name != &quot;JOB_TITLE&quot; or (has(&quot;end&quot;) | not)))\r\n| from_entries\r\n| select(has(&quot;JOB_TITLE&quot;) and has(&quot;EMAIL&quot;))\r\n| &quot;\\&quot;\\(.EMAIL)\\&quot;: \\&quot;\\(.JOB_TITLE)\\&quot;&quot;\r\n~~~\r\n~~~json\r\n&quot;john.doe@contoso.com&quot;: &quot;SALESMAN&quot;\r\n&quot;lorraine.doe@contoso.com&quot;: &quot;SECRETARY&quot;\r\n~~~\r\n[Demo](https://jqplay.org/s/HMhq5mw0tHa)",
                "title": "Using Select to filter in jq query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1668038522,
        "creation_date": 1668030347,
        "last_edit_date": 1668038522,
        "question_id": 74381739,
        "body_markdown": "previously I posted a question here (&lt;https://stackoverflow.com/questions/74214912/create-a-list-from-json-file-with-multiple-values/74215028#74215028&gt;). However, I found some of my keys are outdated, and they contain a key called &quot;end&quot;. I was not able to filter them out, making the data erratic.\r\n\r\nHere&#39;s the updated JSON that I use for testing:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;primary&quot;: &quot;JOHN DOE&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;BUILDING_NUMBER&quot;,\r\n        &quot;value&quot;: &quot;123&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;FLOOR&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;EMAIL&quot;,\r\n        &quot;value&quot;: &quot;john.doe@contoso.com&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;SALESMAN&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;TRAINEE&quot;,\r\n        &quot;end&quot;: &quot;11-09-2022&quot;\r\n      }\r\n    ],\r\n    &quot;aliases&quot;: [\r\n      {\r\n        &quot;alias&quot;: &quot;joao.doe@contoso.com&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;primary&quot;: &quot;LORRAINE DOE&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;BUILDING_NUMBER&quot;,\r\n        &quot;value&quot;: 456\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;FLOOR&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;STATUS&quot;,\r\n        &quot;value&quot;: &quot;Unavaliable&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;EMAIL&quot;,\r\n        &quot;value&quot;: &quot;lorraine.doe@contoso.com&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;Procurement&quot;,\r\n        &quot;end&quot;: &quot;11-09-2021&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;SECRETARY&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;SALES&quot;,\r\n        &quot;end&quot;: &quot;11-09-2021&quot;\r\n      }\r\n    ],\r\n    &quot;aliases&quot;: [\r\n      {\r\n        &quot;alias&quot;: &quot;lorris.doe@contoso.com&quot;\r\n      },\r\n      {\r\n        &quot;alias&quot;: &quot;lorris2.doe@contoso.com&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;primary&quot;: &quot;JACK DOE&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;BUILDING_NUMBER&quot;,\r\n        &quot;value&quot;: &quot;123&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;FLOOR&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;JOB_TITLE&quot;,\r\n        &quot;value&quot;: &quot;OWNER&quot;\r\n      }\r\n    ],\r\n    &quot;aliases&quot;: [\r\n      {\r\n        &quot;alias&quot;: &quot;jack.doe@contoso.com&quot;\r\n      },\r\n      {\r\n        &quot;alias&quot;: &quot;jackson.doe@contoso.com&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;primary&quot;: &quot;NOAH DOE&quot;,\r\n    &quot;attributes&quot;: [\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;BUILDING_NUMBER&quot;,\r\n        &quot;value&quot;: &quot;123&quot;\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;double&quot;,\r\n        &quot;name&quot;: &quot;FLOOR&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;EMAIL&quot;,\r\n        &quot;value&quot;: &quot;noah.doe@contoso.com&quot;\r\n      }\r\n    ],\r\n    &quot;aliases&quot;: [\r\n      {\r\n        &quot;alias&quot;: &quot;noah.doe95@contoso.com&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nIs there a way to filter out the attributes with key &quot;end&quot; and make the result as below?\r\n\r\n    &quot;john.doe@contoso.com&quot;: &quot;SALESMAN&quot;,\r\n    &quot;lorraine.doe@contoso.com&quot;: &quot;SECRETARY&quot;\r\n\r\n\r\nThis is the old solution:\r\n\r\n```\r\n.[].attributes | from_entries\r\n| select(has(&quot;JOB_TITLE&quot;) and has(&quot;EMAIL&quot;))\r\n| &quot;\\&quot;\\(.EMAIL)\\&quot;: \\&quot;\\(.JOB_TITLE)\\&quot;&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/74381739/using-select-to-filter-in-jq-query",
        "title": "Using Select to filter in jq query"
    },
    {
        "tags": [
            "json",
            "swagger",
            "jq",
            "openapi"
        ],
        "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": 1668041803,
                "post_id": 74382992,
                "comment_id": 131314032,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26883894,
                    "reputation": 31,
                    "user_id": 20463822,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu2cVxIo86AB9MEs9PM1evNUNrjiD-qMl85T86_d=k-s256",
                    "display_name": "3agpot",
                    "link": "https://stackoverflow.com/users/20463822/3agpot"
                },
                "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": 1668042496,
                "post_id": 74382992,
                "comment_id": 131314140,
                "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": 1668042857,
                "post_id": 74382992,
                "comment_id": 131314202,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729208488,
                "post_id": 74382992,
                "comment_id": 139476373,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668051136,
                "creation_date": 1668051136,
                "answer_id": 74383841,
                "question_id": 74382992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.paths |= map_values(\r\n   if type == &quot;object&quot;\r\n   then with_entries(select(\r\n        if .value|objects|has(&quot;x-visibility&quot;) \r\n        then .value|.[&quot;x-visibility&quot;] == &quot;public&quot; \r\n        else true end) )\r\n   else . end)\r\n```",
                "title": "How to use jq to remove a path method (based on a x-* property) from OpenAPI 3.0 or Swagger 2.0 json?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668109437,
                "last_edit_date": 1668109437,
                "creation_date": 1668108923,
                "answer_id": 74394444,
                "question_id": 74382992,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map_values` to apply a function to all values of an object. You have two nested objects, so you need to call `map_values` twice:\r\n\r\n```\r\n.paths |= map_values(map_values(select(.&quot;x-visibility&quot; == &quot;public&quot;)))\r\n```\r\n\r\nTo strip empty paths, select only those values which are not an empty array:\r\n\r\n```\r\n.paths |= map_values(\r\n    map_values(select(.&quot;x-visibility&quot; == &quot;public&quot;))\r\n    | select(. != {})\r\n)\r\n```\r\n\r\nor perhaps even one of the following:\r\n\r\n```\r\n.paths |= map_values(\r\n    map_values(select(.&quot;x-visibility&quot; == &quot;public&quot;))\r\n    | select(length &gt; 0)\r\n)\r\n```\r\n\r\n```\r\n.paths |= map_values(\r\n    map_values(select(.&quot;x-visibility&quot; == &quot;public&quot;))\r\n    | select(any)\r\n)\r\n```",
                "title": "How to use jq to remove a path method (based on a x-* property) from OpenAPI 3.0 or Swagger 2.0 json?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1668109437,
        "creation_date": 1668041451,
        "last_edit_date": 1668041889,
        "question_id": 74382992,
        "body_markdown": "I am new to **jq** and this one seems impossible to write. So need some help from jq gurus out there:\r\n\r\nSo I have an Open API spec file, let&#39;s take version 3.0 for example:\r\n\r\nThe `paths` element has `endpoints` listed, and each of them has methods(`get`, `post`, etc.)\r\n\r\nI need a jq filter to select ONLY those methods marked with `&quot;x-visibility&quot;: &quot;public&quot;` and leave everything else out.\r\n\r\n\r\n## So far, I&#39;ve tried this:\r\n\r\n```\r\n.paths |= map(select(.[].&quot;x-visibility&quot; == &quot;public&quot; | not))\r\n```\r\n\r\nObviously, it doesn&#39;t work.\r\n\r\nAny help/pointers will be appreciated!\r\n-------------------------\r\n\r\nHere is the OpenAPI 3.0 spec file (extra stuff stripped off):\r\n\r\n```\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.1&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;title&quot;: &quot;API service&quot;,\r\n    &quot;description&quot;: &quot;Exposing useful methods&quot;,\r\n    &quot;x-descriptionForPublicDocs&quot;: &quot;This is a test description for public docs specifically&quot;,\r\n    &quot;contact&quot;: {\r\n      &quot;name&quot;: &quot;Message me&quot;,\r\n      &quot;url&quot;: &quot;https://message.me&quot;\r\n    },\r\n    &quot;version&quot;: &quot;1.0&quot;\r\n  },\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;http://localhost:9090&quot;,\r\n      &quot;description&quot;: &quot;Generated server url&quot;\r\n    }\r\n  ],\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;AccountGroups&quot;\r\n    }\r\n  ],\r\n  &quot;x-tags&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;TestResourceLists&quot;\r\n    }\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/crane/v1/resource_list/{id}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;ResourceLists&quot;\r\n        ],\r\n        &quot;x-tags&quot;: &quot;TestResourceLists&quot;,\r\n        &quot;x-visibility&quot;: &quot;public&quot;,\r\n        &quot;summary&quot;: &quot;Get Resource List by ID&quot;,\r\n        &quot;description&quot;: &quot;Returns the resource list that has the specified ID.&quot;,\r\n        &quot;operationId&quot;: &quot;getById&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ResourceList Id&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/ResourceListModel&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;put&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;ResourceLists&quot;\r\n        ],\r\n        &quot;x-visibility&quot;: &quot;internal&quot;,\r\n        &quot;summary&quot;: &quot;Update Resource List&quot;,\r\n        &quot;description&quot;: &quot;Updates the resource list that has the specified ID.&quot;,\r\n        &quot;operationId&quot;: &quot;update&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ResourceList Id&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;description&quot;: &quot;Model for Resource List&quot;,\r\n          &quot;content&quot;: {\r\n            &quot;application/json&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;$ref&quot;: &quot;#/components/schemas/ResourceListModel&quot;\r\n              },\r\n              &quot;examples&quot;: {\r\n                &quot;TAG&quot;: {\r\n                  &quot;description&quot;: &quot;Tag ResourceList&quot;,\r\n                  &quot;value&quot;: {\r\n                    &quot;members&quot;: [\r\n                      {\r\n                        &quot;string&quot;: &quot;string&quot;\r\n                      }\r\n                    ],\r\n                    &quot;name&quot;: &quot;string&quot;,\r\n                    &quot;resourceListType&quot;: &quot;TAG&quot;,\r\n                    &quot;description&quot;: &quot;string&quot;\r\n                  }\r\n                },\r\n                &quot;RESOURCE_GROUP&quot;: {\r\n                  &quot;description&quot;: &quot;RESOURCE_GROUP ResourceList&quot;,\r\n                  &quot;value&quot;: {\r\n                    &quot;description&quot;: &quot;string&quot;,\r\n                    &quot;members&quot;: [\r\n                      &quot;string&quot;,\r\n                      &quot;string&quot;\r\n                    ],\r\n                    &quot;name&quot;: &quot;string&quot;,\r\n                    &quot;resourceListType&quot;: &quot;RESOURCE_GROUP&quot;\r\n                  }\r\n                },\r\n                &quot;COMPUTE_ACCESS_GROUP&quot;: {\r\n                  &quot;description&quot;: &quot;COMPUTE_ACCESS_GROUP ResourceList&quot;,\r\n                  &quot;value&quot;: {\r\n                    &quot;description&quot;: &quot;string&quot;,\r\n                    &quot;members&quot;: [\r\n                      {\r\n                        &quot;appIDs&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;clusters&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;codeRepos&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;containers&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;functions&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;hosts&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;images&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;labels&quot;: [\r\n                          &quot;*&quot;\r\n                        ],\r\n                        &quot;namespaces&quot;: [\r\n                          &quot;*&quot;\r\n                        ]\r\n                      }\r\n                    ],\r\n                    &quot;name&quot;: &quot;string&quot;,\r\n                    &quot;resourceListType&quot;: &quot;COMPUTE_ACCESS_GROUP&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;required&quot;: true\r\n        },\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/ResourceListModel&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;ResourceLists&quot;\r\n        ],\r\n        &quot;x-visibility&quot;: &quot;internal&quot;,\r\n        &quot;summary&quot;: &quot;Delete Resource List&quot;,\r\n        &quot;description&quot;: &quot;Deletes the resource list that has the specified ID.&quot;,\r\n        &quot;operationId&quot;: &quot;delete&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ResourceList Id&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;204&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/crane/v1/account_group/{id}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;AccountGroups&quot;\r\n        ],\r\n        &quot;x-visibility&quot;: &quot;public&quot;,\r\n        &quot;summary&quot;: &quot;Get resource&quot;,\r\n        &quot;description&quot;: &quot;Returns something&quot;,\r\n        &quot;operationId&quot;: &quot;getById_1&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account Group ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;includeAccountInfo&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;Include Cloud Account details&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;boolean&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/AccountGroupModel&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n      },\r\n      &quot;put&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;AccountGroups&quot;\r\n        ],\r\n        &quot;x-visibility&quot;: &quot;internal&quot;,\r\n        &quot;summary&quot;: &quot;Update resource&quot;,\r\n        &quot;description&quot;: &quot;Update information&quot;,\r\n        &quot;operationId&quot;: &quot;update_1&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;AccountGroup Id&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/json; charset=UTF-8&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;$ref&quot;: &quot;#/components/schemas/AccountGroupModel&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;required&quot;: true\r\n        },\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json; charset=UTF-8&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;AccountGroups&quot;\r\n        ],\r\n        &quot;x-visibility&quot;: &quot;internal&quot;,\r\n        &quot;summary&quot;: &quot;Delete resource&quot;,\r\n        &quot;description&quot;: &quot;Deletes the resource&quot;,\r\n        &quot;operationId&quot;: &quot;delete_1&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Delete resource&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;Successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Bad Request&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;Forbidden&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;Internal Server Error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;4XX&quot;: {\r\n            &quot;description&quot;: &quot;Client error&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;*/*&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/SpringErrorResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/74382992/how-to-use-jq-to-remove-a-path-method-based-on-a-x-property-from-openapi-3-0",
        "title": "How to use jq to remove a path method (based on a x-* property) from OpenAPI 3.0 or Swagger 2.0 json?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1668047023,
                "post_id": 74383458,
                "comment_id": 131314779,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1668048771,
                "last_edit_date": 1668048771,
                "creation_date": 1668047070,
                "answer_id": 74383494,
                "question_id": 74383458,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the value part is JSON:\r\n~~~sh\r\njq -Rn &#39;\r\n  reduce (inputs / &quot;=&quot;) as [$key, $value] ({};\r\n    .[$key] = ($value | fromjson / &quot; &quot;)\r\n  )\r\n&#39; input.txt\r\n~~~\r\n[Demo](https://jqplay.org/s/2Sdhvz7WzeY)\r\n\r\nOtherwise, just removing the first and last `&quot;` from it:\r\n~~~sh\r\njq -Rn &#39;\r\n  reduce (inputs / &quot;=&quot;) as [$key, $value] ({};\r\n    .[$key] = ($value | ltrimstr(&quot;\\&quot;&quot;) | rtrimstr(&quot;\\&quot;&quot;) / &quot; &quot;)\r\n  )\r\n&#39; input.txt\r\n~~~\r\n[Demo](https://jqplay.org/s/bcEdwQSWWVi)\r\n\r\nThe most robust approach, however, would be a regex matching, e.g. using `capture`:\r\n~~~sh\r\njq -Rn &#39;\r\n  [inputs | capture(&quot;^(?&lt;key&gt;[^=]+)=\\&quot;(?&lt;value&gt;.*)\\&quot;$&quot;) | .value /= &quot; &quot;]\r\n  | from_entries\r\n&#39; input.txt\r\n~~~\r\n[Demo](https://jqplay.org/s/5a5GIgjehnF)\r\n\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;keya&quot;: [\r\n    &quot;valuea&quot;,\r\n    &quot;valueb&quot;\r\n  ],\r\n  &quot;keyb&quot;: [],\r\n  &quot;keyc&quot;: [\r\n    &quot;valuex&quot;\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "Use jq to read a file and build a json with data from file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1668066823,
        "creation_date": 1668046727,
        "last_edit_date": 1668066823,
        "question_id": 74383458,
        "body_markdown": "I have a simple file like:\r\n\r\n```\r\nkeya=&quot;valuea valueb&quot;\r\nkeyb=&quot;&quot;\r\nkeyc=&quot;valuex&quot;\r\n```\r\n\r\nI would like to convert this file into JSON with following structure:\r\n\r\n```\r\n{\r\n    &quot;keya&quot;: [&quot;valuea&quot;, &quot;valueb&quot;],\r\n    &quot;keyb&quot;: [],\r\n    &quot;keyc&quot;: [&quot;valuex&quot;]\r\n}\r\n```\r\n\r\nIs there anyway to perform it using only jq? I was doing this parse on python but I would be glad If was possible to solve all using only jq.",
        "link": "https://stackoverflow.com/questions/74383458/use-jq-to-read-a-file-and-build-a-json-with-data-from-file",
        "title": "Use jq to read a file and build a json with data from file"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1668071127,
                "post_id": 74386325,
                "comment_id": 131319520,
                "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": 1668072115,
                "post_id": 74386325,
                "comment_id": 131319838,
                "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": 1668091709,
                "post_id": 74386325,
                "comment_id": 131326883,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668072467,
                "last_edit_date": 1668072467,
                "creation_date": 1668071794,
                "answer_id": 74386610,
                "question_id": 74386325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The sample is not quite valid JSON, but after fixing it, the following will produce the output you first mention (without the &quot;3333&quot;), in accordance with my best guess as to your requirements:\r\n```\r\njq -r &#39;.environment\r\n   | (map(.name) | index(&quot;CCC&quot;)) as $ix\r\n   | select($ix)\r\n   | del(.[$ix])\r\n   | map(.value)\r\n   | join(&quot;, &quot;)\r\n&#39;\r\n```\r\n\r\nFor very large arrays, you would probably want to tweak this a bit to avoid mapping the entire array.",
                "title": "jq - if a name is in a disctionary list exists, return a row of values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668092045,
                "creation_date": 1668092045,
                "answer_id": 74390978,
                "question_id": 74386325,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r --arg wanted &quot;CCC&quot; &#39;\r\n    .environment\r\n    | if any(.name == $wanted)\r\n        then map(.value) | @csv\r\n        else empty\r\n      end\r\n&#39; &lt;&lt; END_INPUT\r\n  {\r\n    &quot;environment&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;AAA&quot;,\r\n        &quot;value&quot;: &quot;1111&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;BBB&quot;,\r\n        &quot;value&quot;: &quot;2222&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;CCC&quot;,\r\n        &quot;value&quot;: &quot;3333&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;DDD&quot;,\r\n        &quot;value&quot;: &quot;4444&quot;\r\n      }\r\n    ]\r\n  }\r\nEND_INPUT\r\n```\r\n```none\r\n&quot;1111&quot;,&quot;2222&quot;,&quot;3333&quot;,&quot;4444&quot;\r\n```",
                "title": "jq - if a name is in a disctionary list exists, return a row of values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1668161267,
        "creation_date": 1668070324,
        "last_edit_date": 1668161267,
        "question_id": 74386325,
        "body_markdown": "Given the following input\r\n\r\n\r\n```\r\n{\r\n  &quot;environment&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;AAA&quot;,\r\n      &quot;value&quot;: &quot;1111&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;BBB&quot;,\r\n      &quot;value&quot;: &quot;2222&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;CCC&quot;,\r\n      &quot;value&quot;: &quot;3333&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;DDD&quot;,\r\n      &quot;value&quot;: &quot;4444&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nIf CCC exists, then write out on a single line of certain values \r\n   1111, 2222, 4444 \r\nElse\r\n   Write Nothing\r\n\r\n\r\njq -r &#39;.environment[] | select (.name == &quot;CCC&quot;) | [.name, .value] | @csv&#39;\r\n\r\nDon&#39;t know how to write the other values.\r\n\r\nWould like to see the values \r\n1111, 2222, 3333",
        "link": "https://stackoverflow.com/questions/74386325/jq-if-a-name-is-in-a-disctionary-list-exists-return-a-row-of-values",
        "title": "jq - if a name is in a disctionary list exists, return a row of values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668076435,
                "last_edit_date": 1668076435,
                "creation_date": 1668075615,
                "answer_id": 74387383,
                "question_id": 74387345,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, `null` and `false` are indeed considered falsy, other values as truthy. This notion is (somewhat unfortunately) explained in the [if-then-else](https://stedolan.github.io/jq/manual/#if-then-else) section of the manual.\r\n\r\nTherefore `jq -n &#39;1,2 | select(null)&#39;` will produce nothing, as would `jq -n &#39;1,2 | select(false)&#39;`\r\n\r\nIn the case of `jq -n &#39;1,2 | select(empty)&#39;`, the `empty` just eats up all the results, so there is nothing to output.\r\n\r\nAll other cases are truthy, therefore the input is propagated.\r\n\r\nNote that none of your examples considers the actual input for evaluation. All `select`s have a constant argument.\r\n\r\nTo filter based on the input, the argument of `select` has to somehow process it (as opposed to constants which simply ignore it), e.g. `jq -n &#39;1,2 | select(.%2 == 0)&#39;` outputs just `2`.",
                "title": "Definition of boolean_expression in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668077528,
        "creation_date": 1668075359,
        "last_edit_date": 1668077528,
        "question_id": 74387345,
        "body_markdown": "According to the [manual](https://stedolan.github.io/jq/manual/v1.6/#select(boolean_expression)) `select` needs a parameter `boolean_expression`.\r\nI always wonder what exactly is meant by this in `jq`.\r\nTo take full advantage of the `select` filter, it would be nice to have a clear definition.\r\n\r\nCan someone give this missing precise definition?\r\n\r\nThe following collection of unusual examples looks a bit strange and counterintuitive to me:\r\n\r\n`jq -n &#39;1,2 | select(null)&#39;`  outputs nothing\r\n\r\n`jq -n &#39;1,2 | select(empty)&#39;`  outputs nothing\r\n\r\n`jq -n &#39;1,2 | select(42)&#39;`  outputs `1 2`\r\n\r\n`jq -n &#39;1,2 | select(-1.23)&#39;`  outputs `1 2`\r\n\r\n`jq -n &#39;1,2 | select({a:&quot;strange&quot;})&#39;`  outputs `1 2`\r\n\r\n`jq -n &#39;1,0,-1,null,false,42 | select(.)&#39;`  outputs `1 0 -1 42`\r\n\r\nIt seems to me that everything that is not `false` and not `null` is considered `true`.\r\n\r\nIn the examples, the constants are to understand as placeholders for the result of an arbitrary expression.",
        "link": "https://stackoverflow.com/questions/74387345/definition-of-boolean-expression-in-jq",
        "title": "Definition of boolean_expression in jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668101140,
                "last_edit_date": 1668101140,
                "creation_date": 1668077361,
                "answer_id": 74387752,
                "question_id": 74387515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would this do what you want?\r\n~~~sh\r\n(.paths[].foo | select(all(has(&quot;parameters&quot;, &quot;filter-values&quot;); .))) |= (\r\n  (.parameters[] | select(.name == &quot;filter&quot;).description) +=\r\n    &quot; Possible values are: \\(.&quot;filter-values&quot; | join(&quot;, &quot;))&quot;\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;empty&quot;: {},\r\n  &quot;paths&quot;: {\r\n    &quot;somepath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;sort&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 1, 2, 3&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;orderby&quot;,\r\n            &quot;description&quot;: &quot;This is the `orderby` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;orderby-values&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ]\r\n      },\r\n      &quot;bar&quot;: {}\r\n    },\r\n    &quot;anotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 4, 5, 6&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;6&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;yetanotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/KE1qX6VIitx)",
                "title": "Use jq to append value of one key to another key, but at a different level of document tree"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668207124,
        "creation_date": 1668076282,
        "last_edit_date": 1668207124,
        "question_id": 74387515,
        "body_markdown": "I want to output this entire JSON file to a new file but with the value of `filter-values` appended as a string to each `description` of the `filter` item in each `parameters` array.\r\n\r\nSome notes:\r\n\r\n- I am only interested in the `foo` objects\r\n- Not all `foo` objects contain `parameter` arrays\r\n- Not all `parameter` arrays contain filter objects\r\n\r\n```json\r\n{\r\n  &quot;empty&quot;: {},\r\n  &quot;paths&quot;: {\r\n    &quot;somepath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;sort&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param.&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;orderby&quot;,\r\n            &quot;description&quot;: &quot;This is the `orderby` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;orderby-values&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ]\r\n      },\r\n      &quot;bar&quot;: {}\r\n    },\r\n    &quot;anotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;6&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;yetanotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\n\r\nThis is the closest I have come to getting it to work:\r\n\r\n\r\n```\r\n(.paths[].foo.&quot;filter-values&quot; // empty | join(&quot;, &quot;)) as $filters \r\n| (.paths[].foo.parameters // empty \r\n| . [] \r\n| select(.name? == &quot;filter&quot;)).description |= . + &quot; Possible values are: &quot; + $filters\r\n```\r\n\r\nExpected output:\r\n\r\n\r\n```json\r\n{\r\n  &quot;empty&quot;: {},\r\n  &quot;paths&quot;: {\r\n    &quot;somepath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;sort&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 1, 2, 3&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;orderby&quot;,\r\n            &quot;description&quot;: &quot;This is the `orderby` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;orderby-values&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ]\r\n      },\r\n      &quot;bar&quot;: {}\r\n    },\r\n    &quot;anotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 4, 5, 6&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;6&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;yetanotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\n```\r\n\r\nActual output (the entire document is produced twice, with the wrong `filter-values` appended to the `description` in some cases):\r\n\r\n```json\r\n{\r\n  &quot;empty&quot;: {},\r\n  &quot;paths&quot;: {\r\n    &quot;somepath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;sort&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 1, 2, 3&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;orderby&quot;,\r\n            &quot;description&quot;: &quot;This is the `orderby` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;orderby-values&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ]\r\n      },\r\n      &quot;bar&quot;: {}\r\n    },\r\n    &quot;anotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 1, 2, 3&quot; \r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;6&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;yetanotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;empty&quot;: {},\r\n  &quot;paths&quot;: {\r\n    &quot;somepath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;sort&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 4, 5, 6&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;orderby&quot;,\r\n            &quot;description&quot;: &quot;This is the `orderby` param.&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;1&quot;,\r\n          &quot;2&quot;,\r\n          &quot;3&quot;\r\n        ],\r\n        &quot;orderby-values&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ]\r\n      },\r\n      &quot;bar&quot;: {}\r\n    },\r\n    &quot;anotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;filter&quot;,\r\n            &quot;description&quot;: &quot;This is the `filter` param. Possible values are: 4, 5, 6&quot;\r\n          }\r\n        ],\r\n        &quot;filter-values&quot;: [\r\n          &quot;4&quot;,\r\n          &quot;5&quot;,\r\n          &quot;6&quot;\r\n        ]\r\n      }\r\n    },\r\n    &quot;yetanotherpath&quot;: {\r\n      &quot;foo&quot;: {\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;page&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74387515/use-jq-to-append-value-of-one-key-to-another-key-but-at-a-different-level-of-do",
        "title": "Use jq to append value of one key to another key, but at a different level of document tree"
    },
    {
        "tags": [
            "bash",
            "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": 0,
                "creation_date": 1668102687,
                "post_id": 74393319,
                "comment_id": 131330926,
                "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": 1668102877,
                "post_id": 74393319,
                "comment_id": 131330989,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1668103155,
        "creation_date": 1668102513,
        "last_edit_date": 1668103155,
        "question_id": 74393319,
        "body_markdown": "I&#39;m trying to read a list of paths into `jq` for processing, like so: \r\n\r\n```\r\n# example path: bigFolder.smallFolder.file\r\nfor i in ${!paths[@]}; do \r\n    path=&quot;${paths[$i]}&quot;\r\n    # making sure jq recognizes argument as path\r\n    keyPath=&quot;.$path&quot;\r\n    result=`echo &quot;$path&quot; | jq &quot;$keyPath&quot;\r\n    ...\r\ndone\r\n```\r\n\r\n\r\nHowever, this process fails to read keys that start with numerals, like\r\n```\r\nbigFolder.smallFolder.1thing\r\nbigFolder.smallFolder.2things\r\n...\r\n\r\njq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n```\r\n\r\nHow can I make sure `jq` can properly read these path names in ? ",
        "link": "https://stackoverflow.com/questions/74393319/jq-how-to-pass-key-starting-with-numeral-as-argument",
        "title": "jq How to pass key starting with numeral as argument"
    },
    {
        "tags": [
            "json",
            "docker",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1668114724,
                "creation_date": 1668114724,
                "answer_id": 74395353,
                "question_id": 74395172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You must make the file executable before you can execute it:\r\n\r\n```\r\nchmod u+x /usr/bin/jq\r\n```",
                "title": "Installed jq in Docker Container - permission denied"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668114724,
        "creation_date": 1668113556,
        "question_id": 74395172,
        "body_markdown": "I first installed jq for PowerShell using chocolatey (worked) but wasn&#39;t able to access it within my running docker container. \r\nTherefore I installed jq in the Docker container via the command I found under this [stackexchange-link][1].\r\n\r\n    curl -L -o /usr/bin/jq https://github.com/stedolan/jq/releases/download/jq-1.6/jq-linux64\r\n\r\nWhen I am now trying to access jq for example with the command `jq --version` it says `/bin/sh: 1: jq: permission denied`\r\n\r\nHow am I able to access jq within the Docker-Terminal?\r\n\r\n  [1]: https://unix.stackexchange.com/questions/663481/cannot-install-jq-version-1-6-in-docker",
        "link": "https://stackoverflow.com/questions/74395172/installed-jq-in-docker-container-permission-denied",
        "title": "Installed jq in Docker Container - permission denied"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "contains"
        ],
        "answers": [
            {
                "up_vote_count": 16,
                "is_accepted": true,
                "score": 16,
                "last_activity_date": 1668156903,
                "creation_date": 1668156903,
                "answer_id": 74400076,
                "question_id": 74400075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.[] | select(.title | contains(&quot;Star&quot;))&#39; movies\r\n```",
                "title": "how to select based on a substring in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1668207212,
        "creation_date": 1668156903,
        "last_edit_date": 1668207212,
        "question_id": 74400075,
        "body_markdown": "\r\nWith `jq`, how do I select only elements that contain the word &quot;Star&quot; in the following file `movies`:\r\n\r\n```json\r\n$ cat movies\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Dark Knight, The&quot;,\r\n    &quot;year&quot;: 2008\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Star Trek Beyond&quot;,\r\n    &quot;year&quot;: 2016\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Star Wars: Episode VII - The Force Awakens&quot;,\r\n    &quot;year&quot;: 2015\r\n  }\r\n]\r\n```\r\n\r\nExpected output: \r\n```\r\n{\r\n  &quot;title&quot;: &quot;Star Trek Beyond&quot;,\r\n  &quot;year&quot;: 2016\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Star Wars: Episode VII - The Force Awakens&quot;,\r\n  &quot;year&quot;: 2015\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74400075/how-to-select-based-on-a-substring-in-jq",
        "title": "how to select based on a substring in jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "gsub"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1668169094,
                "creation_date": 1668169094,
                "answer_id": 74402394,
                "question_id": 74402306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "* [`split()`][1] on a `=`\r\n* Take the [`first`][2] part\r\n* wrap in \\` using [string interpolation][3]\r\n* [`join()`][4] with an `,`:\r\n```\r\n.values | map(&quot;`\\(split(&quot;=&quot;) | first)`&quot;) | join(&quot;,&quot;)\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/d-dFAhsGqNz)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#split(str)\r\n  [2]: https://stedolan.github.io/jq/manual/#first,last,nth(n)\r\n  [3]: https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C(foo)\r\n  [4]: https://stedolan.github.io/jq/manual/#join(str)",
                "title": "Pass multiple regular expressions to the gsub() function in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668170392,
                "creation_date": 1668170392,
                "answer_id": 74402648,
                "question_id": 74402306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yet you can use `gsub()` such as\r\n```sh\r\n.&quot;values&quot; | map(&quot;`\\(gsub(&quot;=\\\\w+&quot;;&quot;&quot;))`&quot;)| join(&quot;,&quot;)\r\n```\r\n&lt;kbd&gt;[Demo](https://jqplay.org/s/PQTQR-ixuVx)&lt;/kbd&gt;",
                "title": "Pass multiple regular expressions to the gsub() function in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668180553,
                "last_edit_date": 1668180553,
                "creation_date": 1668179933,
                "answer_id": 74404605,
                "question_id": 74402306,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.values\r\n| map(capture( &quot;(?&lt;key&gt;^[^=]*)=&quot; ).key | &quot;`\\(.)`&quot; ) \r\n| join(&quot;,&quot;)",
                "title": "Pass multiple regular expressions to the gsub() function in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1668251389,
        "creation_date": 1668168626,
        "last_edit_date": 1668251389,
        "question_id": 74402306,
        "body_markdown": "How can I avoid doing embarrassing stuff like this when trying to apply multiple regular expressions using the `gsub()` function in jq?\r\n\r\n```\r\n.&quot;values&quot; | tostring | gsub(&quot;\\&quot;&quot;;&quot;`&quot;) | gsub(&quot;\\\\[&quot;;&quot;&quot;) | gsub(&quot;\\\\]&quot;;&quot;&quot;) | gsub(&quot;=\\\\w*&quot;;&quot;&quot;)\r\n```\r\n\r\nI want to convert the array below to a string, keep the values to the left of the equals sign and surround each value in backticks. \r\n\r\nThe jq command above works but something tells me there&#39;s a more elegant solution. \r\n\r\nInput:\r\n\r\n```json\r\n{\r\n  &quot;values&quot;: [\r\n    &quot;1=foo&quot;,\r\n    &quot;2=bar&quot;,\r\n    &quot;3=baz&quot;\r\n  ]\r\n}\r\n```\r\n\r\nOutput (expected and actual)\r\n\r\n```json\r\n&quot;`1`,`2`,`3`&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74402306/pass-multiple-regular-expressions-to-the-gsub-function-in-jq",
        "title": "Pass multiple regular expressions to the gsub() function in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668250044,
                "creation_date": 1668250044,
                "answer_id": 74412215,
                "question_id": 74411666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq -Rr &#39;\r\n    . / &quot; &quot; |\r\n    map(. / &quot;=&quot; |\r\n          &quot;\\&quot;&quot; + join(&quot;\\&quot;: \\&quot;&quot;) + &quot;\\&quot;&quot;\r\n       ) |\r\n    join(&quot;, &quot;)\r\n&#39; input.json\r\n```",
                "title": "Converting a line of text into another format with jq avoiding &#39;if-then-else&#39;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1668257637,
        "creation_date": 1668244204,
        "last_edit_date": 1668257637,
        "question_id": 74411666,
        "body_markdown": "Using [jq](https://stedolan.github.io/jq/), I want to convert the input `A B=1 C= D=2` to `&quot;A&quot;, &quot;B&quot;: &quot;1&quot;, &quot;C&quot;: &quot;&quot;, &quot;D&quot;: &quot;2&quot;`\r\n\r\nI came up with the solution\r\n```bash\r\njq -Rr &#39;. / &quot; &quot; | map(. / &quot;=&quot; | &quot;\\&quot;\\(.[0])\\&quot;&quot; + (if .[1] != null then &quot;: \\&quot;\\(.[1])\\&quot;&quot; else &quot;&quot; end)) | join(&quot;, &quot;)&#39;\r\n```\r\n\r\nI am sure there is a more elegant way that avoids the `if-then-else`.\r\nCan you help me shorten the expression?\r\n",
        "link": "https://stackoverflow.com/questions/74411666/converting-a-line-of-text-into-another-format-with-jq-avoiding-if-then-else",
        "title": "Converting a line of text into another format with jq avoiding &#39;if-then-else&#39;"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668267986,
                "creation_date": 1668267986,
                "answer_id": 74414333,
                "question_id": 74414228,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need some parentheses around the `.records[] ...` part\r\n```sh\r\njq -r &#39;\r\n  [&quot;name&quot;,  &quot;tijd&quot;, &quot;totaalAantalPlaatsen&quot;, &quot;bezettePlaatsen&quot;, &quot;bezetting&quot;],\r\n  (.records[].fields | [.facilityname, .time, .totalplaces, .occupiedplaces, .bezetting])\r\n  | @csv\r\n&#39; file.json\r\n```",
                "title": "How can I convert nested JSON to CSV on command line?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668267986,
        "creation_date": 1668267099,
        "last_edit_date": 1668267170,
        "question_id": 74414228,
        "body_markdown": "I have a JSON file who I am trying to convert to CSV using jq, but I&#39;ve been having a lot of problems, this is the JSON:\r\n```\r\n{\r\n    &quot;nhits&quot;: 2,\r\n    &quot;parameters&quot;: {\r\n        &quot;dataset&quot;: &quot;real-time-bezettingen-fietsenstallingen-gent&quot;,\r\n        &quot;rows&quot;: 10,\r\n        &quot;start&quot;: 0,\r\n        &quot;facet&quot;: [\r\n            &quot;facilityname&quot;\r\n        ],\r\n        &quot;format&quot;: &quot;json&quot;,\r\n        &quot;timezone&quot;: &quot;UTC&quot;\r\n    },\r\n    &quot;records&quot;: [\r\n        {\r\n            &quot;datasetid&quot;: &quot;real-time-bezettingen-fietsenstallingen-gent&quot;,\r\n            &quot;recordid&quot;: &quot;d471594688a931ba8d81f8d883874a08cee84775&quot;,\r\n            &quot;fields&quot;: {\r\n                &quot;id&quot;: &quot;48-2&quot;,\r\n                &quot;freeplaces&quot;: 71,\r\n                &quot;facilityname&quot;: &quot;Braunplein&quot;,\r\n                &quot;geo_point_2d&quot;: [\r\n                    51.05406845807926,\r\n                    3.723722319130363\r\n                ],\r\n                &quot;time&quot;: &quot;2022-11-10T12:18:01+00:00&quot;,\r\n                &quot;totalplaces&quot;: 116,\r\n                &quot;occupiedplaces&quot;: 45,\r\n                &quot;bezetting&quot;: 38\r\n            },\r\n            &quot;geometry&quot;: {\r\n                &quot;type&quot;: &quot;Point&quot;,\r\n                &quot;coordinates&quot;: [\r\n                    3.723722319130363,\r\n                    51.05406845807926\r\n                ]\r\n            },\r\n            &quot;record_timestamp&quot;: &quot;2022-11-10T12:18:04.838Z&quot;\r\n        },\r\n        {\r\n            &quot;datasetid&quot;: &quot;real-time-bezettingen-fietsenstallingen-gent&quot;,\r\n            &quot;recordid&quot;: &quot;d0121748cf31c7e1c02d99712bdf07cb33156689&quot;,\r\n            &quot;fields&quot;: {\r\n                &quot;id&quot;: &quot;48-1&quot;,\r\n                &quot;freeplaces&quot;: 65,\r\n                &quot;facilityname&quot;: &quot;Korenmarkt&quot;,\r\n                &quot;geo_point_2d&quot;: [\r\n                    51.05388288288933,\r\n                    3.7214177570400473\r\n                ],\r\n                &quot;time&quot;: &quot;2022-11-10T12:18:01+00:00&quot;,\r\n                &quot;totalplaces&quot;: 235,\r\n                &quot;occupiedplaces&quot;: 170,\r\n                &quot;bezetting&quot;: 72\r\n            },\r\n            &quot;geometry&quot;: {\r\n                &quot;type&quot;: &quot;Point&quot;,\r\n                &quot;coordinates&quot;: [\r\n                    3.7214177570400473,\r\n                    51.05388288288933\r\n                ]\r\n            },\r\n            &quot;record_timestamp&quot;: &quot;2022-11-10T12:18:04.838Z&quot;\r\n        }\r\n    ],\r\n    &quot;facet_groups&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;facilityname&quot;,\r\n            &quot;facets&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;Braunplein&quot;,\r\n                    &quot;count&quot;: 1,\r\n                    &quot;state&quot;: &quot;displayed&quot;,\r\n                    &quot;path&quot;: &quot;Braunplein&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;Korenmarkt&quot;,\r\n                    &quot;count&quot;: 1,\r\n                    &quot;state&quot;: &quot;displayed&quot;,\r\n                    &quot;path&quot;: &quot;Korenmarkt&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\n\r\nI only want to have the columns facilityname, time, totalplaces, occupiedplaces and bezetting, I tried converting using the following command: \r\n\r\n`jq -r &#39;[&quot;naam&quot;, &quot;tijd&quot;, &quot;totaalAantalPlaatsen&quot;, &quot;bezettePlaatsen&quot;, &quot;bezetting&quot;] , .records[] | (.fields[] | [.facilityname, .time, .totalplaces, .occupiedplaces, .bezetting]) | @csv&#39; data.json\r\n`\r\n\r\nBut I get the error:\r\n\r\n`jq: error (at data.json:0): Cannot index array with string &quot;fields&quot;`\r\n\r\nDoes anyone know what I&#39;m doing wrong?",
        "link": "https://stackoverflow.com/questions/74414228/how-can-i-convert-nested-json-to-csv-on-command-line",
        "title": "How can I convert nested JSON to CSV on command line?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 137028,
                    "reputation": 43837,
                    "user_id": 340947,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/D0CKc.jpg?s=256",
                    "display_name": "Steven Lu",
                    "link": "https://stackoverflow.com/users/340947/steven-lu"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668313759,
                "post_id": 74418465,
                "comment_id": 131373334,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668314107,
                "post_id": 74418465,
                "comment_id": 131373365,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 137028,
                    "reputation": 43837,
                    "user_id": 340947,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/D0CKc.jpg?s=256",
                    "display_name": "Steven Lu",
                    "link": "https://stackoverflow.com/users/340947/steven-lu"
                },
                "reply_to_user": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668438958,
                "post_id": 74418465,
                "comment_id": 131398829,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668313885,
                "creation_date": 1668313885,
                "answer_id": 74418476,
                "question_id": 74418465,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found an answer in `jq &#39;.[] |= select(.marked==true)&#39;`. Alternatively/Equivalently, `map_values`.\r\n\r\nNow to find out what this does and why it works.",
                "title": "jq: How to count number of values that match a condition?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668313885,
        "creation_date": 1668313706,
        "question_id": 74418465,
        "body_markdown": "Working with a large hash, something like: \r\n\r\n```\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;marked&quot;: true,\r\n    &quot;id&quot;: 1\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;id&quot;: 2\r\n  },\r\n  &quot;3&quot;: {\r\n    &quot;id&quot;: 3,\r\n    &quot;data&quot;: &quot;blah&quot;,\r\n    &quot;marked&quot;: true\r\n}\r\n```\r\n\r\nI&#39;d like to just count the number of entries (two) which are marked, with &quot;marked&quot; property as true.\r\n\r\nAttempt: \r\n\r\n```\r\n❯ echo &#39;{  &quot;1&quot;: { &quot;marked&quot;: true, &quot;id&quot;: 1  }, &quot;2&quot;: { &quot;id&quot;: 2  }, &quot;3&quot;: { &quot;id&quot;: 3, &quot;data&quot;: &quot;blah&quot;, &quot;marked&quot;: true }}&#39; | jq &#39;.[] | select(.marked==true) | length&#39;                                          experiment/git-ci-artifact-view[✦]47ed9707a[✎✭]22m\r\n2\r\n3\r\n```\r\n\r\nWhat&#39;s happening here is I&#39;m getting shown that the first item that matches has 2 props and the second item has 3 props. Since I&#39;ve converted the large object into an array with the initial `.[]`, and the filter has properly eliminated the second entry from this. \r\n\r\nI could obtain the answer with a `wc -l` but the point of the question is how to get to the answer of `2`, e.g. id&#39;s 1 and 3 make for two items that are marked true.\r\n\r\nI tried a bunch of stuff, the most promising, `.[] | [select(.marked==true)]&#39;` just produces this though, wrapping each item in `[]`:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;marked&quot;: true,\r\n    &quot;id&quot;: 1\r\n  }\r\n]\r\n[]\r\n[\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;data&quot;: &quot;blah&quot;,\r\n    &quot;marked&quot;: true\r\n  }\r\n]\r\n```\r\n\r\nVarious stuff that seems like it would make sense don&#39;t parse, such as `.select(.marked==true)`.",
        "link": "https://stackoverflow.com/questions/74418465/jq-how-to-count-number-of-values-that-match-a-condition",
        "title": "jq: How to count number of values that match a condition?"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26677616,
                    "reputation": 911,
                    "user_id": 20288037,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5775376cdcd25aaa4fbe2f36bae61f3d?s=256&d=identicon&r=PG",
                    "display_name": "Ping",
                    "link": "https://stackoverflow.com/users/20288037/ping"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668344073,
                "post_id": 74421111,
                "comment_id": 131377368,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668345678,
                "creation_date": 1668345678,
                "answer_id": 74421354,
                "question_id": 74421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need `map` to make `select` test individual objects:\r\n\r\n```\r\njq &#39;map(select(. != {}))&#39;\r\n```",
                "title": "Select only non-empty objects from array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668346481,
                "creation_date": 1668346481,
                "answer_id": 74421480,
                "question_id": 74421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use the `del` filter:\r\n\r\n```bash\r\njq &#39;del(.[] | select(length == 0))&#39;\r\n```\r\n\r\nor\r\n\r\n```bash\r\njq &#39;del(.[] | select(. == {}))&#39;\r\n```\r\n",
                "title": "Select only non-empty objects from array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668369676,
                "last_edit_date": 1668369676,
                "creation_date": 1668350024,
                "answer_id": 74421913,
                "question_id": 74421111,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`map` is required to apply the filter to every item in the array. Then `any` can be used: it will return `true` for objects with at least one property, and `false` if the object is empty.\r\n\r\n```\r\n$ jq -n &#39;{} | any&#39;\r\nfalse\r\n$ jq -n &#39;{x:42} | any&#39;\r\ntrue\r\n```\r\n\r\n`empty` is not a test, but a generator for &quot;no value&quot; ([docs](https://stedolan.github.io/jq/manual/v1.6/#empty)).\r\n\r\nSolution:\r\n\r\n```\r\nmap(select(any))\r\n```\r\n\r\nAs noted by user [Philippe](https://stackoverflow.com/users/2125671/philippe) in the comments, using `any` only works if the values of the objects&#39; properties are not `false`. It would detect objects such as `{&quot;x&quot;:false}` as &quot;empty&quot;. A better approach is comparing the empty object directly or using `length`:\r\n\r\n```\r\nmap(select(length&gt;0))\r\n```",
                "title": "Select only non-empty objects from array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1668369736,
        "creation_date": 1668343777,
        "last_edit_date": 1668369736,
        "question_id": 74421111,
        "body_markdown": "I have a JSON array with objects as items. Some of the objects have properties, some don&#39;t. How can I filter the list with jq to keep only non-empty objects in the list?\r\n\r\nInput:\r\n\r\n```\r\n[\r\n  {},\r\n  { &quot;x&quot;: 42 },\r\n  {},\r\n  { &quot;y&quot;: 21 },\r\n  {},\r\n  { &quot;z&quot;: 13 }\r\n]\r\n```\r\n\r\nExpected output:\r\n\r\n\r\n```\r\n[\r\n  { &quot;x&quot;: 42 },\r\n  { &quot;y&quot;: 21 },\r\n  { &quot;z&quot;: 13 }\r\n]\r\n```\r\n\r\nI tried `jq &#39;select(. != {})&#39;`, but the result still contains all items. Using `jq &#39;map(select(empty))&#39;` doesn&#39;t keep any item and returns an empty array!",
        "link": "https://stackoverflow.com/questions/74421111/select-only-non-empty-objects-from-array",
        "title": "Select only non-empty objects from array"
    },
    {
        "tags": [
            "jq",
            "openapi"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668371225,
                "post_id": 74424368,
                "comment_id": 131383354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39252,
                    "reputation": 99231,
                    "user_id": 113116,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/e0v1H.png?s=256",
                    "display_name": "Helen",
                    "link": "https://stackoverflow.com/users/113116/helen"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1668404794,
                "post_id": 74424368,
                "comment_id": 131388269,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668371951,
                "creation_date": 1668371951,
                "answer_id": 74424590,
                "question_id": 74424368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could build an array of key-value pairs based on the `.tags` array, which you can eventually convert to an object using `from_entries`. Use `del` to delete what you don&#39;t want to be included.\r\n\r\n~~~sh\r\n[.tags[] as $tag | {key: &quot;tag_\\($tag.name | gsub(&quot; &quot;; &quot;&quot;))&quot;, value: del(\r\n  \r\n  .openapi,\r\n  (.tags[] | select(. != $tag)),\r\n  (.paths[] | select(IN(.[].tags[]; $tag.name) | not))\r\n  \r\n)}] | from_entries\r\n~~~\r\n~~~json\r\n{\r\n  &quot;tag_RotorParts&quot;: {\r\n    &quot;info&quot;: {\r\n      &quot;description&quot;: &quot;Prisma Cloud REST APIs for external use.&quot;,\r\n      &quot;version&quot;: &quot;v1&quot;,\r\n      &quot;title&quot;: &quot;Prisma Cloud REST API Doc&quot;,\r\n      &quot;contact&quot;: {},\r\n      &quot;license&quot;: {\r\n        &quot;name&quot;: &quot;Public&quot;\r\n      }\r\n    },\r\n    &quot;tags&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Rotor Parts&quot;,\r\n        &quot;description&quot;: &quot;Rotor Parts API&quot;\r\n      }\r\n    ],\r\n    &quot;paths&quot;: {\r\n      &quot;/access_keys&quot;: {\r\n        &quot;get&quot;: {\r\n          &quot;tags&quot;: [\r\n            &quot;Rotor Parts&quot;\r\n          ],\r\n          &quot;summary&quot;: &quot;List Rotor Parts&quot;,\r\n          &quot;description&quot;: &quot;Returns all rotor parts if you have an Admin role. Returns just your rotor parts if you don&#39;t have this role.&quot;,\r\n          &quot;operationId&quot;: &quot;get-my-rotor-parts&quot;,\r\n          &quot;responses&quot;: {\r\n            &quot;200&quot;: {\r\n              &quot;description&quot;: &quot;successful operation&quot;,\r\n              &quot;content&quot;: {\r\n                &quot;application/json&quot;: {\r\n                  &quot;schema&quot;: {\r\n                    &quot;type&quot;: &quot;array&quot;,\r\n                    &quot;items&quot;: {\r\n                      &quot;$ref&quot;: &quot;#/components/schemas/RotorPartsResponseModel&quot;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;400&quot;: {\r\n              &quot;description&quot;: &quot;user_inactive_or_not_exist&quot;\r\n            },\r\n            &quot;403&quot;: {\r\n              &quot;description&quot;: &quot;unauthorized_to_use_rotor_parts&quot;\r\n            },\r\n            &quot;500&quot;: {\r\n              &quot;description&quot;: &quot;failed_fetch_user_profile&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;post&quot;: {\r\n          &quot;tags&quot;: [\r\n            &quot;Rotor Parts&quot;\r\n          ],\r\n          &quot;summary&quot;: &quot;Add Rotor Parts&quot;,\r\n          &quot;description&quot;: &quot;Adds a new rotor part for the current user. If you have API access, you can create up to two rotor parts.&quot;,\r\n          &quot;operationId&quot;: &quot;add-rotor-parts&quot;,\r\n          &quot;requestBody&quot;: {\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/UserRotorPartRequestModel&quot;\r\n                }\r\n              }\r\n            },\r\n            &quot;description&quot;: &quot;Model user rotor part model&quot;,\r\n            &quot;required&quot;: true\r\n          },\r\n          &quot;responses&quot;: {\r\n            &quot;200&quot;: {\r\n              &quot;description&quot;: &quot;successful operation&quot;,\r\n              &quot;content&quot;: {\r\n                &quot;application/json&quot;: {\r\n                  &quot;schema&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/CreateUserAccessKeyResponseModel&quot;\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;400&quot;: {\r\n              &quot;description&quot;: &quot;invalid_expiry_access_key / already_have_two_access_keys / invalid_access_key_name_length / invalid_access_key_name&quot;\r\n            },\r\n            &quot;403&quot;: {\r\n              &quot;description&quot;: &quot;unauthorized_to_use_access_keys&quot;\r\n            },\r\n            &quot;409&quot;: {\r\n              &quot;description&quot;: &quot;duplicate_access_key_name&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;tag_CloudAccounts&quot;: {\r\n    &quot;info&quot;: {\r\n      &quot;description&quot;: &quot;Prisma Cloud REST APIs for external use.&quot;,\r\n      &quot;version&quot;: &quot;v1&quot;,\r\n      &quot;title&quot;: &quot;Prisma Cloud REST API Doc&quot;,\r\n      &quot;contact&quot;: {},\r\n      &quot;license&quot;: {\r\n        &quot;name&quot;: &quot;Public&quot;\r\n      }\r\n    },\r\n    &quot;tags&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Cloud Accounts&quot;,\r\n        &quot;description&quot;: &quot;Plant Locations APIs&quot;\r\n      }\r\n    ],\r\n    &quot;paths&quot;: {\r\n      &quot;/account/{accountId}/config/status&quot;: {\r\n        &quot;get&quot;: {\r\n          &quot;tags&quot;: [\r\n            &quot;Cloud Accounts&quot;\r\n          ],\r\n          &quot;summary&quot;: &quot;List Account Status Details&quot;,\r\n          &quot;description&quot;: &quot;Returns a list of Cloud services whose status indicates a warning or error for the given cloud account ID. Includes status details for each listed service.&quot;,\r\n          &quot;operationId&quot;: &quot;list-cloud-account-status-details&quot;,\r\n          &quot;parameters&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;accountId&quot;,\r\n              &quot;in&quot;: &quot;path&quot;,\r\n              &quot;description&quot;: &quot;Cloud account ID&quot;,\r\n              &quot;required&quot;: true,\r\n              &quot;schema&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;responses&quot;: {\r\n            &quot;200&quot;: {\r\n              &quot;description&quot;: &quot;successful operation&quot;,\r\n              &quot;content&quot;: {\r\n                &quot;application/json; charset=UTF-8&quot;: {\r\n                  &quot;schema&quot;: {\r\n                    &quot;type&quot;: &quot;array&quot;,\r\n                    &quot;items&quot;: {\r\n                      &quot;$ref&quot;: &quot;#/components/schemas/CloudAccountConfigStatusView&quot;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;400&quot;: {\r\n              &quot;description&quot;: &quot;bad_request&quot;\r\n            },\r\n            &quot;500&quot;: {\r\n              &quot;description&quot;: &quot;internal_error&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/ds7oUHkSaf8)",
                "title": "Using jq, how to split OpenAPI 3.0 file into chunks based on the tag property?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668372929,
                "creation_date": 1668372929,
                "answer_id": 74424700,
                "question_id": 74424368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a solution that looks like it works:\r\n\r\n```\r\n. as {$info, $paths}\r\n| .tags\r\n| map(\r\n    . as $tag\r\n    | (.name |= &quot;tag_&quot; + gsub(&quot; &quot;; &quot;&quot;))\r\n    | .value = {\r\n        $info,\r\n        tags: [ $tag ],\r\n        paths: $paths | map_values(\r\n            with_entries(select(IN(.value.tags[]; $tag.name)))\r\n            | select(length &gt; 0)\r\n        )\r\n    }\r\n)\r\n| from_entries\r\n```",
                "title": "Using jq, how to split OpenAPI 3.0 file into chunks based on the tag property?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668376188,
                "creation_date": 1668376188,
                "answer_id": 74425029,
                "question_id": 74424368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can reformulate this to [group by](https://stackoverflow.com/q/73893818/112968) tags and then transform:\r\n\r\n```\r\n\r\ndef group(k):\r\n  group_by(k) | map({key:first|k, value:.}) | from_entries;\r\n\r\n. as {$info}\r\n| INDEX(.tags[];.name) as $tags # lookup table for tags by name\r\n| .paths\r\n| to_entries\r\n| group(.value[].tags[]) # group paths by their tags\r\n| with_entries(\r\n    [$tags[.key]] as $tags\r\n    | .key |= &quot;tag_&quot; + gsub(&quot; &quot;; &quot;&quot;)  # fix property names\r\n    | .value |= { $info, $tags, paths: from_entries } # transform to result\r\n)\r\n```",
                "title": "Using jq, how to split OpenAPI 3.0 file into chunks based on the tag property?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668403668,
                "creation_date": 1668403668,
                "answer_id": 74427271,
                "question_id": 74424368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a constructive solution that uses a helper function in the hope of making it digestible:\r\n```\r\n  # Input: an object { k1: { k21: { tags: [TAG ...] ... }, ...} }\r\n  # Output: drop every key, k2, at the second level if k2.tags does not contain $tag\r\n  def selection($tag):\r\n    map_values(\r\n      if type == &quot;object&quot; \r\n      then with_entries(\r\n             select(.value | objects | select(.tags) | .tags | index($tag)))\r\n      else .\r\n      end );\r\n\r\n  [range(0; .tags|length) as $i\r\n   | (.tags[$i].name) as $tag\r\n   | {&quot;tag_\\($tag|gsub(&quot; &quot;;&quot;&quot;))&quot;: \r\n       { info,\r\n         tags: [.tags[$i]],\r\n         paths: (.paths | selection($tag ) | with_entries(select(.value != {})) )\r\n       }\r\n     } ] \r\n  | add\r\n```",
                "title": "Using jq, how to split OpenAPI 3.0 file into chunks based on the tag property?"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1668436003,
        "creation_date": 1668370081,
        "last_edit_date": 1668436003,
        "question_id": 74424368,
        "body_markdown": "I&#39;ve got something challenging (at least for me) to do. There is this OpenAPI 3.0 file that needs some dicing based on the tags (i.e. cut into as many chunks as there are items in the `tags` property.\r\n\r\nFor simplicity, there 2 tags in this example.\r\nSo, all the `paths` that belong to the **Rotor Parts** tag will go into the first dictionary item. And other parts will go under the second dictionary item.\r\n\r\nHere&#39;s the input file:\r\n\r\n```\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.0&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;description&quot;: &quot;PREST APIs for external use.&quot;,\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;title&quot;: &quot;REST API Doc&quot;,\r\n    &quot;contact&quot;: {},\r\n    &quot;license&quot;: {\r\n      &quot;name&quot;: &quot;Public&quot;\r\n    }\r\n  },\r\n  &quot;tags&quot;:[\r\n      {\r\n        &quot;name&quot;: &quot;Rotor Parts&quot;,\r\n        &quot;description&quot;: &quot;Rotor Parts API&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;Cloud Accounts&quot;,\r\n        &quot;description&quot;: &quot;Plant Locations APIs&quot;\r\n      }\r\n\t],\r\n  &quot;paths&quot;: {\r\n    &quot;/access_keys&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Rotor Parts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;List Rotor Parts&quot;,\r\n        &quot;description&quot;: &quot;Returns all rotor parts if you have an Admin role. Returns just your rotor parts if you don&#39;t have this role.&quot;,\r\n        &quot;operationId&quot;: &quot;get-my-rotor-parts&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/RotorPartsResponseModel&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;user_inactive_or_not_exist&quot;\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;unauthorized_to_use_rotor_parts&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;failed_fetch_user_profile&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Rotor Parts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Add Rotor Parts&quot;,\r\n        &quot;description&quot;: &quot;Adds a new rotor part for the current user. If you have API access, you can create up to two rotor parts.&quot;,\r\n        &quot;operationId&quot;: &quot;add-rotor-parts&quot;,\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/json&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;$ref&quot;: &quot;#/components/schemas/UserRotorPartRequestModel&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;description&quot;: &quot;Model user rotor part model&quot;,\r\n          &quot;required&quot;: true\r\n        },\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/CreateUserAccessKeyResponseModel&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_expiry_access_key / already_have_two_access_keys / invalid_access_key_name_length / invalid_access_key_name&quot;\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;unauthorized_to_use_access_keys&quot;\r\n          },\r\n          &quot;409&quot;: {\r\n            &quot;description&quot;: &quot;duplicate_access_key_name&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/account/{accountId}/config/status&quot;: {\r\n    &quot;get&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;Cloud Accounts&quot;\r\n      ],\r\n      &quot;summary&quot;: &quot;List Account Status Details&quot;,\r\n      &quot;description&quot;: &quot;Returns a list of Cloud services whose status indicates a warning or error for the given cloud account ID. Includes status details for each listed service.&quot;,\r\n      &quot;operationId&quot;: &quot;list-cloud-account-status-details&quot;,\r\n      &quot;parameters&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;accountId&quot;,\r\n          &quot;in&quot;: &quot;path&quot;,\r\n          &quot;description&quot;: &quot;Cloud account ID&quot;,\r\n          &quot;required&quot;: true,\r\n          &quot;schema&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;responses&quot;: {\r\n        &quot;200&quot;: {\r\n          &quot;description&quot;: &quot;successful operation&quot;,\r\n          &quot;content&quot;: {\r\n            &quot;application/json; charset=UTF-8&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;type&quot;: &quot;array&quot;,\r\n                &quot;items&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/CloudAccountConfigStatusView&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;400&quot;: {\r\n          &quot;description&quot;: &quot;bad_request&quot;\r\n        },\r\n        &quot;500&quot;: {\r\n          &quot;description&quot;: &quot;internal_error&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  }\r\n}\r\n```\r\n\r\nAnd here&#39;s an expected output:\r\n\r\n```\r\n{\r\n  &quot;tag_RotorParts&quot;: {\r\n    &quot;info&quot;: &quot;same content here&quot;,\r\n    &quot;tags&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Rotor Parts&quot;,\r\n        &quot;description&quot;: &quot;Rotor Parts API&quot;\r\n      }\r\n    ],\r\n    &quot;paths&quot;: {\r\n      &quot;/access_keys&quot;: {\r\n        &quot;get&quot;: {\r\n          &quot;tags&quot;: [\r\n            &quot;Rotor Parts&quot;\r\n          ],\r\n          &quot;summary&quot;: &quot;List Rotor Parts&quot;,\r\n          &quot;description&quot;: &quot;Returns all rotor parts if you have an Admin role. Returns just your rotor parts if you don&#39;t have this role.&quot;,\r\n          &quot;operationId&quot;: &quot;get-my-rotor-parts&quot;,\r\n          &quot;responses&quot;: {\r\n            &quot;200&quot;: {\r\n              &quot;description&quot;: &quot;successful operation&quot;,\r\n              &quot;content&quot;: {\r\n                &quot;application/json&quot;: {\r\n                  &quot;schema&quot;: {\r\n                    &quot;type&quot;: &quot;array&quot;,\r\n                    &quot;items&quot;: {\r\n                      &quot;$ref&quot;: &quot;#/components/schemas/RotorPartsResponseModel&quot;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;400&quot;: {\r\n              &quot;description&quot;: &quot;user_inactive_or_not_exist&quot;\r\n            },\r\n            &quot;403&quot;: {\r\n              &quot;description&quot;: &quot;unauthorized_to_use_rotor_parts&quot;\r\n            },\r\n            &quot;500&quot;: {\r\n              &quot;description&quot;: &quot;failed_fetch_user_profile&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;post&quot;: {\r\n          &quot;tags&quot;: [\r\n            &quot;Rotor Parts&quot;\r\n          ],\r\n          &quot;summary&quot;: &quot;Add Rotor Parts&quot;,\r\n          &quot;description&quot;: &quot;Adds a new rotor part for the current user. If you have API access, you can create up to two rotor parts.&quot;,\r\n          &quot;operationId&quot;: &quot;add-rotor-parts&quot;,\r\n          &quot;requestBody&quot;: {\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/UserRotorPartRequestModel&quot;\r\n                }\r\n              }\r\n            },\r\n            &quot;description&quot;: &quot;Model user rotor part model&quot;,\r\n            &quot;required&quot;: true\r\n          },\r\n          &quot;responses&quot;: {\r\n            &quot;200&quot;: {\r\n              &quot;description&quot;: &quot;successful operation&quot;,\r\n              &quot;content&quot;: {\r\n                &quot;application/json&quot;: {\r\n                  &quot;schema&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/CreateUserAccessKeyResponseModel&quot;\r\n                  }\r\n                }\r\n              }\r\n            },\r\n            &quot;400&quot;: {\r\n              &quot;description&quot;: &quot;invalid_expiry_access_key / already_have_two_access_keys / invalid_access_key_name_length / invalid_access_key_name&quot;\r\n            },\r\n            &quot;403&quot;: {\r\n              &quot;description&quot;: &quot;unauthorized_to_use_access_keys&quot;\r\n            },\r\n            &quot;409&quot;: {\r\n              &quot;description&quot;: &quot;duplicate_access_key_name&quot;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  },\r\n  &quot;tag_CloudAccounts&quot;: &quot;Same Format as above&quot;\r\n}\r\n```\r\n\r\n\r\nSo far, I&#39;ve tried using `reduce` to achieve this:\r\n\r\n```\r\n. as $all |  reduce .tags as $tag  ({}; . + {&quot;tag_&quot; + $tag.name: (($all.paths) | select(.[][].tags | contains([$tag.name]))) })\r\n```\r\n\r\nBut can&#39;t even make the query valid. Really lost at this point.\r\n\r\nAny help/pointers much appreciated",
        "link": "https://stackoverflow.com/questions/74424368/using-jq-how-to-split-openapi-3-0-file-into-chunks-based-on-the-tag-property",
        "title": "Using jq, how to split OpenAPI 3.0 file into chunks based on the tag property?"
    },
    {
        "tags": [
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668449736,
                "last_edit_date": 1668449736,
                "creation_date": 1668409646,
                "answer_id": 74427973,
                "question_id": 74427502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input is a stream of JSON arrays, you could use jq&#39;s `-s`/`--slurp` command-line option.  Join the first array with comma, the second array with &quot;x&quot;; and finally join both strings with a space:\r\n\r\n```\r\n$ jq -sr &#39;[(.[0]|join(&quot;,&quot;)), (.[1]|join(&quot;x&quot;))] | join(&quot; &quot;)&#39; &lt;&lt;JSON\r\n[\r\n  3067,\r\n  584\r\n]\r\n[\r\n  764,\r\n  487\r\n]\r\nJSON\r\n3067,584 764x487\r\n```\r\n\r\nAlternatively, simply use string interpolation:\r\n\r\n```\r\njq -sr &#39;&quot;\\(.[0][0]),\\(.[0][1]) \\(.[1][0])x\\(.[1][1])&quot;&#39;\r\n```",
                "title": "Formating window values with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668410406,
                "creation_date": 1668410406,
                "answer_id": 74428114,
                "question_id": 74427502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution that does not `--slurp` would be using `input` for every other array:\r\n~~~sh\r\njq -r &#39;join(&quot;,&quot;)+&quot; &quot;+(input|join(&quot;x&quot;))&#39;\r\n~~~\r\n~~~none\r\n3067,584 764x487\r\n~~~\r\n[Demo](https://jqplay.org/s/rn3W-Df7P6G)",
                "title": "Formating window values with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668449736,
        "creation_date": 1668405902,
        "question_id": 74427502,
        "body_markdown": "I would like to take the json output of window values from a program. The output of it currently is:\r\n\r\n```\r\n[\r\n  3067,\r\n  584\r\n]\r\n[\r\n  764,\r\n  487\r\n]\r\n```\r\n\r\nBut I need it to be formatted like: ```3067,584 764x487```. How would I go about doing this using jq or other commands?\r\n\r\nI&#39;m not very experienced with jq and json formatting in general, so I&#39;m not really sure where to start. I have tried looking this up but am still not really sure how to do it.",
        "link": "https://stackoverflow.com/questions/74427502/formating-window-values-with-jq",
        "title": "Formating window values with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1066600,
                    "reputation": 22163,
                    "user_id": 1067003,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e3af2bd4b5604b0b661b5e6646544eba?s=256&d=identicon&r=PG",
                    "display_name": "hanshenrik",
                    "link": "https://stackoverflow.com/users/1067003/hanshenrik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668423089,
                "post_id": 74430389,
                "comment_id": 131393306,
                "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": 1,
                "creation_date": 1668427267,
                "post_id": 74430389,
                "comment_id": 131394535,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1668422885,
                "creation_date": 1668422885,
                "answer_id": 74430440,
                "question_id": 74430389,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.list.&quot;foo-beta&quot;.host&#39;\r\n```\r\n - but i&#39;m voting to close this question as a duplicate of https://stackoverflow.com/questions/37018393/how-to-use-jq-when-the-variable-has-reserved-characters",
                "title": "Parsing a JSON values using jq with key containing a &#39;-&#39; character"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668422885,
        "creation_date": 1668422636,
        "question_id": 74430389,
        "body_markdown": "I have a json file that looks like this:\r\n\r\n\t{\r\n\t\t&quot;list&quot;: {\r\n\t\t\t&quot;foo&quot;: {\r\n\t\t\t\t&quot;host&quot;: &quot;www.someurl1.com&quot;\r\n\t\t\t},\r\n\t\t\t&quot;bar&quot;: {\r\n\t\t\t\t&quot;host&quot;: &quot;www.someurl2.com&quot;\r\n\t\t\t},\r\n\t\t\t&quot;baz&quot;: {\r\n\t\t\t\t&quot;host&quot;: &quot;www.someurl3.com&quot;\r\n\t\t\t},\r\n\t\t\t&quot;foo-beta&quot;: {\r\n\t\t\t\t&quot;host&quot;: &quot;www.someurl4.com&quot;\r\n\t\t\t}\r\n\t\t},\r\n\t\t&quot;currentServer&quot;: &quot;foo-beta&quot;\r\n\t}\r\n\r\nWhen the value of `&quot;currentServer&quot;` is `&quot;foo&quot;` or `&quot;bar&quot;` or `&quot;baz&quot;`, I can read it using the following (for foo):\r\n\r\n    jq .list.foo.host test.json\r\n\r\nHowever, when value of `&quot;currentServer&quot;` is `&quot;foo-beta&quot;`, meaning anything that has a `&#39;-&#39;` character I get an error. I have tried the following:\r\n\r\n    jq .list[&quot;foo-beta&quot;].host test.json\r\n\r\nOr\r\n\r\n    jq .list.foo-beta.host test.json\r\n\r\nOr\r\n\r\n    jq .list | .[&quot;foo-beta&quot;].host test.json\r\n\r\nI&#39;m an Embedded Software engineer who usually works with low-level programming in C, haven&#39;t used `jq` much before and the constraint is using `jq` for this as the target platform has this requirement.\r\n\r\nAdditionally, is there a way I can come up with a `jq` command usage which will allow me to read the `&quot;currentServer&quot;&#39; and pass it as follows, or similar:\r\n\r\n    CURR_SERVER=jq currentServer test.json\r\n    CURR_SERVER_URL=jq .list.$CURR_SERVER.host test.json\r\n\r\n`jq` version I am using is v1.6.",
        "link": "https://stackoverflow.com/questions/74430389/parsing-a-json-values-using-jq-with-key-containing-a-character",
        "title": "Parsing a JSON values using jq with key containing a &#39;-&#39; character"
    },
    {
        "tags": [
            "json",
            "jq",
            "transform"
        ],
        "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": 1668455877,
                "post_id": 74432894,
                "comment_id": 131404615,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25850657,
                    "reputation": 1,
                    "user_id": 19584694,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/73b16e362a67a5d553f5e36efff862a7?s=256&d=identicon&r=PG",
                    "display_name": "Shivam Chetani",
                    "link": "https://stackoverflow.com/users/19584694/shivam-chetani"
                },
                "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": 1668491289,
                "post_id": 74432894,
                "comment_id": 131411526,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1668434690,
        "creation_date": 1668434647,
        "last_edit_date": 1668434690,
        "question_id": 74432894,
        "body_markdown": "I am using this library for JQ transformation.\r\n\r\nhttps://github.com/eiiches/jackson-jq/tree/master/0.x\r\n\r\nHow can we transform a number upto 2 precision?\r\nIs there any inbuilt function in jq for this?\r\nCurrently, It is supporting 1 precision\r\n.\r\n\r\n\r\n\r\n\r\nRequirement:\r\nfor ex: \r\n1 to 1.00,\r\n1.0 to 1.00,\r\n1.00 to 1.00,\r\n1.1 to 1.10. etc\r\n",
        "link": "https://stackoverflow.com/questions/74432894/jq-transform-a-number-upto-2-precision",
        "title": "JQ transform a number upto 2 precision"
    },
    {
        "tags": [
            "bash",
            "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": 1668454651,
                "post_id": 74436923,
                "comment_id": 131404262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668490681,
                "post_id": 74436923,
                "comment_id": 131411435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1668456653,
        "creation_date": 1668454407,
        "last_edit_date": 1668456653,
        "question_id": 74436923,
        "body_markdown": "How can I get the id value if name equals to `y` in cli?\r\n\r\nJSON input :\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;x&quot;,\r\n      &quot;name&quot;: &quot;y&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI&#39;ve tried this\r\n```\r\njson file | jq -r &#39;.items | select(.name==&quot;y&quot;)\r\n```\r\nit returns \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;name&quot;` error\r\n\r\nHow to retrieve the value of name only via jq?\r\n\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/74436923/how-to-retrieve-the-value-of-key-in-array-with-jq",
        "title": "How to retrieve the value of key in array with jq?"
    },
    {
        "tags": [
            "bash",
            "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": 2,
                "creation_date": 1668471565,
                "post_id": 74439340,
                "comment_id": 131408677,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10660136,
                    "reputation": 1329,
                    "user_id": 7848350,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/87ad61e783196e7b0cc6236f2397d63b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hcdocs",
                    "link": "https://stackoverflow.com/users/7848350/hcdocs"
                },
                "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": 1668473457,
                "post_id": 74439340,
                "comment_id": 131408999,
                "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": 1,
                "creation_date": 1668473887,
                "post_id": 74439340,
                "comment_id": 131409069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1668483656,
                "post_id": 74439340,
                "comment_id": 131410452,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1668498706,
                "post_id": 74439340,
                "comment_id": 131413235,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668495218,
                "creation_date": 1668495218,
                "answer_id": 74441632,
                "question_id": 74439340,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Almost. Variables are not automatically expanded within a string. You must interpolate them explicitly with `\\(…)`:\r\n\r\n```\r\njq --arg siteUrl &#39;docs.mysite.com&#39; &#39;.[].name |= (gsub(&quot; - https://\\($siteUrl)/&quot;; &quot;&quot;))&#39; file.json\r\n```\r\n\r\nAlternatively, detect a suffix match and extract the prefix by slicing:\r\n\r\n```\r\njq --arg siteUrl &#39;docs.mysite.com&#39; &#39;&quot; - https://\\($siteUrl)/&quot; as $suffix | (.[].name | select(endswith($suffix))) |= .[:$suffix|-length]&#39; file.json\r\n```",
                "title": "Replace string with Bash variable in jq command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697187026,
                "creation_date": 1697187026,
                "answer_id": 77286352,
                "question_id": 74439340,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I had a similar use-case but instead of passing in a variable, I wanted it to replace the string in one key (name) from a value in another key (url) within that same object. You can accomplish this for your example with the following:\r\n\r\n```bash\r\njq &#39;map(. as $dot | .name |= gsub(&quot;[ -]*&quot; + $dot.url + &quot;/?&quot;; &quot;&quot;))&#39;\r\n```\r\n\r\nYou can try it out at https://jqplay.org/s/SCO3_P8TmGP",
                "title": "Replace string with Bash variable in jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697187026,
        "creation_date": 1668471389,
        "question_id": 74439340,
        "body_markdown": "I realize this is a simple question but I haven&#39;t been able to find the answer. Thank you to anyone who may be able to help me understand what I am doing wrong.\r\n\r\nGoal: Search and replace a string in a specific key in a JSON file with a string in a Bash variable using jq.\r\n\r\nFor example, in the following JSON file:\r\n\r\n`&quot;name&quot;: &quot;Welcome - https://docs.mysite.com/&quot;,`\r\n\r\nwould become\r\n\r\n`&quot;name&quot;: &quot;Welcome&quot;,`\r\n\r\n\r\n**Input (file.json)**\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;https://docs.mysite.com&quot;,\r\n    &quot;name&quot;: &quot;Welcome - https://docs.mysite.com/&quot;,\r\n    &quot;Ocurrences&quot;: &quot;679&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://docs.mysite.com&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;Ocurrences&quot;: &quot;382&quot;\r\n  }\r\n]\r\n```\r\n\r\n**Failing script (using variable)**\r\n```\r\nsiteUrl=&quot;docs.mysite.com&quot;\r\n\r\njq --arg siteUrl &quot;$siteUrl&quot; &#39;.[].name|= (gsub(&quot; - https://$siteUrl/&quot;; &quot;&quot;))&#39; file.json &gt; file1.json`\r\n```\r\n\r\n**Desired output (file1.json)**\r\n```\r\n[\r\n  {\r\n    &quot;url&quot;: &quot;https://docs.mysite.com&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;Ocurrences&quot;: &quot;679&quot;\r\n  },\r\n  {\r\n    &quot;url&quot;: &quot;https://docs.mysite.com&quot;,\r\n    &quot;name&quot;: &quot;Welcome&quot;,\r\n    &quot;Ocurrences&quot;: &quot;382&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve tried various iterations on removing quotes, changing between `&#39;` and `&quot;`, and adding and removing backslashes.\r\n\r\n**Successful script (not using variable)**\r\n```\r\njq &#39;.[].name|= (gsub(&quot; - https://docs.mysite.com/&quot;; &quot;&quot;))&#39; file.json &gt; file1.json\r\n```\r\n\r\nMore specifically, if it matters, I am processing an export of a website&#39;s usage data from Azure App Insights. Unfortunately, the same page may be assigned different names. I sum the `Ocurrences` of the two objects with the newly identical `url` later. If it is better to fix this in App Insights I am grateful for that insight, although I know Bash better than Kusto queries. I am grateful for any help or direction.",
        "link": "https://stackoverflow.com/questions/74439340/replace-string-with-bash-variable-in-jq-command",
        "title": "Replace string with Bash variable in jq command"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1668495586,
                "last_edit_date": 1668495586,
                "creation_date": 1668495109,
                "answer_id": 74441611,
                "question_id": 74440061,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to return entities only if they match a condition. Substring matches can be tested with `contains`:\r\n\r\n```\r\nselect(.ResourceARN|contains(&quot;vm-managed-itg&quot;))\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1&quot;,\r\n  &quot;Tags&quot;: []\r\n}\r\n{\r\n  &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test&quot;,\r\n  &quot;Tags&quot;: []\r\n}\r\n```\r\n\r\nIf you are only interested in the values of `ResourceARN`, without tags and surrounding objects, then:\r\n\r\n```\r\n.ResourceARN | select(contains(&quot;vm-managed-itg&quot;))\r\n```\r\n\r\njq applies the filter to every single JSON entity in its input (which is a stream of objects).\r\n\r\nOutput:\r\n\r\n```\r\n&quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1&quot;\r\n&quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test&quot;\r\n```\r\n\r\n(`jq -r` for raw output without quotes).",
                "title": "Extracting output of aws command and assign it to a variable in bash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668528652,
        "creation_date": 1668480081,
        "last_edit_date": 1668528652,
        "question_id": 74440061,
        "body_markdown": "Following aws command outputs the below json from which I want to extract the resources which is having the string &quot;vm-managed-itg* values ( last two entries in the output)\r\n\r\n&gt; $aws resourcegroupstaggingapi get-resources --resource-type-filters\r\n&gt; cloudwatch:alarm --profile acc | jq &#39;.ResourceTagMappingList[] |\r\n&gt; select(contains({Tags: [{Key: &quot;vm:cost:accountenv&quot;} ]}) | not) |\r\n&gt; select(contains({Tags: [{Value: &quot;itg&quot;} ]}) | not)&#39;\r\n\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-uat-test&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-stg-test&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-uat-test3&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-stg-test1&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test1&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n    {\r\n      &quot;ResourceARN&quot;: &quot;arn:aws:cloudwatch:us-east-1:xxxx:alarm:vm-managed-itg-test&quot;,\r\n      &quot;Tags&quot;: []\r\n    }\r\n\r\nI tried adding jq -r &#39;.[].ResourceARN&#39; but it didn&#39;t work and instead threw this error\r\n\r\n    ~$ aws resourcegroupstaggingapi get-resources --resource-type-filters cloudwatch:alarm --profile per-acc --output json | jq &#39;.ResourceTagMappingList[] | select(contains({Tags: [{Key: &quot;vm:cost:accountenv&quot;} ]}) | not) | select(contains({Tags: [{Value: &quot;itg&quot;} ]}) | not)&#39; | jq -r &#39;.[].ResourceARN&#39;\r\n    jq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:12): Cannot index string with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:16): Cannot index string with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:20): Cannot index string with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:24): Cannot index string with string &quot;ResourceARN&quot;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74440061/extracting-output-of-aws-command-and-assign-it-to-a-variable-in-bash-using-jq",
        "title": "Extracting output of aws command and assign it to a variable in bash using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1668494672,
                "post_id": 74441486,
                "comment_id": 131412152,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668495010,
                "post_id": 74441486,
                "comment_id": 131412221,
                "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": 1668495020,
                "post_id": 74441486,
                "comment_id": 131412222,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20439299,
                    "reputation": 115,
                    "user_id": 14996394,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HVRFX37s1GU/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucniEprGZ91VFhGV_fJwLlxE_EJnOw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Ajay Sabarish",
                    "link": "https://stackoverflow.com/users/14996394/ajay-sabarish"
                },
                "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": 1668495038,
                "post_id": 74441486,
                "comment_id": 131412227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20439299,
                    "reputation": 115,
                    "user_id": 14996394,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-HVRFX37s1GU/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucniEprGZ91VFhGV_fJwLlxE_EJnOw/s96-c/s256-rj/photo.jpg",
                    "display_name": "Ajay Sabarish",
                    "link": "https://stackoverflow.com/users/14996394/ajay-sabarish"
                },
                "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": 1668495325,
                "post_id": 74441486,
                "comment_id": 131412292,
                "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": 1668495360,
                "post_id": 74441486,
                "comment_id": 131412302,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1668499013,
                "last_edit_date": 1668499013,
                "creation_date": 1668495269,
                "answer_id": 74441642,
                "question_id": 74441486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON in a file named input.json, then based on my understanding of the requirements, you could go with:\r\n\r\n```\r\njq --argjson limit 7.0 &#39;\r\n  any(.. | select(type==&quot;object&quot; and (.base_score|type==&quot;number&quot;)) | .base_score; . &gt; $limit)\r\n  | halt_error(if . then 1 else 0 end)\r\n&#39; input.json\r\n```\r\n\r\nYou can modify the argument to `halt_error` to set the exit code as you wish. \r\n\r\nNote that `halt_error` redirects its input to stderr, so you might want to append `2&gt; /dev/null` (or the equivalent expression appropriate for your shell) to the above invocation.",
                "title": "filter keys in JSON using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668530474,
                "last_edit_date": 1668530474,
                "creation_date": 1668496002,
                "answer_id": 74441746,
                "question_id": 74441486,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can easily get a stream of `base_score` values at any level and use that with `any`:\r\n\r\n```\r\nany(..|.base_score?; . &gt; 7)\r\n```\r\n\r\nThe stream will contain `null` values for objects without the property, but null is not greater than any number, so that shouldn&#39;t be a stopper.\r\n\r\nYou could then compare the output or specify `-e`/`--exit-status` to be used with a condition directly:\r\n\r\n```\r\njq -e &#39;any(..|.base_score?; . &gt; 7)&#39; complexnestedfile.json &gt;/dev/null &amp;&amp; exit 1\r\n```",
                "title": "filter keys in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668530474,
        "creation_date": 1668494446,
        "last_edit_date": 1668495159,
        "question_id": 74441486,
        "body_markdown": "I am having a complex nested json \r\n\r\n```\r\n{\r\n...\r\n&quot;key1&quot;: {\r\n   &quot;key2&quot; : [\r\n       { ...\r\n         &quot;base_score&quot; :4.5\r\n       }\r\n    ]\r\n&quot;key3&quot;: {\r\n\r\n       &quot;key4&quot;: [\r\n         { ...\r\n           &quot;base_score&quot; : 0.5 \r\n           ...\r\n         }\r\n       ]\r\n\r\n       }\r\n...\r\n\r\n    }\r\n}\r\n\r\n```\r\nThere maybe multiple &quot;base_score&quot; in the json(&quot;base_score&quot; path is unknown) and the corresponding value will be a number, I have to check if at least one such value is greater than some known value 7.0, and if there is, I have to do &quot;exit 1&quot;. I have to write this query in shell script.",
        "link": "https://stackoverflow.com/questions/74441486/filter-keys-in-json-using-jq",
        "title": "filter keys in JSON using jq"
    },
    {
        "tags": [
            "regex",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3391382,
                    "reputation": 5187,
                    "user_id": 2846138,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2sp68.png?s=256",
                    "display_name": "cyberbrain",
                    "link": "https://stackoverflow.com/users/2846138/cyberbrain"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1668520271,
                "post_id": 74446715,
                "comment_id": 131421161,
                "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": 1,
                "creation_date": 1668520324,
                "post_id": 74446715,
                "comment_id": 131421181,
                "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": 1668526897,
                "post_id": 74446715,
                "comment_id": 131424163,
                "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": 1668530064,
                "post_id": 74446715,
                "comment_id": 131425483,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668530165,
                "creation_date": 1668530165,
                "answer_id": 74449158,
                "question_id": 74446715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`example-*` matches strings that contain `example` followed by zero or more `-`.\r\n\r\n`^example-` matches strings that start with `example-`.\r\n\r\n```sh\r\njq -r &#39;.SecretList[].Name | select( test( &quot;^example-&quot; ) )&#39;\r\n```",
                "title": "How do I get the regex to return more accurately?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668530902,
                "creation_date": 1668530902,
                "answer_id": 74449328,
                "question_id": 74446715,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A regular expression is not a shell glob/wildcard. `*` in a regex does not mean &quot;anything&quot;, but rather &quot;whatever came before is repeated 0 or more times&quot;. `.` is a single arbitrary character. `.*` are 0 or more arbitrary characters.\r\n\r\nIf you want to match &quot;example-&quot; and don&#39;t care what comes after, simply use the regex `example-`. If you want to match &quot;example-&quot;, then anything or nothing, then &quot;_key&quot;, use the regex `example-.*_key`.\r\n\r\n```\r\njq -r &#39;.SecretList[].Name | select(test(&quot;example-&quot;))&#39;\r\n```",
                "title": "How do I get the regex to return more accurately?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1668530902,
        "creation_date": 1668519956,
        "question_id": 74446715,
        "body_markdown": "I am trying to get the regex right to return one or the other but not both:\r\nWhen I run for example the following:\r\n\r\n    aws secretsmanager list-secrets | jq -r &quot;.SecretList[] | select(.Name|match(\\&quot;example-*\\&quot;)) | .Name &quot;\r\nit returns\r\n\r\n    example-secret_key\r\nas well as\r\n\r\n    examplecompany-secret_key\r\n\r\n\r\nhow can I modify the command to return one and not the other? Thanks",
        "link": "https://stackoverflow.com/questions/74446715/how-do-i-get-the-regex-to-return-more-accurately",
        "title": "How do I get the regex to return more accurately?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": true,
                "score": 8,
                "last_activity_date": 1668522537,
                "creation_date": 1668522537,
                "answer_id": 74447286,
                "question_id": 74447285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I did find a solution while I was writing the question: don&#39;t put the input inside string interpolation, output a stream of things:\r\n\r\n```sh\r\necho &#39;{&quot;foo&quot;:&quot;bar&quot;, &quot;baz&quot;:[1,2,3]}&#39; | jq -r &#39;&quot;My value is:&quot;, . , &quot;Some other stuff&quot;&#39;\r\n# .........................................................^^^^^\r\n```\r\noutputs\r\n```\r\nMy value is:\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: [\r\n    1,\r\n    2,\r\n    3\r\n  ]\r\n}\r\nSome other stuff\r\n```\r\n",
                "title": "Pretty printing in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668522881,
                "creation_date": 1668522881,
                "answer_id": 74447374,
                "question_id": 74447285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might not fit your actual use case, but instead of creating a single JSON string in `jq`, just use a shell command group.\r\n\r\n    echo &#39;{&quot;foo&quot;:&quot;bar&quot;, &quot;baz&quot;:[1,2,3]}&#39; | { echo &quot;My value is:&quot;; jq .; echo &quot;Some other stuff&quot;; }",
                "title": "Pretty printing in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1668522881,
        "creation_date": 1668522537,
        "question_id": 74447285,
        "body_markdown": "`jq .` has the side-effect of pretty printing the input.\r\n\r\n```sh\r\n$ echo &#39;{&quot;foo&quot;:&quot;bar&quot;, &quot;baz&quot;:[1,2,3]}&#39; | jq .\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: [\r\n    1,\r\n    2,\r\n    3\r\n  ]\r\n}\r\n```\r\nBut if I want to use [tag:jq] to incorporate the input with some surrounding text, the input renders compactly\r\n```sh\r\n$ echo &#39;{&quot;foo&quot;:&quot;bar&quot;, &quot;baz&quot;:[1,2,3]}&#39; | jq -r &#39;&quot;My value is:\\n\\(.)\\nSome other stuff&quot;&#39;\r\nMy value is:\r\n{&quot;foo&quot;:&quot;bar&quot;,&quot;baz&quot;:[1,2,3]}\r\nSome other stuff\r\n```\r\n\r\nIs there any way to force pretty printing here? I&#39;d like the output to be\r\n```\r\nMy value is:\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: [\r\n    1,\r\n    2,\r\n    3\r\n  ]\r\n}\r\nSome other stuff\r\n```",
        "link": "https://stackoverflow.com/questions/74447285/pretty-printing-in-jq",
        "title": "Pretty printing in jq"
    },
    {
        "tags": [
            "json",
            "curl",
            "cmd",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668617214,
                "post_id": 74460794,
                "comment_id": 131450660,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26950545,
                    "reputation": 13,
                    "user_id": 20519844,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n0aAw.jpg?s=256",
                    "display_name": "Randy",
                    "link": "https://stackoverflow.com/users/20519844/randy"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669125192,
                "post_id": 74460794,
                "comment_id": 131568972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669138139,
                "post_id": 74460794,
                "comment_id": 131574300,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26950545,
                    "reputation": 13,
                    "user_id": 20519844,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/n0aAw.jpg?s=256",
                    "display_name": "Randy",
                    "link": "https://stackoverflow.com/users/20519844/randy"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1671524658,
                "post_id": 74460794,
                "comment_id": 132112217,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1671524519,
                "creation_date": 1671524519,
                "answer_id": 74860215,
                "question_id": 74460794,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This took me soo long but.. i have the first part working.\r\n\r\nSolved!\r\n\r\n    for i in $(cat &quot;c:\\Test\\output.json&quot; | jq -r .[].employerReferenceId); do\r\n\r\nAfter this part is start the Curl Command, wich also works fine till the data part, and thats where im stuck now.\r\n\r\n    curl -X POST &quot;https://website.eu/test-Company/api2/external-employees/$i&quot; -H &quot;accept: application/json&quot; -H &quot;Authorization: Token {TOKEN}&quot; -H &quot;Content-Type: application/json&quot; -d &quot;EXAMPLE: $initials:value $firstName:value $lastNamePrefix:value $lastName:value $employerReferenceId:value $jobDescription:value&quot;\r\n\r\nProblem: how to reffer to the corresponding value&#39;s that belong to person in $i in the curl command data section.\r\n\r\n",
                "title": "Separate &quot;Curl POST&#39;s&quot; with data from json file - Windows CMD Shell"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1671902896,
                "creation_date": 1671902896,
                "answer_id": 74909270,
                "question_id": 74460794,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might be interested in the JSON-parser [tag:xidel], for which this is a relatively easy task.  \r\nNo need for FOR-loops. One `xidel` call could be enough.\r\n```\r\nxidel -s &quot;OUTPUT.JSON&quot; -e ^&quot;^\r\n  for $x in $json() return^\r\n  x:request({^\r\n    &#39;headers&#39;:(^\r\n      &#39;accept: application/json&#39;,^\r\n      &#39;Authorization: Token %TOKEN%&#39;,^\r\n      &#39;Content-Type: application/json&#39;^\r\n    ),^\r\n    &#39;post&#39;:serialize($x,{&#39;method&#39;:&#39;json&#39;}),^\r\n    &#39;url&#39;:&#39;https://website.eu/test-Company/api2/external-employees/&#39;^|^|$x/employerReferenceId^\r\n  })/json^\r\n&quot;\r\n```\r\nThis is the [tag:cmd] prettified version (with the necessary escape-characters).  \r\nOr alternatively the minified version:\r\n```\r\nxidel -s &quot;OUTPUT.JSON&quot; -e &quot;for $x in $json() return x:request({&#39;headers&#39;:(&#39;accept: application/json&#39;,&#39;Authorization: Token %TOKEN%&#39;,&#39;Content-Type: application/json&#39;),&#39;post&#39;:serialize($x,{&#39;method&#39;:&#39;json&#39;}),&#39;url&#39;:&#39;https://website.eu/test-Company/api2/external-employees/&#39;||$x/employerReferenceId})&quot;\r\n```\r\nFor each JSON-object (person) [`x:request()`](https://www.benibela.de/documentation/internettools/xpath-functions.html#x-request) sends a POST-request. As you can see, it accepts options as a JSON-object.\r\n\r\n - The 3 headers you can simply add as a sequence. (*this is assuming the `%TOKEN%`-variable is set beforehand*)\r\n - The POST-data needs to be serialized! For the first JSON-object for instance this will be POSTed:\r\n```\r\n{&quot;initials&quot;:&quot;V.&quot;,&quot;firstName&quot;:&quot;Victor&quot;,&quot;lastNamePrefix&quot;:&quot; &quot;,&quot;lastName&quot;:&quot;Rutherford&quot;,&quot;employerReferenceId&quot;:&quot;0258741&quot;,&quot;jobDescription&quot;:&quot;Rental&quot;}\r\n```\r\n - The base-url with the value of the `employerReferenceId`-attribute added. The url for the first JSON-object for instance: `https://website.eu/test-Company/api2/external-employees/0258741`.\r\n - `x:request()`&#39;s output is also a JSON-object. If this url/api also returns JSON, then you can parse it by selecting the `json`-attribute: `x:request(...)/json`. If not, then `x:request(...)/raw`.",
                "title": "Separate &quot;Curl POST&#39;s&quot; with data from json file - Windows CMD Shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1671902896,
        "creation_date": 1668603255,
        "last_edit_date": 1668665909,
        "question_id": 74460794,
        "body_markdown": "I&#39;m working on an API connection, I am receiving JSON datasets which contain multiple objects and I&#39;m trying to pass that through to the next system.\r\n\r\nThe JSON dataset has the following information (OUTPUT.JSON):\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;initials&quot;: &quot;V.&quot;,\r\n    &quot;firstName&quot;: &quot;Victor&quot;,\r\n    &quot;lastNamePrefix&quot;: &quot; &quot;,\r\n    &quot;lastName&quot;: &quot;Rutherford&quot;,\r\n    &quot;employerReferenceId&quot;: &quot;0258741&quot;,\r\n    &quot;jobDescription&quot;: &quot;Rental&quot;\r\n  },\r\n  {\r\n   &quot;initials&quot;: &quot;P.&quot;,\r\n    &quot;firstName&quot;: &quot;Pippa&quot;,\r\n    &quot;lastNamePrefix&quot;: &quot; &quot;,\r\n    &quot;lastName&quot;: &quot;Lewis&quot;,\r\n    &quot;employerReferenceId&quot;: &quot;98765431&quot;,\r\n    &quot;jobDescription&quot;: &quot;Rental&quot;\r\n  },\r\n  {\r\n    &quot;initials&quot;: &quot;S.&quot;,\r\n    &quot;firstName&quot;: &quot;Stephanie&quot;,\r\n    &quot;lastNamePrefix&quot;: &quot; &quot;,\r\n    &quot;lastName&quot;: &quot;Reid&quot;,\r\n    &quot;employerReferenceId&quot;: &quot;123456789&quot;,\r\n    &quot;jobDescription&quot;: &quot;Rental&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe API post I&#39;m trying to do has to be a separate Post for each object (person) in the JSON datafile.\r\nThis because the post has to have the referencenumber of the EMPLOYERREFEREBCEID in the URL for each post, but the post also needs to only have the section of data that belongs to that EMPLOYERREFEREBCEID in the JSON file.\r\n\r\n```\r\ncurl -X POST &quot;https://website.eu/test-Company/api2/external-employees/[EMPLOYERREFEREBCEID]&quot; -H &quot;accept: application/json&quot; -H &quot;Authorization: Token {TOKEN}&quot; -H &quot;Content-Type: application/json&quot; -d &quot;@output.json&quot;\r\n```\r\n\r\nI did found an old post that works with JQ and Bash, but since I am running Windows Server 2016 this is going to be challenging\r\n\r\n```\r\nfor (( i = 0 ; i &lt; ${#id[@]} ; i++ ))\r\ndo \r\n     POST REST API \r\ndone\r\n```\r\nhttps://unix.stackexchange.com/questions/271307/post-json-data-with-curl-from-a-while-loop-bash-shell",
        "link": "https://stackoverflow.com/questions/74460794/separate-curl-posts-with-data-from-json-file-windows-cmd-shell",
        "title": "Separate &quot;Curl POST&#39;s&quot; with data from json file - Windows CMD Shell"
    },
    {
        "tags": [
            "windows",
            "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": 0,
                "creation_date": 1668613727,
                "post_id": 74463432,
                "comment_id": 131449218,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3047853,
                    "reputation": 1552,
                    "user_id": 2583044,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e389ae8a908e2c80cca150bcbbf827ed?s=256&d=identicon&r=PG",
                    "display_name": "62mkv",
                    "link": "https://stackoverflow.com/users/2583044/62mkv"
                },
                "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": 1668614142,
                "post_id": 74463432,
                "comment_id": 131449401,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668614492,
                "creation_date": 1668614492,
                "answer_id": 74463626,
                "question_id": 74463432,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When [constructing objects](https://stedolan.github.io/jq/manual/#ObjectConstruction%3A%7B%7D) with expressions as key or value, the expression needs to be surrounded by parentheses:\r\n~~~sh\r\njq &quot;{b: (6-.a)}&quot; input.json\r\n~~~\r\n~~~json\r\n{\r\n  &quot;b&quot;: 2\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/uruJW0VTop8)",
                "title": "How to do jq arithmetic under Windows"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668614492,
        "creation_date": 1668613656,
        "question_id": 74463432,
        "body_markdown": "I am reading the `jq` manual and it says, that `+` and `-` operations on number should &quot;just work&quot;. However, I can&#39;t seem to be able to use them in almost any operation, for example, in object construction\r\n\r\nGiven `input.json` as `{&quot;a&quot;: 4}`\r\n\r\nthis command: \r\n```\r\njq &quot;6-.a&quot; input.json\r\n```\r\nproduces \r\n```\r\n2\r\n```\r\n\r\nbut this command: \r\n```\r\njq &quot;{b: 6-.a}&quot; input.json\r\n```\r\n\r\nproduces\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;-&#39;, expecting &#39;}&#39; (Windows cmd shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n{b: 6-.a}     \r\njq: 1 compile error\r\n```\r\n\r\nHow to work this around? Thanks",
        "link": "https://stackoverflow.com/questions/74463432/how-to-do-jq-arithmetic-under-windows",
        "title": "How to do jq arithmetic under Windows"
    },
    {
        "tags": [
            "json",
            "grep",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668622531,
                "creation_date": 1668622531,
                "answer_id": 74465340,
                "question_id": 74465242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//`, you can default to something else if the input happens to be falsy. With the `empty` [function](https://stedolan.github.io/jq/manual/#empty), you can simply discard that input.\r\n~~~sh\r\njq -r &#39;.[] | &quot;\\(.name) \\(.version // empty)&quot;&#39;\r\n~~~\r\n~~~\r\nPolymer 3.5.0\r\nHammer.js 2.0.2\r\n~~~\r\n[Demo](https://jqplay.org/s/OvaWk5kO4w3)",
                "title": "Return the value, if another value exists using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1668696056,
                "last_edit_date": 1668696056,
                "creation_date": 1668624800,
                "answer_id": 74465747,
                "question_id": 74465242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate to @pmf&#39;s solution, making the same assumptions about the structure of the data: select the objects that have a &quot;truthy&quot; version:\r\n```sh\r\njq -r &#39;.[] | select(.version) | &quot;\\(.name) \\(.version)&quot;&#39; file.json\r\n```\r\n\r\n---\r\nWith the corrected input data, you want\r\n```sh\r\njq -r &#39;.technologies[] | select(.version) | &quot;\\(.name) \\(.version)&quot;&#39; file.json\r\n# .....^^^^^^^^^^^^^^^\r\n```\r\nSame change for @pmf&#39;s solution.",
                "title": "Return the value, if another value exists using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668696056,
        "creation_date": 1668621946,
        "last_edit_date": 1668678497,
        "question_id": 74465242,
        "body_markdown": "I have a json fragment like below. I want to return the value of the name key together with the value of the version key if the version key has a value. The expected output is &quot;name&quot;: &quot;value&quot; , &quot;version&quot; : &quot;value&quot;\r\n\r\nIt is better to have a solution with grep or jq.\r\n\r\n\r\n    node ~/wappalyzer/src/drivers/npm/cli.js https://youtube.com | jq .\r\n\r\n\r\nResult:\r\n```json\r\n{\r\n  &quot;urls&quot;: {\r\n    &quot;https://youtube.com/&quot;: {\r\n      &quot;status&quot;: 301\r\n    },\r\n    &quot;https://www.youtube.com/&quot;: {\r\n      &quot;status&quot;: 200\r\n    }\r\n  },\r\n  &quot;technologies&quot;: [\r\n    {\r\n      &quot;slug&quot;: &quot;youtube&quot;,\r\n      &quot;name&quot;: &quot;YouTube&quot;,\r\n      &quot;description&quot;: &quot;YouTube is a video sharing service where users can create their own profile, upload videos, watch, like and comment on other videos.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;YouTube.png&quot;,\r\n      &quot;website&quot;: &quot;http://www.youtube.com&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 14,\r\n          &quot;slug&quot;: &quot;video-players&quot;,\r\n          &quot;name&quot;: &quot;Video players&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;polymer&quot;,\r\n      &quot;name&quot;: &quot;Polymer&quot;,\r\n      &quot;description&quot;: null,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: &quot;3.5.0&quot;,\r\n      &quot;icon&quot;: &quot;Polymer.png&quot;,\r\n      &quot;website&quot;: &quot;http://polymer-project.org&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 12,\r\n          &quot;slug&quot;: &quot;javascript-frameworks&quot;,\r\n          &quot;name&quot;: &quot;JavaScript frameworks&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;google-ads&quot;,\r\n      &quot;name&quot;: &quot;Google Ads&quot;,\r\n      &quot;description&quot;: &quot;Google Ads is an online advertising platform developed by Google.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;Google Ads.svg&quot;,\r\n      &quot;website&quot;: &quot;https://ads.google.com&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 36,\r\n          &quot;slug&quot;: &quot;advertising&quot;,\r\n          &quot;name&quot;: &quot;Advertising&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;hammer-js&quot;,\r\n      &quot;name&quot;: &quot;Hammer.js&quot;,\r\n      &quot;description&quot;: null,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: &quot;2.0.2&quot;,\r\n      &quot;icon&quot;: &quot;Hammer.js.png&quot;,\r\n      &quot;website&quot;: &quot;https://hammerjs.github.io&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 59,\r\n          &quot;slug&quot;: &quot;javascript-libraries&quot;,\r\n          &quot;name&quot;: &quot;JavaScript libraries&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;google-font-api&quot;,\r\n      &quot;name&quot;: &quot;Google Font API&quot;,\r\n      &quot;description&quot;: &quot;Google Font API is a web service that supports open-source font files that can be used on your web designs.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;Google Font API.png&quot;,\r\n      &quot;website&quot;: &quot;http://google.com/fonts&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 17,\r\n          &quot;slug&quot;: &quot;font-scripts&quot;,\r\n          &quot;name&quot;: &quot;Font scripts&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;recaptcha&quot;,\r\n      &quot;name&quot;: &quot;reCAPTCHA&quot;,\r\n      &quot;description&quot;: &quot;reCAPTCHA is a free service from Google that helps protect websites from spam and abuse.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;reCAPTCHA.svg&quot;,\r\n      &quot;website&quot;: &quot;https://www.google.com/recaptcha/&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 16,\r\n          &quot;slug&quot;: &quot;security&quot;,\r\n          &quot;name&quot;: &quot;Security&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;google-ads-conversion-tracking&quot;,\r\n      &quot;name&quot;: &quot;Google Ads Conversion Tracking&quot;,\r\n      &quot;description&quot;: &quot;Google Ads Conversion Tracking is a free tool that shows you what happens after a customer interacts with your ads.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;Google.svg&quot;,\r\n      &quot;website&quot;: &quot;https://support.google.com/google-ads/answer/1722022&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 10,\r\n          &quot;slug&quot;: &quot;analytics&quot;,\r\n          &quot;name&quot;: &quot;Analytics&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;hsts&quot;,\r\n      &quot;name&quot;: &quot;HSTS&quot;,\r\n      &quot;description&quot;: &quot;HTTP Strict Transport Security (HSTS) informs browsers that the site should only be accessed using HTTPS.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;default.svg&quot;,\r\n      &quot;website&quot;: &quot;https://www.rfc-editor.org/rfc/rfc6797#section-6.1&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 16,\r\n          &quot;slug&quot;: &quot;security&quot;,\r\n          &quot;name&quot;: &quot;Security&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;webpack&quot;,\r\n      &quot;name&quot;: &quot;webpack&quot;,\r\n      &quot;description&quot;: &quot;Webpack is an open-source JavaScript module bundler.&quot;,\r\n      &quot;confidence&quot;: 50,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;webpack.svg&quot;,\r\n      &quot;website&quot;: &quot;https://webpack.js.org/&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 19,\r\n          &quot;slug&quot;: &quot;miscellaneous&quot;,\r\n          &quot;name&quot;: &quot;Miscellaneous&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;pwa&quot;,\r\n      &quot;name&quot;: &quot;PWA&quot;,\r\n      &quot;description&quot;: &quot;Progressive Web Apps (PWAs) are web apps built and enhanced with modern APIs to deliver enhanced capabilities, reliability, and installability while reaching anyone, anywhere, on any device, all with a single codebase.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;PWA.svg&quot;,\r\n      &quot;website&quot;: &quot;https://web.dev/progressive-web-apps/&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 19,\r\n          &quot;slug&quot;: &quot;miscellaneous&quot;,\r\n          &quot;name&quot;: &quot;Miscellaneous&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;open-graph&quot;,\r\n      &quot;name&quot;: &quot;Open Graph&quot;,\r\n      &quot;description&quot;: &quot;Open Graph is a protocol that is used to integrate any web page into the social graph.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;Open Graph.png&quot;,\r\n      &quot;website&quot;: &quot;https://ogp.me&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 19,\r\n          &quot;slug&quot;: &quot;miscellaneous&quot;,\r\n          &quot;name&quot;: &quot;Miscellaneous&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;module-federation&quot;,\r\n      &quot;name&quot;: &quot;Module Federation&quot;,\r\n      &quot;description&quot;: &quot;Module Federation is a webpack technology for dynamically loading parts of other independently deployed builds.&quot;,\r\n      &quot;confidence&quot;: 50,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;Module Federation.png&quot;,\r\n      &quot;website&quot;: &quot;https://webpack.js.org/concepts/module-federation/&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 19,\r\n          &quot;slug&quot;: &quot;miscellaneous&quot;,\r\n          &quot;name&quot;: &quot;Miscellaneous&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;slug&quot;: &quot;http-3&quot;,\r\n      &quot;name&quot;: &quot;HTTP/3&quot;,\r\n      &quot;description&quot;: &quot;HTTP/3 is the third major version of the Hypertext Transfer Protocol used to exchange information on the World Wide Web.&quot;,\r\n      &quot;confidence&quot;: 100,\r\n      &quot;version&quot;: null,\r\n      &quot;icon&quot;: &quot;HTTP3.svg&quot;,\r\n      &quot;website&quot;: &quot;https://httpwg.org/&quot;,\r\n      &quot;cpe&quot;: null,\r\n      &quot;categories&quot;: [\r\n        {\r\n          &quot;id&quot;: 19,\r\n          &quot;slug&quot;: &quot;miscellaneous&quot;,\r\n          &quot;name&quot;: &quot;Miscellaneous&quot;\r\n        }\r\n      ],\r\n      &quot;rootPath&quot;: true\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n**I expect this:**\r\n\r\nPolymer 3.5.0\r\n\r\nHammer.js 2.0.2\r\n",
        "link": "https://stackoverflow.com/questions/74465242/return-the-value-if-another-value-exists-using-jq",
        "title": "Return the value, if another value exists using jq"
    },
    {
        "tags": [
            "docker",
            "vue.js",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668633539,
                "post_id": 74465958,
                "comment_id": 131456246,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668633570,
                "post_id": 74465958,
                "comment_id": 131456250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668635463,
                "post_id": 74465958,
                "comment_id": 131456819,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12523895,
                    "reputation": 608,
                    "user_id": 9114389,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sdcON.png?s=256",
                    "display_name": "Vinicius Andrade",
                    "link": "https://stackoverflow.com/users/9114389/vinicius-andrade"
                },
                "reply_to_user": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668651985,
                "post_id": 74465958,
                "comment_id": 131459971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12523895,
                    "reputation": 608,
                    "user_id": 9114389,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sdcON.png?s=256",
                    "display_name": "Vinicius Andrade",
                    "link": "https://stackoverflow.com/users/9114389/vinicius-andrade"
                },
                "reply_to_user": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668652577,
                "post_id": 74465958,
                "comment_id": 131460056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1668984287,
                "post_id": 74465958,
                "comment_id": 131532921,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "reply_to_user": {
                    "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": 0,
                "creation_date": 1668990349,
                "post_id": 74465958,
                "comment_id": 131533861,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669294813,
                "last_edit_date": 1669294813,
                "creation_date": 1668980224,
                "answer_id": 74512204,
                "question_id": 74465958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m a `jq` novice, and I&#39;d be very interested in a better `jq` script, but here&#39;s one way to use environment variables to modify a `settings.json` file.  \r\n```bash\r\n$ cat settings.json \r\n{\r\n  &quot;apis&quot;: {\r\n    &quot;payment&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n    },\r\n    &quot;order&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n    }\r\n  },\r\n  &quot;features&quot;: {\r\n    &quot;authentication&quot;: {\r\n      &quot;authProviders&quot;: true,\r\n      &quot;registration&quot;: false\r\n    }\r\n  },\r\n  &quot;availableLocales&quot;: [\r\n    &quot;en&quot;,\r\n    &quot;es&quot;\r\n  ]\r\n}\r\n\r\n$ printenv|grep SETTINGS__\r\nSETTINGS__APIS__PAYMENT__BASE_URL=https://example2.com\r\nSETTINGS__AVAILABLELOCALES__0=cs\r\n\r\n$ jq -n &#39;\r\ninputs as $i\r\n| [ $i\r\n    | ..\r\n    | keys_unsorted?\r\n    | .[]\r\n    | strings\r\n  ]\r\n| unique as $allKeys\r\n|\r\ndef fixCase:\r\n  . as $w\r\n  | reduce ($allKeys[]|select(length == ($w|length))) as $k\r\n      (&quot;&quot;;. + $k|match($w;&quot;i&quot;).string)\r\n;\r\ndef envpaths:\r\n  [\r\n    $ENV\r\n    | to_entries[]\r\n    | select(.key | startswith(&quot;SETTINGS__&quot;))\r\n    | [[ (.key|split(&quot;__&quot;))[1:][]\r\n         | if test(&quot;^[0-9]+$&quot;) then tonumber else fixCase end\r\n       ],\r\n         .value\r\n      ]\r\n  ]\r\n;\r\nreduce envpaths[] as $p ($i; .|setpath($p[0];$p[1]))&#39; settings.json\r\n# the output\r\n{\r\n  &quot;apis&quot;: {\r\n    &quot;payment&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example2.com&quot;\r\n    },\r\n    &quot;order&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n    }\r\n  },\r\n  &quot;features&quot;: {\r\n    &quot;authentication&quot;: {\r\n      &quot;authProviders&quot;: true,\r\n      &quot;registration&quot;: false\r\n    }\r\n  },\r\n  &quot;availableLocales&quot;: [\r\n    &quot;cs&quot;,\r\n    &quot;es&quot;\r\n  ]\r\n}\r\n```\r\nSee it work on [jqplay.org](https://jqplay.org/s/2t8dYRCAPh6 &quot;Click me!&quot;).",
                "title": "Override json file values with environment variables docker"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669295037,
                "last_edit_date": 1669295037,
                "creation_date": 1669290283,
                "answer_id": 74560224,
                "question_id": 74465958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The task can be solved using [jq](https://stedolan.github.io/jq/).\r\nThe version is robust against settings that do not match a path in the document.\r\n\r\n**Variables**\r\n```\r\nSETTINGS__APIS__PAYMENT__BASE_URL=https://example2.com\r\nSETTINGS__AVAILABLELOCALES__0=cs\r\nSETTINGS__UNAVAILABLE__PATH=1\r\n```\r\n\r\n**Code**\r\n```bash\r\njq &#39;def settings:\r\n      def prepareVariables:\r\n        [$ENV | to_entries[] | select(.key | startswith(&quot;SETTINGS__&quot;))]   # select all variables that starts with &quot;SETTINGS__&quot;\r\n        | map(.key |= (. / &quot;__&quot; | map(tonumber? // .))[1:]);              # convert variable names to path arrays\r\n\r\n      [paths(scalars) | [., map(ascii_upcase? // .)]] |                   # collect all leaf paths from input file and add uppercase path\r\n      reduce .[] as $leafPath                                             # add leaf paths to corresponding settings\r\n             (prepareVariables; map(select($leafPath[1] == .key) |= . + {path: $leafPath[0]})) |\r\n      map(select(has(&quot;path&quot;)));                                           # drop settings for unknown paths\r\n\r\n    . as $input |\r\n    reduce settings[] as $setting                                         # apply new settings from variables to input file\r\n           ($input; . | setpath($setting[&quot;path&quot;]; $setting[&quot;value&quot;]))\r\n&#39; input.json\r\n```\r\n\r\n**Output**\r\n```json\r\n{\r\n  &quot;apis&quot;: {\r\n    &quot;payment&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example2.com&quot;\r\n    },\r\n    &quot;order&quot;: {\r\n      &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n    }\r\n  },\r\n  &quot;features&quot;: {\r\n    &quot;authentication&quot;: {\r\n      &quot;authProviders&quot;: true,\r\n      &quot;registration&quot;: false\r\n    }\r\n  },\r\n  &quot;availableLocales&quot;: [\r\n    &quot;cs&quot;,\r\n    &quot;es&quot;\r\n  ]\r\n}\r\n```",
                "title": "Override json file values with environment variables docker"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669295037,
        "creation_date": 1668625980,
        "last_edit_date": 1668789956,
        "question_id": 74465958,
        "body_markdown": "Assume that I&#39;ve a complex json file that is used to configurate my project. \r\n\r\nLike the json below: \r\n\r\n```json\r\n{\r\n    &quot;apis&quot;: {\r\n        &quot;payment&quot;: {\r\n            &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n        },\r\n        &quot;order&quot;: {\r\n            &quot;base_url&quot;: &quot;https://example.com/&quot;\r\n        },\r\n        \r\n    },\r\n    &quot;features&quot;: {\r\n        &quot;authentication&quot;: {\r\n            &quot;authProviders&quot;: true,\r\n            &quot;registration&quot;: false\r\n        }\r\n    },\r\n    &quot;availableLocales&quot;: [\r\n      &quot;en&quot;,\r\n      &quot;es&quot;\r\n    ]\r\n}\r\n```\r\n\r\nWith .Net there&#39;s a feature that allows us to override the values based on environment variables.\r\n\r\nIf I wanted to override the value of apis.payment.base_url I could pass an environment variable: **APIS__PAYMENT__BASE_URL** and the value would be replaced. \r\n\r\nSince I&#39;m currently not using .Net is there any alternatives? \r\nThis is what I&#39;m using right now, but this does not fit my needs\r\n\r\n```docker\r\nFROM code as prepare-build\r\nENV JQ_VERSION=1.6\r\nRUN wget --no-check-certificate \\\r\n    https://github.com/stedolan/jq/releases/download/jq-${JQ_VERSION}/jq-linux64 \\\r\n    -O /tmp/jq-linux64\r\nRUN cp /tmp/jq-linux64 /usr/bin/jq\r\nRUN chmod +x /usr/bin/jq\r\nWORKDIR /code/public\r\nRUN jq &#39;reduce path(recurse | scalars) as $p (.;setpath($p; &quot;$&quot; + ($p | join(&quot;_&quot;))))&#39; \\ \r\n    ./configurations/settings.json &gt; ./configurations/settings.temp.json &amp;&amp; \\\r\n    yez | cp ./configurations/settings.temp.json ./configurations/settings.json\r\nWORKDIR /code/deploy\r\nRUN echo &quot;#!/usr/bin/env sh&quot; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;export EXISTING_VARS=$(printenv | awk -F= &#39;\\&#39;&#39;{print $1}&#39;\\&#39;&#39; | sed &#39;\\&#39;&#39;s/^/\\$/g&#39;\\&#39;&#39; | paste -sd,);&#39; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;for file in $CONFIGURATIONS_FOLDER;&#39; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;do&#39; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;   cat $file | envsubst $EXISTING_VARS | tee $file&#39; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;done&#39; | tee -a /code/deploy/start.sh &gt; /dev/null &amp;&amp; \\\r\n    echo &#39;nginx -g &#39;\\&#39;&#39;daemon off;&#39;\\&#39;&#39;&#39; | tee -a /code/deploy/start.sh &gt; /dev/null\r\nWORKDIR /code\r\n```\r\n\r\nThis was I have a problem that, I need to pass all the json paths as environment variables, to override it correctly. If not, the variables will be replaced with the path of it, only. \r\n\r\nI think the best approach would be: \r\n\r\nRead the environment variables and create a json file with their values, then override the existing json file with the values of the created one. \r\n\r\nDoes anyone have any thing that could help me achieve this?\r\n\r\nTo summarize. \r\n\r\nIn order to make easy to identify which environment variables I should use, let&#39;s assume it will have a prefix of **SETTINGS**.\r\nExample of how I would override values.\r\n\r\n|         **JSON PATH**            |  **EQUIVALENT ENVIRONMENT VARIABLE**    |\r\n|             ----                 |       ----        |\r\n|  APIS.PAYMENT.BASE_URL           |     SETTINGS__APIS__PAYMENT__BASE_URL  |\r\n|   AVAILABLELOCALES[0]            | SETTINGS__AVAILABLELOCALES__0     |\r\n",
        "link": "https://stackoverflow.com/questions/74465958/override-json-file-values-with-environment-variables-docker",
        "title": "Override json file values with environment variables docker"
    },
    {
        "tags": [
            "json",
            "null",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1777088,
                    "reputation": 25,
                    "user_id": 1647396,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a3d33f100d4b798540df7abb729ae11c?s=256&d=identicon&r=PG",
                    "display_name": "jars99",
                    "link": "https://stackoverflow.com/users/1647396/jars99"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668629682,
                "post_id": 74466550,
                "comment_id": 131455103,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668630566,
                "creation_date": 1668630566,
                "answer_id": 74466828,
                "question_id": 74466550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use parentheses to exclude `.InstanceId` but include `&quot; &quot; + …` when failing:\r\n~~~sh\r\n{together: (.InstanceId + ((.Tags[] | &quot; &quot; + select(.Key == &quot;Name&quot;).Value)? // &quot;&quot;))}\r\n~~~\r\n~~~json\r\n{\r\n  &quot;together&quot;: &quot;i-abc Grafana&quot;\r\n}\r\n{\r\n  &quot;together&quot;: &quot;i-def&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/B9ezLjjEbmO)",
                "title": "How do I concatenate two strings with jq when one of them might be null?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668631787,
                "creation_date": 1668631787,
                "answer_id": 74467051,
                "question_id": 74466550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option would be to generate an array using `select()`, end then let `join(&quot; &quot;)` deal with the rest:\r\n```\r\n{ together: [ .InstanceId, (.Tags[]? | select(.Key==&quot;Name&quot;).Value)  ] | join(&quot; &quot;) }\r\n```\r\n```json\r\n{\r\n  &quot;together&quot;: &quot;i-abc Grafana&quot;\r\n}\r\n{\r\n  &quot;together&quot;: &quot;i-def&quot;\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [JqPlay](https://jqplay.org/s/B9ezLjjEbmO)",
                "title": "How do I concatenate two strings with jq when one of them might be null?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668635564,
                "creation_date": 1668635564,
                "answer_id": 74467677,
                "question_id": 74466550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t overcomplicate things:\r\n\r\n* Get rid of the no-op `.|`\r\n* Use the error-suppression operator (`?`) when accessing the optional property.\r\n* The empty string is `&quot;&quot;`, not `empty`. `empty` is a generator which generates nothing (with somewhat confusing effects).\r\n* Add parentheses to group expressions/define operator precedence.\r\n\r\n```\r\n{ together: (.InstanceId + &quot; &quot; + ((.Tags[]|select(.Key == &quot;Name&quot;).Value)? // &quot;&quot;)) }\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;together&quot;: &quot;i-abc Grafana&quot;\r\n}\r\n{\r\n  &quot;together&quot;: &quot;i-def &quot;\r\n}\r\n```\r\n\r\nIf you don&#39;t want to have the trailing blank, go with 0stone0&#39;s solution.",
                "title": "How do I concatenate two strings with jq when one of them might be null?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668637674,
                "creation_date": 1668637674,
                "answer_id": 74468024,
                "question_id": 74466550,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Before I got an answer, I asked a friend for help.  He responded with another method:\r\n```\r\ncat sample.json|jq -r &#39;((.Tags[]|select(.Key == &quot;Name&quot;).Value)? // &quot;&quot;) as $name|{together: (.InstanceId + &quot; &quot; + $name)}&#39;\r\n```",
                "title": "How do I concatenate two strings with jq when one of them might be null?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1668637674,
        "creation_date": 1668629094,
        "question_id": 74466550,
        "body_markdown": "I&#39;m trying to parse AWS instance metadata to take two values and combine them into one string (a name and an id).  The name is sometimes empty, and jq doesn&#39;t want to append to null.  How do I tell jq to just assume the null value is an empty string?  I&#39;ve seen mentions of a &quot;destructuring&quot; operator, or a map function to do this, but I can&#39;t seem to get any of that syntax to work.  \r\n\r\nIt may further complicate things, but the name is stored as the value in a key-value tag.  I have to do a select like this to get the name: ```.Tags[]|select(.Key == &quot;Name&quot;).Value```.\r\n \r\nHere&#39;s some sample data:\r\n```\r\n{\r\n  &quot;InstanceId&quot;: &quot;i-abc&quot;,\r\n  &quot;Tags&quot;: [\r\n    {\r\n      &quot;Key&quot;: &quot;Name&quot;,\r\n      &quot;Value&quot;: &quot;Grafana&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;InstanceId&quot;: &quot;i-def&quot;\r\n}\r\n```\r\n\r\nHere&#39;s what I&#39;m trying:\r\n```\r\ncat sample.json |jq -r &#39;.|{together: (.InstanceId + &quot; &quot; + (.Tags[]|select(.Key == &quot;Name&quot;).Value) // empty)}&#39;\r\n{\r\n  &quot;together&quot;: &quot;i-abc Grafana&quot;\r\n}\r\njq: error (at &lt;stdin&gt;:12): Cannot iterate over null (null)\r\n```",
        "link": "https://stackoverflow.com/questions/74466550/how-do-i-concatenate-two-strings-with-jq-when-one-of-them-might-be-null",
        "title": "How do I concatenate two strings with jq when one of them might be null?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12914911,
                    "reputation": 1176,
                    "user_id": 9339516,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6bdf538027245a9f4d2d08d1db570a05?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ᴓᴓᴓ",
                    "link": "https://stackoverflow.com/users/9339516/%e1%b4%93%e1%b4%93%e1%b4%93"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668629384,
                "post_id": 74466564,
                "comment_id": 131454981,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 1,
                "creation_date": 1668630165,
                "post_id": 74466564,
                "comment_id": 131455255,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668629931,
                "last_edit_date": 1668629931,
                "creation_date": 1668629471,
                "answer_id": 74466621,
                "question_id": 74466564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `sort` within jq, then index using `:` to get a range (negative indices count from the end).\r\n~~~sh\r\njq -r &#39;.tags | sort[:-3][]&#39;\r\n~~~\r\n\r\nYou can emulate version sorting by splitting the version string at the dots, and converting the items to numbers (works for the kind of version strings given in the sample).\r\n~~~sh\r\njq -r &#39;.tags | sort_by(./&quot;.&quot; | map(tonumber))[:-3][]&#39;\r\n~~~\r\n\r\nOutput:\r\n~~~\r\n1.0.0\r\n1.0.1\r\n1.1.0\r\n1.1.1\r\n1.1.2\r\n~~~",
                "title": "How to remove the last three elements of a list in bash?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1668648141,
                "creation_date": 1668648141,
                "answer_id": 74469076,
                "question_id": 74466564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With GNU coreutils:\r\n```sh\r\necho &quot;$data&quot; | sort -V | head -n -3\r\n```\r\n```\r\n1.0.0\r\n1.0.1\r\n1.1.0\r\n1.1.1\r\n1.1.2\r\n```\r\n\r\n`-V` is &quot;version sort&quot;\r\n\r\n`-n` with a negative argument is &quot;print all but the last _NUM_ lines&quot;\r\n",
                "title": "How to remove the last three elements of a list in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668648141,
        "creation_date": 1668629155,
        "last_edit_date": 1668629732,
        "question_id": 74466564,
        "body_markdown": "This is how I do get all version tags of an image in a custom docker registry:\r\n\r\n    r=`curl -sS &quot;$registry/v2/&quot; \\\r\n        -o /dev/null \\\r\n        -w &#39;%{http_code}:%header{www-authenticate}&#39;`\r\n    http_code=`echo &quot;$r&quot; | cut -d: -f1`\r\n    curl_args=(-sS -H &#39;Accept: application/vnd.docker.distribution.manifest.v2+json&#39;)\r\n    curl_args+=(-u &quot;$creds&quot;)\r\n    tags=`curl &quot;${curl_args[@]}&quot; &quot;$registry/v2/$image/tags/list&quot;  | jq -r .tags[] | sort -V`\r\n\r\nThe result could be something like:\r\n\r\n    1.0.0\r\n    1.1.2\r\n    1.2.0\r\n    1.2.1\r\n    1.0.1\r\n    1.1.0\r\n    1.1.1\r\n    1.2.1\r\n\r\nNow I just want to get all tags except the newest three and if there are less than three tags, the result should be empty. So in this example I need to get\r\n\r\n    1.0.0\r\n    1.0.1\r\n    1.1.0\r\n    1.1.1\r\n    1.1.2\r\n\r\nI tried to use `unset $tags[-3]`, but I think I do not get an array returned by the last curl call. So is `sort -V` working at all with this syntax?\r\n",
        "link": "https://stackoverflow.com/questions/74466564/how-to-remove-the-last-three-elements-of-a-list-in-bash",
        "title": "How to remove the last three elements of a list in bash?"
    },
    {
        "tags": [
            "shell",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1668781572,
                "creation_date": 1668781572,
                "answer_id": 74491131,
                "question_id": 74490712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Basically, remove `tostring`\r\n```sh\r\njson=$(\r\n    yq &#39;select(.action == &quot;want-to-update&quot;).foo&#39; sample.yaml \\\r\n    | jq &#39;.a = &quot;updated a&quot;&#39;\r\n)\r\nescaped_quotes=${json//\\&quot;/\\\\\\&quot;}\r\nyq &#39;select(.action == &quot;want-to-update&quot;).foo = &quot;&#39;&quot;${escaped_quotes}&quot;&#39;&quot;&#39; sample.yaml\r\n```\r\n\r\n```yaml\r\n---\r\naction: &quot;want-to-update&quot;\r\nfoo: |-\r\n  {\r\n    &quot;a&quot;: &quot;updated a&quot;,\r\n    &quot;b&quot;: &quot;actual B&quot;,\r\n    &quot;c&quot;: &quot;actual C&quot;\r\n  }\r\n\r\n---\r\naction: &quot;dont-want-to-update&quot;\r\nfoo: |-\r\n  &quot;ok&quot;\r\n\r\n```\r\n",
                "title": "Update JSON string field in yaml using yq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1668787259,
                "creation_date": 1668787259,
                "answer_id": 74492299,
                "question_id": 74490712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `fromjson` and `tojson`, you can decode and encode JSON on the fly, so all of this can be done with just one call to [yq](https://github.com/mikefarah/yq) (no [jq](https://github.com/stedolan/jq) and no command substitution needed):\r\n~~~sh\r\nyq -i &#39;select(.action == &quot;want-to-update&quot;).foo |= (\r\n  fromjson | .a = &quot;updated a&quot; | tojson\r\n)&#39; sample.yaml\r\n~~~",
                "title": "Update JSON string field in yaml using yq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1668787259,
        "creation_date": 1668779649,
        "question_id": 74490712,
        "body_markdown": "Have a file **sample.yaml**\r\n```\r\n---\r\naction: &quot;want-to-update&quot;\r\nfoo: |-\r\n    {\r\n        &quot;a&quot; : &quot;actual A&quot;,\r\n        &quot;b&quot; : &quot;actual B&quot;,\r\n        &quot;c&quot; : &quot;actual C&quot;\r\n    }\r\n---\r\naction: &quot;dont-want-to-update&quot;\r\nfoo: |-\r\n.\r\n.\r\n.\r\n```\r\nNeed to update value in `a` field from `actual a` to `updated a`\r\n\r\n\r\nTried to update with `yq` and `jq`\r\n```\r\nyq &#39;select(.action == &quot;want-to-update&quot;).foo&#39; sample.yaml | jq &#39;.a = &quot;updated a&quot; | tostring&#39; | xargs -0 -n1 -I{} yq &#39;select(.action == &quot;want-to-update&quot;).foo = {}&#39; -i sample.yaml\r\n```\r\nGetting output as below:\r\n```\r\n---\r\naction: &quot;want-to-update&quot;\r\nfoo: |-\r\n  {&quot;a&quot;:&quot;updated a&quot;,&quot;b&quot;:&quot;actual B&quot;,&quot;c&quot;:&quot;actual C&quot;}\r\n---\r\n.\r\n.\r\n```\r\n\r\nBut I want the prettier version of above:\r\n```\r\n---\r\naction: &quot;want-to-update&quot;\r\nfoo: |-\r\n    {\r\n        &quot;a&quot; : &quot;updated A&quot;,\r\n        &quot;b&quot; : &quot;actual B&quot;,\r\n        &quot;c&quot; : &quot;actual C&quot;\r\n    }\r\n---\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/74490712/update-json-string-field-in-yaml-using-yq",
        "title": "Update JSON string field in yaml using yq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "powershell",
            "jq",
            "hashicorp-vault"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668857320,
                "creation_date": 1668857320,
                "answer_id": 74499601,
                "question_id": 74499585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can acess the nested object with `.data.data`. You can convert an object into a list of key-value pairs with `to_entries`. Then it is only a matter of joining:\r\n\r\n```\r\nvault ... | jq -r &#39;.data.data | to_entries[] | join(&quot;=&quot;)&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\ntest=test123\r\ntest1=test1234\r\n```",
                "title": "How can I use jq to get the key value pairs only and set as environment variable?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1668867199,
                "creation_date": 1668867199,
                "answer_id": 74500761,
                "question_id": 74499585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&lt;!-- language-all: sh --&gt;\r\n\r\nTo provide an **all-PowerShell alternative** to [knittl&#39;s helpful `jq` answer](https://stackoverflow.com/a/74499601/45375), which also addresses the aspect of setting environment variables:\r\n\r\n\r\n```\r\n(vault kv get kv/Env | ConvertFrom-Json).data.data.psobject.Properties |\r\n  % { Set-Item Env:$($_.Name) $_.Value }\r\n```\r\n\r\n* [`ConvertFrom-Json`](https://learn.microsoft.com/powershell/module/microsoft.powershell.utility/convertfrom-json) parses the input JSON into an object graph (based on type `[pscustomobject]`), so that regular OO dot notation can be used to drill down into the graph, such as with `.data.data` in this case.\r\n\r\n* The `.Properties` collection of the [intrinsic `psobject` property](https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_Intrinsic_Members#psobject) is then used to reflect on the properties of the object contained in `.data.data`\r\n\r\n* `%` (a built-in alias of the [`ForEach-Object`](https://learn.microsoft.com/powershell/module/microsoft.powershell.core/foreach-object) cmdlet) then processes each property and uses [`Set-Item`](https://learn.microsoft.com/powershell/module/microsoft.powershell.management/set-item) with the [`Env:` drive](https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_Environment_Variables) (representing all in-process environment variables) to set an environment variable for each property&#39;s name and value.\r\n\r\n",
                "title": "How can I use jq to get the key value pairs only and set as environment variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1668867199,
        "creation_date": 1668857113,
        "question_id": 74499585,
        "body_markdown": "Below is the vault output generated by the vault command\r\n\r\nvault kv get kv/Env | jq\r\n\r\n```\r\n{\r\n  &quot;request_id&quot;: &quot;8498e5e4-050a-51e9-deaf-64a06a0&quot;,\r\n  &quot;lease_id&quot;: &quot;&quot;,\r\n  &quot;lease_duration&quot;: 0,\r\n  &quot;renewable&quot;: false,\r\n  &quot;data&quot;: {\r\n    &quot;data&quot;: {\r\n      &quot;test&quot;: &quot;test123&quot;,\r\n      &quot;test1&quot;: &quot;test1234&quot;\r\n    },\r\n    &quot;metadata&quot;: {\r\n      &quot;created_time&quot;: &quot;2022-11-17T12:2214.93229792Z&quot;,\r\n      &quot;custom_metadata&quot;: null,\r\n      &quot;deletion_time&quot;: &quot;&quot;,\r\n      &quot;destroyed&quot;: false,\r\n      &quot;version&quot;: 1\r\n    }\r\n  },\r\n  &quot;warnings&quot;: null\r\n}\r\n```\r\n\r\nI am unable to find a way to get only test and test1 and set as environmental variable in powershell. The issue is I would like to extract only test and test1, but it is under data/data which is like sublist and unable to find a way to extract it. Kindly help \r\n\r\nI had provided the paths to delete as below but not sure if its efficient way to loop through\r\n```\r\nvault kv get kv/Env | jq &#39;del(.data.metadata, .request_id, .lease_id, .lease_duration, .renewable, .warnings)&#39;\r\n```\r\nI would like to get the output something like below which I can loop through and set as variable.\r\n```\r\ntest=test123\r\ntest1=test1234\r\n```",
        "link": "https://stackoverflow.com/questions/74499585/how-can-i-use-jq-to-get-the-key-value-pairs-only-and-set-as-environment-variable",
        "title": "How can I use jq to get the key value pairs only and set as environment variable?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668862661,
                "post_id": 74500168,
                "comment_id": 131511802,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668863976,
                "post_id": 74500168,
                "comment_id": 131512081,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16357163,
                    "reputation": 635,
                    "user_id": 11813885,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/i4y0L.png?s=256",
                    "display_name": "tg0h",
                    "link": "https://stackoverflow.com/users/11813885/tg0h"
                },
                "reply_to_user": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1668866766,
                "post_id": 74500168,
                "comment_id": 131512672,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1668862868,
                "creation_date": 1668862868,
                "answer_id": 74500230,
                "question_id": 74500168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Taking the regular expression from the Superuser question [Removing ANSI color codes from text stream](https://superuser.com/q/380772/3773):\r\n\r\n```\r\ndef escape: &quot;\\u001b&quot;;\r\ndef _red(text):\r\n  escape + &quot;[31m&quot; + text + escape + &quot;[0m&quot;;\r\ndef _strip_ansi: gsub(&quot;\\\\x1b\\\\[[0-9;]*m&quot;; &quot;&quot;);\r\n_red(&quot;a&quot;) | _strip_ansi | length # gives 1\r\n```",
                "title": "How do I calculate the length (exclude escape codes) of a string containing ANSI colour codes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1668862999,
        "creation_date": 1668862372,
        "last_edit_date": 1668862999,
        "question_id": 74500168,
        "body_markdown": "## Current\r\nI am unable to calculate the length of a string containing ANSI colour codes.\r\n\r\nThe snippet below shows that the &#39;length&#39; of the string is 10.\r\n\r\n## Expected\r\nSince the string only has the letter &quot;a&quot; in it, I would like to have some function that determines the length of the string to be 1.\r\n\r\n```jq\r\ndef escape: &quot;\\u001b&quot;;\r\ndef _red(text):\r\n  escape + &quot;[31m&quot; + text + escape + &quot;[0m&quot;;\r\n_red(&quot;a&quot;) | length # gives 10\r\n```\r\n\r\n## Background\r\nTo provide a bit more context I have a left pad function in jq that relies on the length of the string to determine how much to pad a provided string with. However, this padding function does not work if the provided string contains ANSI colour codes.\r\n```jq\r\ndef lp($len):\r\n  if . == null then &quot;&quot; else . end | tostring | ($len - length) as $l | (&quot; &quot; * $l)[:$l] + .;\r\n```",
        "link": "https://stackoverflow.com/questions/74500168/how-do-i-calculate-the-length-exclude-escape-codes-of-a-string-containing-ansi",
        "title": "How do I calculate the length (exclude escape codes) of a string containing ANSI colour codes"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669043401,
                "last_edit_date": 1669043401,
                "creation_date": 1669042655,
                "answer_id": 74520851,
                "question_id": 74520746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re sure the `computers` array will just contain a single object, you could use:\r\n```\r\n.computers |= (first | . + .status | del(.status) | (.display |= join(.)))\r\n```\r\n\r\nThat will alter the value of `.computers` by doing to following:\r\n* Get the `first` object\r\n* Move everything inside `.status` to the object itself\r\n* `del()` the `.status` key\r\n* `join()` on the `.display` to get single value instead of the array.\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;computers&quot;: {\r\n    &quot;host&quot;: &quot;example&quot;,\r\n    &quot;platform&quot;: &quot;some_platform&quot;,\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;working&quot;: &quot;yes&quot;,\r\n    &quot;display&quot;: &quot;no&quot;\r\n  }\r\n}\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/QoRwdYFuNMt)\r\n\r\n\r\n----------\r\n\r\nIf there could be multiple objects in the `computer` array, `first` will ensure the first object is used. \r\n\r\nWe could also use `last` to get the last one:\r\n```\r\n.computers |= (last | . + .status | del(.status) | (.display |= join(.)))\r\n```\r\n\r\nOr combine `map()` and `add` to loop over all the objects, and add them together, then the the keys will be overwritten so the last value will stay visible, this might be handy if not all the objects have all the keys:\r\n```\r\n.computers |= (map(. + .status | del(.status) | (.display |= join(.))) | add)\r\n```",
                "title": "How do you replace a nested array with a flattened version of itself in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669045468,
                "last_edit_date": 1669045468,
                "creation_date": 1669043910,
                "answer_id": 74521116,
                "question_id": 74520746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your JSON structure is fixed, the following could do:\r\n\r\n```\r\n.computers\r\n| first\r\n| { host, platform, description }\r\n+ (.status | .display |= first)\r\n| { computers: . }\r\n```\r\n\r\nor\r\n\r\n```\r\n.computers\r\n| first\r\n| del(.status) + (.status | .display |= first)\r\n| { computers: . }\r\n```\r\n\r\nor\r\n\r\n```\r\n{\r\n    computers: (\r\n        .computers[0] | del(.status) + (.status | .display |= first)\r\n    )\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;computers&quot;: {\r\n    &quot;host&quot;: &quot;example&quot;,\r\n    &quot;platform&quot;: &quot;some_platform&quot;,\r\n    &quot;description&quot;: &quot;&quot;,\r\n    &quot;working&quot;: &quot;yes&quot;,\r\n    &quot;display&quot;: &quot;no&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnother alternative is reassigning the computers property, similar to 0stone0&#39;s solution, but a little bit shorter:\r\n\r\n```\r\n.computers |= (first | del(.status) + (.status | .display |= first))\r\n```",
                "title": "How do you replace a nested array with a flattened version of itself in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669061515,
                "creation_date": 1669061515,
                "answer_id": 74524391,
                "question_id": 74520746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can generically &quot;flatten&quot; nested objects by recursively traversing to their `scalars`, and putting them together by taking the deepest field name available:\r\n~~~sh\r\n.computers |= ([paths(scalars) as $p | {($p | map(strings)[-1]): getpath($p)}] | add)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;computers&quot;: {\r\n    &quot;host&quot;: &quot;example&quot;,\r\n    &quot;platform&quot;: &quot;some_platform&quot;,\r\n    &quot;working&quot;: &quot;yes&quot;,\r\n    &quot;display&quot;: &quot;no&quot;,\r\n    &quot;description&quot;: &quot;&quot;\r\n  }\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/iPFQkJyptVw)\r\n\r\nNote: You didn&#39;t define how arrays should be handled in the general case. For instance, what should happen if the `.computers` array or the `.display` array had more than just that single element. This approach merges them with latter elements overwriting previous ones if field names in the result object clash.",
                "title": "How do you replace a nested array with a flattened version of itself in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1669061515,
        "creation_date": 1669042147,
        "last_edit_date": 1669045860,
        "question_id": 74520746,
        "body_markdown": "Taking a json file as input such as:\r\n\r\n```json\r\n{&quot;computers&quot;:\r\n    [{&quot;host&quot;:&quot;example&quot;,\r\n    &quot;platform&quot;:&quot;some_platform&quot;,\r\n    &quot;status&quot;:\r\n        {&quot;working&quot;:&quot;yes&quot;,\r\n        &quot;display&quot;:[&quot;no&quot;]},\r\n    &quot;description&quot;:&quot;&quot;\r\n    }]\r\n}\r\n```\r\n\r\n...how can this be flattened to this form:\r\n\r\n\r\n```json\r\n{&quot;computers&quot;:\r\n    &quot;host&quot;:&quot;example&quot;,\r\n    &quot;platform&quot;:&quot;some_platform&quot;,\r\n    &quot;working&quot;:&quot;yes&quot;,\r\n    &quot;display&quot;:&quot;no&quot;,\r\n    &quot;description&quot;:&quot;&quot;\r\n}\r\n```\r\n\r\nie. the status element has been flattened, the square brackets in `&quot;display&quot;:[&quot;no&quot;]` have been removed, and the square brackets around `&quot;computers&quot;:[...]` have been removed.\r\n\r\nI have so far tried using flatten in multiple ways, eg.:\r\n\r\n```\r\ncat ./output.json | jq &#39;.computers|.[]|.status|flatten&#39;\r\n```\r\n\r\nbut this only outputs the flattened version of the contents of the status element. I cannot work out how to replace the contents with the flattened version.",
        "link": "https://stackoverflow.com/questions/74520746/how-do-you-replace-a-nested-array-with-a-flattened-version-of-itself-in-jq",
        "title": "How do you replace a nested array with a flattened version of itself in jq?"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 0,
                "creation_date": 1669044963,
                "post_id": 74521305,
                "comment_id": 131547878,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20095173,
                    "reputation": 11,
                    "user_id": 14734862,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Gcg51PijTaM/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclGkNetB43mDwBG28ygH8J1Is3rZg/s96-c/s256-rj/photo.jpg",
                    "display_name": "Kalyan",
                    "link": "https://stackoverflow.com/users/14734862/kalyan"
                },
                "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": 1669046822,
                "post_id": 74521305,
                "comment_id": 131548608,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1669045006,
        "creation_date": 1669044805,
        "last_edit_date": 1669045006,
        "question_id": 74521305,
        "body_markdown": "I am trying fetch get all the compute instances list using google cloud REST API. I have some information in a file.json.\r\n\r\nExample file.json\r\n```json\r\n&quot;zones/me-west1-c&quot;: {\r\n    &quot;warning&quot;: {\r\n      &quot;code&quot;: &quot;NO_RESULTS_ON_PAGE&quot;,\r\n      &quot;message&quot;: &quot;There are no results for scope &#39;zones/me-west1-c&#39; on this page.&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;scope&quot;,\r\n          &quot;value&quot;: &quot;zones/me-west1-c&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n```\r\nWhen I run the below command I get the following error.\r\n```\r\ncat file.json | jq .items.zone/me-west-c\r\n```\r\n```none\r\njq: error: me/0 is not defined at &lt;top-level&gt;, line 1:\r\n.items.zones/me-west1-c             \r\njq: error: west1/0 is not defined at &lt;top-level&gt;, line 1:\r\n.items.zones/me-west1-c                \r\njq: error: c/0 is not defined at &lt;top-level&gt;, line 1:\r\n.items.zones/me-west1-c\r\n```\r\n\r\nCan someone help me to where exactly I am doing wrong?\r\n",
        "link": "https://stackoverflow.com/questions/74521305/i-was-trying-to-fetch-get-all-the-compute-instances-list-using-google-cloud-rest",
        "title": "I was trying to fetch get all the compute instances list using google cloud REST API. I get the below error while filtering with jq"
    },
    {
        "tags": [
            "regex",
            "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": 1669053602,
                "post_id": 74522985,
                "comment_id": 131550907,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669055301,
                "last_edit_date": 1669055301,
                "creation_date": 1669053636,
                "answer_id": 74523092,
                "question_id": 74522985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `--raw-input` (or `-R`) option to read in the string, and the `--argfile` option to read in the regex JSON file:\r\n~~~sh\r\necho &quot;path/to/melon/data&quot; |\r\njq -Rr --argfile rs regex.json &#39;\r\n  $rs[] as $r\r\n  | if test($r.regex) then $r.name else empty end\r\n&#39;\r\n~~~\r\n~~~\r\nCantaloupe\r\n~~~\r\n\r\nIf the string is contained somewhere in your input JSON, you obviously don&#39;t need the `--raw-input` (or `-R`) option:\r\n~~~sh\r\njq -r --argfile rs regex.json &#39;\r\n  ...traverse to the string... | $rs[] as $r\r\n  | if test($r.regex) then $r.name else empty end\r\n&#39; input.json\r\n~~~",
                "title": "jq - Use regex in the json in test function"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669139762,
                "last_edit_date": 1669139762,
                "creation_date": 1669058327,
                "answer_id": 74523899,
                "question_id": 74522985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It sounds like you want to apply your array of regexes in turn to your input string. In other words: [reducing](https://stedolan.github.io/jq/manual/v1.6/#Reduce) your input by aggregating the results of a substitution operation.\r\n\r\n```\r\nreduce $regex[0][] as $re (.; gsub($re.regex; $re.name))\r\n```\r\n\r\nProvide `$regex` via `--slurpfile` and make sure to read raw input (`-R`) and write raw output (`-r`):\r\n\r\n```\r\n$ echo &quot;Is this banana&quot; | jq -Rr --slurpfile regex test.json &#39;reduce $regex[0][] as $re (.; gsub($re.regex; $re.name))&#39;\r\nIs this Long and yellow\r\n```\r\n\r\nAll substitutions are applied:\r\n\r\n```\r\n$ echo &quot;Apple or Is this melon a banana&quot; | jq -Rr --slurpfile regex test.json &#39;reduce $regex[0][] as $re (.; gsub($re.regex; $re.name))&#39;\r\nFor teahcersor Is this melon a Long and yellow\r\n```\r\n\r\nAnd would be applied to already-substituted strings. So if you had `&quot;^a&quot;`=&gt;`&quot;x&quot;` and `&quot;x&quot;`=&gt;`&quot;y&quot;`, then the input `&quot;abc&quot;` would end up as `&quot;ybc&quot;`.\r\n\r\n```\r\n$ echo &quot;Apple or Is this /melon/ a banana&quot; | jq -Rr --slurpfile regex test.json &#39;reduce $regex[0][] as $re (.; gsub($re.regex; $re.name))&#39;\r\nCantaloupe\r\n```\r\n\r\n****\r\n\r\nAnd if you only want to print the first substitution which is possible, the following could work (although I&#39;m sure there&#39;s a smarter way, this looks way to convoluted):\r\n\r\n```\r\n$ echo &quot;Apple or Is this /melon/ a banana&quot; | jq -Rr --slurpfile regex test.json &#39;\r\n. as $in \r\n| $regex[0] \r\n| map(\r\n  . as $re\r\n  | $in\r\n  | select(test($re.regex))\r\n  | gsub($re.regex; $re.name)\r\n) \r\n| first\r\n&#39;\r\nFor teahcersor Is this /melon/ a banana\r\n```\r\n\r\n*****\r\n\r\nAfter the updates to the question, here&#39;s an answer to the last version:\r\n\r\n```\r\n$ echo &quot;Apple or Is this /melon/ a banana&quot; | jq -Rr --slurpfile regex test.json &#39;\r\n. as $in \r\n| $regex[0] \r\n| map(\r\n  select(. as $re | $in | test($re.regex))\r\n  | .name\r\n)\r\n&#39;\r\n[\r\n  &quot;For teahcers&quot;,\r\n  &quot;Long and yellow&quot;,\r\n  &quot;Cantaloupe&quot;\r\n]\r\n```",
                "title": "jq - Use regex in the json in test function"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669818327,
        "creation_date": 1669053046,
        "last_edit_date": 1669818327,
        "question_id": 74522985,
        "body_markdown": "I have some json that contains regex\r\n\r\n```\r\n[\r\n  {\r\n     &quot;name&quot;: &quot;For teachers&quot;,\r\n     &quot;regex&quot;: &quot;^Apple &quot;\r\n  },\r\n  {\r\n     &quot;name&quot;: &quot;Long and yellow&quot;,\r\n     &quot;regex&quot;: &quot;banana$&quot;\r\n  },\r\n  {\r\n     &quot;name&quot;: &quot;Cantaloupe&quot;,\r\n     &quot;regex&quot;: &quot;.*/melon/.*&quot;\r\n  }\r\n]\r\n```\r\n\r\nWhat I wanted to do is use the `.regex` value in the test function e.g.\r\n\r\n```\r\n&gt;&gt;&gt; jq &#39;. | select( &quot;path/to/melon/data&quot; | test( .regex ) )&#39; test.json\r\njq: error (at test.json:14): Cannot index string with string &quot;regex&quot;\r\n```\r\n\r\nI am trying to check if a string, passed in anyhow, matches any of the `.regex` in the json and if it does return the corresponding `.name`. \r\n\r\nIn the above `test.json`, passing a string =&gt; output:\r\n- starting &quot;Apples &quot; =&gt; &quot;For teachers&quot;\r\n- ending &quot;banana&quot; =&gt; &quot;Long and yellow&quot;\r\n- containing the text &quot;/melons/&quot; =&gt; &quot;Canteloupe&quot;\r\n\r\nIf there are multiple matches then return all the `.name` values where the `.regex` matches the passed in string. So from the comments:\r\n&quot;Apple or Is this /melon/ a banana&quot; =&gt; [ &quot;For teachers&quot;, &quot;Long and yellow&quot;, &quot;Canteloupe&quot; ]\r\n\r\n-----------------------------------------\r\nI was considering trying something like building a sed command but I have not got that far and I think adding what I had was causing confusion rather than clarifying. Leaving it here so the comments make sense.\r\n\r\n```\r\n&gt;&gt;&gt; echo &quot;path/to/melon/data&quot; | sed -E -e &#39;s#^Apple #For teachers #g&#39; -e &#39;s#banana$#long and yellow#g&#39; -e &#39;s#.*/melon/.*#Cantaloupe#g&#39;\r\nCantaloupe\r\n&gt;&gt;&gt; echo &quot;Is this banana&quot; | sed -E -e &#39;s#^Apple #For teachers#g&#39; -e &#39;s#banana$#long and yellow#g&#39; -e &#39;s#.*/melon/.*#Cantaloupe#g&#39;\r\nIs this long and yellow\r\n```\r\n\r\nI want a behaviour similar to this sed, but without me needing to construct lots of `-e` options from `jq` print.\r\n\r\nI am sure I can get something like that to work, so every time the echoed in string matches a `.regex` it returns the corresponding `.name` but that is such a hack ... even for me! (Note: This sed is not doing what I want except in the melon case, because it is replacing the text matched rather than responding with the text)\r\n",
        "link": "https://stackoverflow.com/questions/74522985/jq-use-regex-in-the-json-in-test-function",
        "title": "jq - Use regex in the json in test function"
    },
    {
        "tags": [
            "bash",
            "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": 0,
                "creation_date": 1669077451,
                "post_id": 74526175,
                "comment_id": 131556776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669076794,
                "creation_date": 1669076794,
                "answer_id": 74526228,
                "question_id": 74526175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wouldn&#39;t using [`all`](https://stedolan.github.io/jq/manual/#all%2Call%28condition%29%2Call%28generator%3Bcondition%29) and the `--exit-status` (or `-e`) [option](https://stedolan.github.io/jq/manual/#Invokingjq) make more sense here?\r\n~~~sh\r\nif jq -e &#39;all(.. | objects | select(has(&quot;foo&quot;)); .foo)&#39; file.json &gt;/dev/null\r\nthen\r\n  echo &quot;All true&quot;\r\nelse\r\n  echo &quot;At least one not true&quot;\r\nfi\r\n~~~",
                "title": "How to modify external variable inside jq walk"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669086762,
                "creation_date": 1669086762,
                "answer_id": 74527116,
                "question_id": 74526175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could avoid entanglements with the shell, e.g. as follows:\r\n```\r\njq &#39;if all(.. | objects | select(has(&quot;foo&quot;)); .foo) \r\n    then &quot;All truthy&quot; \r\n    else &quot;At least one not truthy&quot;\r\n    end&#39;\r\n```",
                "title": "How to modify external variable inside jq walk"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669086762,
        "creation_date": 1669076205,
        "question_id": 74526175,
        "body_markdown": "I&#39;m currently writing a script that uses the function `walk` in jq, which I&#39;m using to check for the value of a field, which can appear multiple times in the file. If any instance of that field is not `true`, I want to echo an error notifying users that the field is invalid. Similar to below:\r\n\r\n\r\n```\r\nflag=false\r\n\r\ncat file.json | jq &#39;walk (\r\n  if type == &quot;object&quot; and has &quot;foo&quot; and (.foo != true); then\r\n     flag=true\r\n  else . end\r\n)&#39;\r\n\r\nif [[ &quot;$flag&quot; == true ]]; then\r\n  echo &quot;ERROR&quot;\r\n  exit 1\r\nfi\r\n```\r\n\r\nHow can I notify the rest of the program if the check inside `walk` fails ? Any help is much appreciated!",
        "link": "https://stackoverflow.com/questions/74526175/how-to-modify-external-variable-inside-jq-walk",
        "title": "How to modify external variable inside jq walk"
    },
    {
        "tags": [
            "escaping",
            "jq",
            "zsh",
            "quoting"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1669099366,
                "post_id": 74528005,
                "comment_id": 131560244,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669099929,
                "post_id": 74528005,
                "comment_id": 131560373,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1669328705,
                "last_edit_date": 1669328705,
                "creation_date": 1669097026,
                "answer_id": 74528116,
                "question_id": 74528005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.rows[]` means something special to `zsh`.&lt;sup&gt;[1]&lt;/sup&gt; You need to escape or quote so that `.rows[]` is passed to `jq`. \r\n\r\n```sh\r\njq &#39;.rows[]&#39; file.json\r\n```\r\n\r\n---\r\n\r\n1. I&#39;m not familiar with zsh, so I don&#39;t know what it means, but that&#39;s not important here.\r\n",
                "title": "Broken JSON using JQ processing: Possible Bug?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669122680,
                "creation_date": 1669122680,
                "answer_id": 74533184,
                "question_id": 74528005,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As [@Ikegami][1] points out, just use quotes!\r\n\r\nHowever, if you don&#39;t want to, you can use the &#39;*Precommand Modifier `noglob`*&#39; &lt;sup&gt;[\\[docs\\]][2]&lt;/sup&gt; to let ZSH not expand any of the special chars, so:\r\n```\r\nnoglob jq .rows[] input\r\n```\r\n\r\nWill work just fine. \r\n\r\n\r\n  [1]: https://stackoverflow.com/a/74528116/5625547\r\n  [2]: https://Precommand%20Modifiers",
                "title": "Broken JSON using JQ processing: Possible Bug?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1669328705,
        "creation_date": 1669096122,
        "last_edit_date": 1669097120,
        "question_id": 74528005,
        "body_markdown": "I have a JSON I found that seems to fail to be able to remove an Array after indexing once. Here is the valid JSON below (according to jsonlint.com\r\n\r\nGoal: Remove an outer array from what {was a valid JSON} on the outside. \r\n\r\n**Steps to reproduce** \r\n\r\n1. validate JSON is valid\r\n2. run `cat file.json | jq .rows`\r\n3. Observe works OK\r\n4. try `cat file.json | jq .rows[]`\r\n\r\nObserve my following error\r\n\r\n`zsh: no matches found: .rows[]`\r\n\r\nI also tried  `cat file.json | jq .rows | jq .[]`\r\n\r\nFor good measure, here is the exact text that is failing but I think JQ should process like this according to https://stackoverflow.com/questions/58566524/jq-how-to-define-filter-to-remove-brackets-quotes-and-commas-from-output-arra\r\n\r\n\r\n    {\r\n\t&quot;selfLink&quot;: null,\r\n\t&quot;id&quot;: &quot;eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0fQ==&quot;,\r\n\t&quot;title&quot;: &quot;My Daily Discovery&quot;,\r\n\t&quot;rows&quot;: [{\r\n\t\t&quot;modules&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiMTg3ZGVhMTMtNWI1ZS00OWYwLWI5YjktYjc5ODk3M2M2MjVmIiwibVYiOjEsIm1IIjoiYmMyMTQ4NDkifQ==&quot;,\r\n\t\t\t&quot;type&quot;: &quot;MIX_HEADER&quot;,\r\n\t\t\t&quot;width&quot;: 100,\r\n\t\t\t&quot;title&quot;: &quot;&quot;,\r\n\t\t\t&quot;description&quot;: &quot;&quot;,\r\n\t\t\t&quot;preTitle&quot;: &quot;&quot;,\r\n\t\t\t&quot;mix&quot;: {\r\n\t\t\t\t&quot;id&quot;: &quot;016574ac3abf29b2a6a1ae2c1b2f34&quot;,\r\n\t\t\t\t&quot;title&quot;: &quot;My Daily Discovery&quot;,\r\n\t\t\t\t&quot;subTitle&quot;: &quot;Songs by new and familiar artists inspired by your listening. Updates every morning.&quot;,\r\n\t\t\t\t&quot;graphic&quot;: {\r\n\t\t\t\t\t&quot;type&quot;: &quot;SQUARES_GRID&quot;,\r\n\t\t\t\t\t&quot;text&quot;: &quot;My Daily Discovery&quot;,\r\n\t\t\t\t\t&quot;images&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: &quot;dummy-placeholder&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#FFFFFF&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;ARTIST&quot;\r\n\t\t\t\t\t}]\r\n\t\t\t\t},\r\n\t\t\t\t&quot;images&quot;: {\r\n\t\t\t\t\t&quot;SMALL&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 320,\r\n\t\t\t\t\t\t&quot;height&quot;: 320,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=03c55020deef749a0a7608833cebe3ae2f8f33f6&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;MEDIUM&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 640,\r\n\t\t\t\t\t\t&quot;height&quot;: 640,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=c391f21c624d0b58f4badc2185211b89eb2cee7f&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;LARGE&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 1500,\r\n\t\t\t\t\t\t&quot;height&quot;: 1500,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ?token=b055bb723e064256026fcb7d17a6dfa6ef839c25&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t},\r\n\t\t\t\t&quot;sharingImages&quot;: null,\r\n\t\t\t\t&quot;mixType&quot;: &quot;DISCOVERY_MIX&quot;,\r\n\t\t\t\t&quot;mixNumber&quot;: null,\r\n\t\t\t\t&quot;contentBehavior&quot;: &quot;UNRESTRICTED&quot;,\r\n\t\t\t\t&quot;shortSubtitle&quot;: null,\r\n\t\t\t\t&quot;master&quot;: false,\r\n\t\t\t\t&quot;titleColor&quot;: &quot;#F9A192&quot;,\r\n\t\t\t\t&quot;subTitleColor&quot;: &quot;#F9A192&quot;,\r\n\t\t\t\t&quot;detailImages&quot;: {\r\n\t\t\t\t\t&quot;SMALL&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 320,\r\n\t\t\t\t\t\t&quot;height&quot;: 320,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/EMACGMAC/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=2d26406e237b5f9e830cac45b7ec6470ce71638f&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;MEDIUM&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 640,\r\n\t\t\t\t\t\t&quot;height&quot;: 640,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/EIAFGIAF/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=9406f1c8bc4061c7841f35156b0f81e9dc961d0b&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;LARGE&quot;: {\r\n\t\t\t\t\t\t&quot;width&quot;: 1500,\r\n\t\t\t\t\t\t&quot;height&quot;: 1500,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://images.tidal.com/0/ENwLGNwL/CAEQCCIDMzI2KgcjRjlBMTkyMAQ4AQ?token=b8eb265be431640046cb1b376715d0ceaef19677&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t&quot;playbackControls&quot;: [{\r\n\t\t\t\t&quot;shuffle&quot;: false,\r\n\t\t\t\t&quot;playbackMode&quot;: &quot;PLAY&quot;,\r\n\t\t\t\t&quot;title&quot;: &quot;Play&quot;,\r\n\t\t\t\t&quot;icon&quot;: &quot;play_tracks&quot;,\r\n\t\t\t\t&quot;targetModuleId&quot;: &quot;eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ==&quot;\r\n\t\t\t}, {\r\n\t\t\t\t&quot;shuffle&quot;: true,\r\n\t\t\t\t&quot;playbackMode&quot;: &quot;SHUFFLE&quot;,\r\n\t\t\t\t&quot;title&quot;: &quot;Shuffle&quot;,\r\n\t\t\t\t&quot;icon&quot;: &quot;shuffle_tracks&quot;,\r\n\t\t\t\t&quot;targetModuleId&quot;: &quot;eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ==&quot;\r\n\t\t\t}]\r\n\t\t}]\r\n\t}, {\r\n\t\t&quot;modules&quot;: [{\r\n\t\t\t&quot;id&quot;: &quot;eyJwIjoiOGMxZjRkNjAtZDhmNS00YmU2LTg1YjMtYTA0NDExNDVkYmMwIiwicFYiOjE0LCJtIjoiNmU5OWY3ZjUtMDk4My00Mzk5LWFkYjEtZDk2NzRmMGQ2ZDQ5IiwibVYiOjEsIm1IIjoiNDgyMDRjMGMifQ==&quot;,\r\n\t\t\t&quot;type&quot;: &quot;TRACK_LIST&quot;,\r\n\t\t\t&quot;width&quot;: 100,\r\n\t\t\t&quot;title&quot;: &quot;&quot;,\r\n\t\t\t&quot;description&quot;: &quot;&quot;,\r\n\t\t\t&quot;preTitle&quot;: null,\r\n\t\t\t&quot;showMore&quot;: null,\r\n\t\t\t&quot;supportsPaging&quot;: false,\r\n\t\t\t&quot;quickPlay&quot;: false,\r\n\t\t\t&quot;listFormat&quot;: &quot;COVERS&quot;,\r\n\t\t\t&quot;scroll&quot;: &quot;VERTICAL&quot;,\r\n\t\t\t&quot;layout&quot;: &quot;LIST&quot;,\r\n\t\t\t&quot;pagedList&quot;: {\r\n\t\t\t\t&quot;limit&quot;: 10,\r\n\t\t\t\t&quot;offset&quot;: 0,\r\n\t\t\t\t&quot;totalNumberOfItems&quot;: 10,\r\n\t\t\t\t&quot;items&quot;: [{\r\n\t\t\t\t\t&quot;id&quot;: 182220043,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Hippies and Cowboys&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 301,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/182220043&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 6364193,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Cody Jinks&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;bf1a2f1e-7da1-4692-8a66-2bf96157c642&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 182220040,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Less Wise&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;12193ada-c3f6-48f4-9fa0-d55cb2e0a43e&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#FFFFFF&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/182220040&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2016-08-12&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: false,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 3,\r\n\t\t\t\t\t&quot;popularity&quot;: 44,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2021-05-01T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -10.58,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;LOSSLESS&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001fffe9146518c56b9ad0d015c4a2&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 231866033,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Numb&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 156,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/231866033&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 7250145,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Marshmello&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;a596f1fe-3e76-4314-8530-69b27fb93fa3&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 4916222,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Khalid&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;84e7a97a-e66c-48b3-ad88-2890066fb64e&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 231866032,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Numb&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;703caf3c-8dc4-4836-a29e-aa44d9afedae&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#9fd1df&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/231866032&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2022-06-10&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: false,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 68,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2022-06-10T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -9.46,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;0147bdf794b09b50b6d60f1d6fb903&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;00137d2d4dd1030005ef1ae2e64d21&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 138872432,\r\n\t\t\t\t\t&quot;title&quot;: &quot;I Look Good&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 102,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/138872432&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 5896451,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;O.T. Genasis&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;6ac8210e-b1ed-4225-a44a-cbddd586d419&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 138872431,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;I Look Good&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;f406561e-a799-43de-9d1e-280b852a8cd3&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#f9d46b&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/138872431&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2020-05-01&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 38,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2020-05-01T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -8.96,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;01452343b3589909390a4164019425&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001f6cb8e851a11d9a68d80003f5f2&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 125093690,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Red Line&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 182,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/125093690&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 8048820,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Geordie Kieffer&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: null\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 125093689,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Red Line&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;b80983b9-f2a7-404e-b65f-1ed7860fea82&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#b35e67&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/125093689&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2020-01-08&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 8,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2020-01-08T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -8.62,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;LOSSLESS&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;00104d152616c6579359939441ab42&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 215213468,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Gospel&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 210,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/215213468&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 3963798,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Dr. Dre&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;1a705aec-4f48-40ba-a146-6f67e011680a&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 17275,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Eminem&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;480b074a-58da-469e-b4aa-d4e53fd1d5f5&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 215213467,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Gospel&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;b32350b6-56e3-49cf-9207-a714ff91025e&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#a6944d&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/215213467&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2022-02-04&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 58,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2022-02-04T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -10.74,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;014de0b796546a650cb74a3c7d3ed0&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;0013aa67e00d042e6608c9adb427c8&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 70870118,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Sleeping on the Blacktop&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 192,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/70870118&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 6672522,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Colter Wall&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;a11692f6-e875-491f-bce4-0173f44ee7c1&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 70870117,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Imaginary Appalachia&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;8da58d7c-a9d4-42a7-a135-712d60397f08&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#e2d0af&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/70870117&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2018-01-19&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: false,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 39,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2017-03-03T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -7.13,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;LOSSLESS&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001a2a053ac274a3ac80eb7e9d4d2a&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 237821203,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Doja&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 97,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/237821203&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 8589558,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Central Cee&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;137e6101-36ec-4462-8d18-c6f374a3e4ca&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 237821202,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Doja&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;a4739199-f51f-4e9d-8e15-4aef11330322&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#c7d8e9&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/237821202&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2022-07-21&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 1,\r\n\t\t\t\t\t&quot;popularity&quot;: 64,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2022-07-21T16:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -5.98,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;014d023089eade21828a9b11774c4e&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001a920815b5f4d57efb6ce11ec78b&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 140490817,\r\n\t\t\t\t\t&quot;title&quot;: &quot;ooh la la (feat. Greg Nice &amp; DJ Premier)&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 181,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/140490817&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 5171527,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Run The Jewels&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;4c4895e6-030f-4120-be39-ca840b3caad7&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 3604111,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;El-P&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;9e6a524c-3fa2-4e1c-9aad-4e4b796073bb&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 5016,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Killer Mike&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;1ba6de84-bab8-433a-99e1-82d1781d412b&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 4082619,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;DJ Premier&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;FEATURED&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;f9c60d02-5eef-4662-8e58-e588e5e7b72f&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 3718662,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Greg Nice&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;FEATURED&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;94047994-fc96-4410-b5d5-f126fdf8e7d4&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 140490815,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;RTJ4&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;b13d9c84-747d-47e6-b9f2-c23c71e62e81&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#be1574&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/140490815&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2020-06-05&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 2,\r\n\t\t\t\t\t&quot;popularity&quot;: 41,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2020-06-22T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -8.53,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;0140dec298c0e46db85d6ddba6dcba&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;0015622125d9f15c27c30b2dbf2fb8&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 52974885,\r\n\t\t\t\t\t&quot;title&quot;: &quot;Weight of Sound (feat. TJ O&#39;Neill)&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 443,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/52974885&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 4942474,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Stick Figure&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;eb6ed2bf-a8ab-4f97-9d07-b60b97bab27f&quot;\r\n\t\t\t\t\t}, {\r\n\t\t\t\t\t\t&quot;id&quot;: 4942475,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;TJ O&#39;Neill&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;FEATURED&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: null\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 52974879,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;Burial Ground&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;525dbfa2-4d71-4078-96cf-0ba5804c3249&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#ccbc85&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/52974879&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2012-01-01&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: false,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 6,\r\n\t\t\t\t\t&quot;popularity&quot;: 35,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2012-06-15T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -9.1,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;LOSSLESS&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001b814bb26f42384d478f8f124133&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}, {\r\n\t\t\t\t\t&quot;id&quot;: 86698003,\r\n\t\t\t\t\t&quot;title&quot;: &quot;It&#39;s Called: Freefall&quot;,\r\n\t\t\t\t\t&quot;duration&quot;: 152,\r\n\t\t\t\t\t&quot;version&quot;: null,\r\n\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/track/86698003&quot;,\r\n\t\t\t\t\t&quot;artists&quot;: [{\r\n\t\t\t\t\t\t&quot;id&quot;: 5416094,\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;Rainbow Kitten Surprise&quot;,\r\n\t\t\t\t\t\t&quot;type&quot;: &quot;MAIN&quot;,\r\n\t\t\t\t\t\t&quot;picture&quot;: &quot;b3675173-8f39-48c9-8172-d0ea7c38cf78&quot;\r\n\t\t\t\t\t}],\r\n\t\t\t\t\t&quot;album&quot;: {\r\n\t\t\t\t\t\t&quot;id&quot;: 86697999,\r\n\t\t\t\t\t\t&quot;title&quot;: &quot;How to: Friend, Love, Freefall&quot;,\r\n\t\t\t\t\t\t&quot;cover&quot;: &quot;2612d792-a8cf-4e40-8df9-635485d2a263&quot;,\r\n\t\t\t\t\t\t&quot;vibrantColor&quot;: &quot;#df9390&quot;,\r\n\t\t\t\t\t\t&quot;videoCover&quot;: null,\r\n\t\t\t\t\t\t&quot;url&quot;: &quot;https://tidal.com/browse/album/86697999&quot;,\r\n\t\t\t\t\t\t&quot;releaseDate&quot;: &quot;2018-04-06&quot;\r\n\t\t\t\t\t},\r\n\t\t\t\t\t&quot;explicit&quot;: true,\r\n\t\t\t\t\t&quot;volumeNumber&quot;: 1,\r\n\t\t\t\t\t&quot;trackNumber&quot;: 4,\r\n\t\t\t\t\t&quot;popularity&quot;: 37,\r\n\t\t\t\t\t&quot;allowStreaming&quot;: true,\r\n\t\t\t\t\t&quot;streamReady&quot;: true,\r\n\t\t\t\t\t&quot;streamStartDate&quot;: &quot;2018-04-06T00:00:00.000+0000&quot;,\r\n\t\t\t\t\t&quot;editable&quot;: false,\r\n\t\t\t\t\t&quot;replayGain&quot;: -9.29,\r\n\t\t\t\t\t&quot;audioQuality&quot;: &quot;HI_RES&quot;,\r\n\t\t\t\t\t&quot;audioModes&quot;: [&quot;STEREO&quot;],\r\n\t\t\t\t\t&quot;mixes&quot;: {\r\n\t\t\t\t\t\t&quot;MASTER_TRACK_MIX&quot;: &quot;014069ec04995575ebd2537f5a365a&quot;,\r\n\t\t\t\t\t\t&quot;TRACK_MIX&quot;: &quot;001d91e79ca357d29a3ad505287121&quot;\r\n\t\t\t\t\t}\r\n\t\t\t\t}],\r\n\t\t\t\t&quot;dataApiPath&quot;: &quot;pages/data/518d479b-3510-41ba-a62b-4c06055ec580?mixId=016574ac3abf29b2a6a1ae2c1b2f34&quot;\r\n\t\t\t},\r\n\t\t\t&quot;showTableHeaders&quot;: true\r\n\t\t}]\r\n\t}]\r\n}\r\n",
        "link": "https://stackoverflow.com/questions/74528005/broken-json-using-jq-processing-possible-bug",
        "title": "Broken JSON using JQ processing: Possible Bug?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669139274,
                "creation_date": 1669139274,
                "answer_id": 74537018,
                "question_id": 74536740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can construct your output from scratch:\r\n\r\n```\r\n.unbonding_responses[]\r\n| { delegator_address }\r\n+ (.entries[] | { \r\n    creation_height,\r\n    completion_time,\r\n    balance: (.balance|tonumber/1000000)\r\n})\r\n```\r\n\r\nor merge full entries objects with delegator address and then delete the unwanted property + normalize your balance:\r\n\r\n```\r\n.unbonding_responses[]\r\n| { delegator_address } + .entries[]\r\n| del(.initial_balance)\r\n| .balance |= tonumber/1000000\r\n```\r\n\r\nOutput for both programs:\r\n\r\n```json\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1zkzfu5tqee0p698w3g83x8a2zswgqglj4t8z3j&quot;,\r\n  &quot;creation_height&quot;: &quot;753019&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-12-13T16:00:56.664864370Z&quot;,\r\n  &quot;balance&quot;: 3\r\n}\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1rjg0vg9hlu8kygnrdehzt3z0t4ea5ssu6wkm06&quot;,\r\n  &quot;creation_height&quot;: &quot;653923&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-12-07T00:53:48.247870844Z&quot;,\r\n  &quot;balance&quot;: 50\r\n}\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1aw44evl5zlqtw93zln83tp4v3w4kp6e9zmx64k&quot;,\r\n  &quot;creation_height&quot;: &quot;597161&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-12-03T05:32:59.107845572Z&quot;,\r\n  &quot;balance&quot;: 2\r\n}\r\n```",
                "title": "How to Select only a couple keys and keep it in an array format using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669139274,
        "creation_date": 1669137838,
        "last_edit_date": 1669138865,
        "question_id": 74536740,
        "body_markdown": "I have the following json I want to sort through:\r\n\r\n```json\r\n{\r\n  &quot;unbonding_responses&quot;: [\r\n    {\r\n      &quot;delegator_address&quot;: &quot;tori1zkzfu5tqee0p698w3g83x8a2zswgqglj4t8z3j&quot;,\r\n      &quot;validator_address&quot;: &quot;torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa&quot;,\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;creation_height&quot;: &quot;753019&quot;,\r\n          &quot;completion_time&quot;: &quot;2022-12-13T16:00:56.664864370Z&quot;,\r\n          &quot;initial_balance&quot;: &quot;3000000&quot;,\r\n          &quot;balance&quot;: &quot;3000000&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;delegator_address&quot;: &quot;tori1rjg0vg9hlu8kygnrdehzt3z0t4ea5ssu6wkm06&quot;,\r\n      &quot;validator_address&quot;: &quot;torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa&quot;,\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;creation_height&quot;: &quot;653923&quot;,\r\n          &quot;completion_time&quot;: &quot;2022-12-07T00:53:48.247870844Z&quot;,\r\n          &quot;initial_balance&quot;: &quot;50000000&quot;,\r\n          &quot;balance&quot;: &quot;50000000&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;delegator_address&quot;: &quot;tori1aw44evl5zlqtw93zln83tp4v3w4kp6e9zmx64k&quot;,\r\n      &quot;validator_address&quot;: &quot;torivaloper189r2mx8h5zt7ep4cf0s4np79w38l420na3h6sa&quot;,\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;creation_height&quot;: &quot;597161&quot;,\r\n          &quot;completion_time&quot;: &quot;2022-12-03T05:32:59.107845572Z&quot;,\r\n          &quot;initial_balance&quot;: &quot;2000000&quot;,\r\n          &quot;balance&quot;: &quot;2000000&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;pagination&quot;: {\r\n    &quot;next_key&quot;: null,\r\n    &quot;total&quot;: &quot;3&quot;\r\n  }\r\n}\r\n```\r\n\r\nCurrently I am filtering using the following command\r\n```bash\r\n curl -s https://rest.mainnet.teritori.com/cosmos/staking/v1beta1/validators/torivaloper1qy38xmcrnht0kt5c5fryvl8llrpdwer6atxj5u/unbonding_delegations | jq &#39;.unbonding_responses[].entries[]|.balance|=(tonumber | ./1000000)&#39;\r\n```\r\nWhich gives the following results:\r\n```json\r\n\r\n{\r\n  &quot;creation_height&quot;: &quot;546726&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-11-29T20:41:54.102529873Z&quot;,\r\n  &quot;initial_balance&quot;: &quot;1000000&quot;,\r\n  &quot;balance&quot;: 1\r\n}\r\n{\r\n  &quot;creation_height&quot;: &quot;560257&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-11-30T18:22:32.286053755Z&quot;,\r\n  &quot;initial_balance&quot;: &quot;4000000&quot;,\r\n  &quot;balance&quot;: 4\r\n}\r\n{\r\n  &quot;creation_height&quot;: &quot;567462&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-12-01T05:57:49.397647828Z&quot;,\r\n  &quot;initial_balance&quot;: &quot;112142&quot;,\r\n  &quot;balance&quot;: 0.112142\r\n}\r\n```\r\n\r\nI have been experimenting with map and select to try and get the results in a format that I am looking for, but am unsuccessful. The two things I am looking to do is, remove `initial_balance` and then add `delegator_address` to the results.\r\n\r\nDesired result so I can easily convert to CSV and import to a spreedsheet:\r\n```json\r\n\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1zkzfu5tqee0p698w3g83x8a2zswgqglj4t8z3j&quot;,\r\n  &quot;creation_height&quot;: &quot;546726&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-11-29T20:41:54.102529873Z&quot;,\r\n  &quot;balance&quot;: 1\r\n}\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1rjg0vg9hlu8kygnrdehzt3z0t4ea5ssu6wkm06&quot;,\r\n  &quot;creation_height&quot;: &quot;560257&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-11-30T18:22:32.286053755Z&quot;,\r\n  &quot;balance&quot;: 4\r\n}\r\n{\r\n  &quot;delegator_address&quot;: &quot;tori1aw44evl5zlqtw93zln83tp4v3w4kp6e9zmx64k&quot;,\r\n  &quot;creation_height&quot;: &quot;567462&quot;,\r\n  &quot;completion_time&quot;: &quot;2022-12-01T05:57:49.397647828Z&quot;,\r\n  &quot;balance&quot;: 0.112142\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74536740/how-to-select-only-a-couple-keys-and-keep-it-in-an-array-format-using-jq",
        "title": "How to Select only a couple keys and keep it in an array format using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669192368,
                "last_edit_date": 1669192368,
                "creation_date": 1669187534,
                "answer_id": 74542973,
                "question_id": 74542915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To have a single count of all resulting items, either make an array and determine its `length`:\r\n~~~sh\r\n.data.data | map(select(.adminLock == 1)) | length\r\n~~~\r\n~~~json\r\n5\r\n~~~\r\n[Demo](https://jqplay.org/s/4fbKGzpq7DL)\r\n\r\nOr iterate and count, e.g. using `reduce`:\r\n~~~sh\r\nreduce (.data.data[] | select(.adminLock == 1)) as $i (0; .+1)\r\n~~~\r\n~~~json\r\n5\r\n~~~\r\n[Demo](https://jqplay.org/s/gb0wrF7JLVC)\r\n\r\nThe first approach may seem more &quot;natural&quot; but it actually builds up an array that you eventually may not need. Therefore, if you only need the count, not the items themselves, use the second approach.\r\n\r\n---\r\nTo count the items based on a certain property, say, the distinct values of `.domains`, create an according structure and count as shown before. The array approach could group the items using `group_by`:\r\n~~~sh\r\n.data.data | map(select(.adminLock == 1)) | group_by(.domains)\r\n| map(&quot;\\(first.domains): \\(length)&quot;) # create your desired format\r\n~~~\r\n~~~json\r\n[\r\n  &quot;dome2.com: 1&quot;,\r\n  &quot;dome4.com: 1&quot;,\r\n  &quot;dome5.com: 1&quot;,\r\n  &quot;dome6.com: 1&quot;,\r\n  &quot;dome7.com: 1&quot;\r\n]\r\n~~~\r\n[Demo](https://jqplay.org/s/EZhF3ndkm8P)\r\n\r\nThe iterative approach successively builds up your output structure, e.g. an object with the property as field names:\r\n~~~sh\r\nreduce (.data.data[] | select(.adminLock == 1)) as $i (\r\n  {}; .[$i.domains] += 1 # create your desired format\r\n)\r\n~~~\r\n~~~json\r\n{\r\n  &quot;dome2.com&quot;: 1,\r\n  &quot;dome4.com&quot;: 1,\r\n  &quot;dome5.com&quot;: 1,\r\n  &quot;dome6.com&quot;: 1,\r\n  &quot;dome7.com&quot;: 1\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/p_ATbzwRqT9)",
                "title": "bash shell script jq Get a field and make statistics"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669189026,
                "last_edit_date": 1669189026,
                "creation_date": 1669187618,
                "answer_id": 74542986,
                "question_id": 74542915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In general, rather than constructing an array, it&#39;s better to use a stream-oriented counting method:\r\n\r\n```\r\ndef count(s): reduce s as $x (0;.+1);\r\n```\r\n\r\nIn your case, it seems you could get away with:\r\n```\r\ncount(.data.data[] | select(.adminLock == 1))\r\n```\r\n\r\nbut perhaps you would want to check there is a `domains` key:\r\n```\r\ncount(.data.data[] | select(.adminLock == 1 and has(&quot;domains&quot;) ))\r\n```\r\n\r\nIf, however, you want to count the number of **distinct** domains satisfying the condition, it would probably be simplest to use `unique`:\r\n```\r\n[.data.data[] | select(.adminLock == 1) | .domains] | unique | length\r\n```\r\n\r\nBut it&#39;s not hard to write a stream-oriented version of `unique` to avoid having to call `unique/0` ...",
                "title": "bash shell script jq Get a field and make statistics"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1669192368,
        "creation_date": 1669187142,
        "last_edit_date": 1669188699,
        "question_id": 74542915,
        "body_markdown": "I want to count the number of &quot;domains&quot; for which &quot;adminLock&quot; is equal to 1.\r\n\r\nThis is my json data structure:\r\n\r\n    {\r\n      &quot;code&quot;: 0,\r\n      &quot;message&quot;: &quot;成功&quot;,\r\n      &quot;data&quot;: {\r\n        &quot;recordCount&quot;: &quot;128&quot;,\r\n        &quot;pageSize&quot;: 100,\r\n        &quot;page&quot;: 1,\r\n        &quot;pageCount&quot;: 2,\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;domainsID&quot;: &quot;173652434&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome1.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 0,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173205836&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome2.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 1,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173205812&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome3.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 0,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173203610&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome4.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 1,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173203210&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome5.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 1,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173203131&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome6.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 1,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          },\r\n          {\r\n            &quot;domainsID&quot;: &quot;173203074&quot;,\r\n            &quot;nsGroupID&quot;: &quot;199&quot;,\r\n            &quot;groupID&quot;: &quot;78987&quot;,\r\n            &quot;domains&quot;: &quot;dome7.com&quot;,\r\n            &quot;state&quot;: 3,\r\n            &quot;userLock&quot;: 0,\r\n            &quot;adminLock&quot;: 1,\r\n            &quot;view_type&quot;: &quot;1&quot;\r\n          }\r\n        ],\r\n        &quot;nextPage&quot;: 2\r\n      }\r\n    }\r\n\r\nHere&#39;s what I have so far:\r\n\r\n    &#39;.data.data[] | select(.adminLock == 1) | .domains&#39;\r\n\r\nI can get the value of .domains, but how can I count how many times it occurs?\r\n# Replenish\r\nThe script I am using is the bash shell\r\nThis command gets the value, I want to count the domains value in the case of adminLock=1, and count the number of domains\r\n————————\r\nJudging that adminLock=1 is getting the domains value, and counting how many in total",
        "link": "https://stackoverflow.com/questions/74542915/bash-shell-script-jq-get-a-field-and-make-statistics",
        "title": "bash shell script jq Get a field and make statistics"
    },
    {
        "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": 1669203202,
                "post_id": 74546051,
                "comment_id": 131589936,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3150808,
                    "reputation": 45,
                    "user_id": 2664304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3c9c29624c0880a3c2535c1a75041eba?s=256&d=identicon&r=PG",
                    "display_name": "user2664304",
                    "link": "https://stackoverflow.com/users/2664304/user2664304"
                },
                "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": 1669204621,
                "post_id": 74546051,
                "comment_id": 131590436,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3150808,
                    "reputation": 45,
                    "user_id": 2664304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3c9c29624c0880a3c2535c1a75041eba?s=256&d=identicon&r=PG",
                    "display_name": "user2664304",
                    "link": "https://stackoverflow.com/users/2664304/user2664304"
                },
                "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": 1669204944,
                "post_id": 74546051,
                "comment_id": 131590555,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1669203142,
        "creation_date": 1669202862,
        "question_id": 74546051,
        "body_markdown": "I make a call to an HPE iLO to pull back SNMP v3 user information.  I get:\r\n\r\n    curl --silent --insecure --header &quot;X-API-Token: ${iLOAuth}&quot; --request GET ${iLOSSO}/redfish/v1/Managers/v1/snmpservice/snmpusers | jq -r &#39;.Members[]&#39;\r\n\r\nand get back:\r\n\r\n    {\r\n       &quot;@odata.id&quot;: &quot;/redfish/v1/Managers/1/SnmpService/SNMPUsers/1&quot;\r\n    }\r\n    {\r\n       &quot;@odata.id&quot;: &quot;/redfish/v1/Managers/1/SnmpService/SNMPUsers/3&quot;\r\n    }\r\n\r\nI just want to get back the values, but if I try:\r\n\r\n    jq -r &#39;.Members[] | .@odata.id&#39;\r\n\r\nI get back an error.  Does anyone know the proper syntax to use?",
        "link": "https://stackoverflow.com/questions/74546051/extract-value-from-json-with-jq",
        "title": "extract value from JSON with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669235892,
                "last_edit_date": 1669235892,
                "creation_date": 1669222250,
                "answer_id": 74550396,
                "question_id": 74550307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(. + (.Tags | from_entries) | del(.Tags))\r\n```\r\n\r\n----------\r\n\r\nWill [`map()`][1] over all the objects in the array and:\r\n* Convert `.Tags` to an object using [`from_entries`][2]\r\n    * This is added to the original object (`. + ()`) \r\n* Delete the original `.Tags`\r\n\r\n----------\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;A&quot;: &quot;a&quot;,\r\n    &quot;x&quot;: 0,\r\n    &quot;y&quot;: 1\r\n  }\r\n]\r\n```\r\n\r\n#### [Online Demo](https://jqplay.org/s/LBsOC09OKiH)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [2]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries",
                "title": "How can I spread array elements in parent object by jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669294807,
        "creation_date": 1669221766,
        "last_edit_date": 1669294807,
        "question_id": 74550307,
        "body_markdown": "I want to transform following type of json obj\r\n\r\n```json\r\n[\r\n{\r\n  &quot;A&quot;: &quot;a&quot;,\r\n  &quot;Tags&quot;: [\r\n    { &quot;key&quot;:&quot;x&quot;, &quot;value&quot;:0},\r\n    { &quot;key&quot;:&quot;y&quot;, &quot;value&quot;:1},\r\n  ]\r\n},\r\n{...}\r\n]\r\n```\r\nto this, including Tags list on top\r\n```json\r\n[\r\n{\r\n  &quot;A&quot;: &quot;a&quot;,\r\n  &quot;x&quot;: 0,\r\n  &quot;y&quot;: 1\r\n},\r\n{...}\r\n]\r\n```\r\n\r\n\r\nI try to use JQ but without result.",
        "link": "https://stackoverflow.com/questions/74550307/how-can-i-spread-array-elements-in-parent-object-by-jq",
        "title": "How can I spread array elements in parent object by jq?"
    },
    {
        "tags": [
            "json",
            "powershell",
            "awk",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669230993,
                "creation_date": 1669230993,
                "answer_id": 74551962,
                "question_id": 74551827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would recommend using PowerShell since working with objects tends to be easier overall. Fortunately, PowerShell has a `ConvertFrom-Json` cmdlet you can use to convert the returned text into a PS object letting you reference the properties via dot notation (`.Participant_id`). Then, you&#39;d just have to convert each iteration back to JSON format and export it. Here I use `New-Item` to create the file with the output but piping to `Out-File` would work as well.\r\n```sh\r\n$json = Get-Content -Path &#39;.\\Metadata_01.json&#39; -Raw | ConvertFrom-Json \r\nforeach ($json_object in $json)\r\n{\r\n    New-Item -Path &quot;.\\Desktop\\&quot; -Name &quot;$($json_object.Participant_id).json&quot; -Value (ConvertTo-Json -InputObject $json_object) -ItemType &#39;File&#39; -Force\r\n}\r\n```\r\nThe issue I can see you *probably* running into is not enough memory, due to the size of that file since you&#39;ll be saving to a variable first in this example. There are ways around it but this is for demonstration purposes.",
                "title": "Split large JSON file by using jq and awk"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669278659,
                "last_edit_date": 1669278659,
                "creation_date": 1669239005,
                "answer_id": 74553210,
                "question_id": 74551827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What adjustments should I make ...?\r\n\r\nI&#39;d go with:\r\n```\r\njq -cr &#39;.[] | (.Participant_id, .)&#39; Metadata_01.json | awk &#39;\r\n  NR%2==1 {fn=&quot;id.&quot; $0 &quot;.json&quot;; next} {print &gt;&gt; fn; close(fn); }\r\n&#39;\r\n```\r\n\r\nand then run something like `jq . &quot;$FILE&quot; | sponge &quot;$FILE&quot;` to pretty-print each file.\r\n\r\nAlternatively, if you can navigate your way around any issues that might arise when escaping quotation marks, you could get awk to call jq:\r\n```\r\njq -cr &#39;.[] | (.Participant_id, .)&#39; Metadata_01.json | awk -v q=$&#39;\\&#39;&#39; &#39;\r\n  NR%2==1 {fn = &quot;id.&quot; $0 &quot;.json&quot;; next}\r\n  {  system( (&quot;jq . &lt;&lt;&lt; &quot; q $0 q &quot; &gt;&gt; \\&quot;&quot; fn &quot;\\&quot;&quot;) );\r\n     close(fn);\r\n  }\r\n&#39;\r\n```\r\n\r\n### &quot;Big Data&quot;\r\nOf course if the input file is too large or too slow for `jq empty`, then you will want to consider alternatives, e.g. jq&#39;s `--stream` option, `jstream`, or my own [jm][1]. For example if you want the JSON to be pretty-printed in each file:\r\n\r\n```\r\nwhile read -r json\r\ndo\r\n   fn=$(jq -r .Participant_id &lt;&lt;&lt; &quot;$json&quot;)\r\n   &lt;&lt;&lt; &quot;$json&quot; jq . &gt; &quot;id.$fn.json&quot;\r\ndone &lt; &lt;(jm Metadata_01.json)\r\n```\r\n\r\n\r\n  [1]: https://github.com/pkoppstein/jm",
                "title": "Split large JSON file by using jq and awk"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1669278659,
        "creation_date": 1669230124,
        "last_edit_date": 1669230244,
        "question_id": 74551827,
        "body_markdown": "I have a large file called \r\n```\r\nMetadata_01.json\r\n```\r\nIt consistst of blocks that following this structure:\r\n\r\n```\r\n[\r\n {\r\n  &quot;Participant_id&quot;: &quot;P04_00001&quot;,\r\n  &quot;no_of_people&quot;: &quot;Multiple&quot;,\r\n  &quot;apparent_gender&quot;: &quot;F&quot;,\r\n  &quot;geographic_location&quot;: &quot;AUS&quot;,\r\n  &quot;ethnicity&quot;: &quot;Caucasian&quot;,\r\n  &quot;capture_device_used&quot;: &quot;iOS 14&quot;,\r\n  &quot;camera_orientation&quot;: &quot;Portrait&quot;,\r\n  &quot;camera_position&quot;: &quot;Side View&quot;,\r\n  &quot;indoor_outdoor_env&quot;: &quot;Indoors&quot;,\r\n  &quot;lighting_condition&quot;: &quot;Bright&quot;,\r\n  &quot;Occluded&quot;: 1,\r\n  &quot;category&quot;: &quot;Two Person&quot;,\r\n  &quot;camera_movement&quot;: &quot;Still&quot;,\r\n  &quot;action&quot;: &quot;No action&quot;,\r\n  &quot;indoor_outdoor_in_moving_car_or_train&quot;: &quot;Indoor&quot;,\r\n  &quot;daytime_nighttime&quot;: &quot;Nighttime&quot;\r\n },\r\n {\r\n  &quot;Participant_id&quot;: &quot;P04_00002&quot;,\r\n  &quot;no_of_people&quot;: &quot;Single&quot;,\r\n  &quot;apparent_gender&quot;: &quot;M&quot;,\r\n  &quot;geographic_location&quot;: &quot;AUS&quot;,\r\n  &quot;ethnicity&quot;: &quot;Caucasian&quot;,\r\n  &quot;capture_device_used&quot;: &quot;iOS 14&quot;,\r\n  &quot;camera_orientation&quot;: &quot;Portrait&quot;,\r\n  &quot;camera_position&quot;: &quot;Frontal View&quot;,\r\n  &quot;indoor_outdoor_env&quot;: &quot;Outdoors&quot;,\r\n  &quot;lighting_condition&quot;: &quot;Bright&quot;,\r\n  &quot;Occluded&quot;: &quot;None&quot;,\r\n  &quot;category&quot;: &quot;Animals&quot;,\r\n  &quot;camera_movement&quot;: &quot;Still&quot;,\r\n  &quot;action&quot;: &quot;Small action&quot;,\r\n  &quot;indoor_outdoor_in_moving_car_or_train&quot;: &quot;Outdoor&quot;,\r\n  &quot;daytime_nighttime&quot;: &quot;Daytime&quot;\r\n },\r\n```\r\nAnd so on... thousands of them.\r\n\r\nI am using the following command:\r\n```\r\njq -cr &#39;.[]&#39; Metadata_01.json | awk &#39;{print &gt; (NR &quot;.json&quot;)}&#39;\r\n```\r\n\r\nAnd it&#39;s kinda doing the expected work.\r\n\r\n[From large file that is structured like this](https://i.sstatic.net/XoeZg.jpg)\r\n\r\n[I am getting tons of files that named like this](https://i.sstatic.net/iQvqB.jpg)\r\n\r\n[And structure like this (in one line)](https://i.sstatic.net/1ovh2.png)\r\n\r\nInstead of those results I need each json file to be named after the &quot;Participant_id&quot; (e.g. P04_00002.json)\r\nAnd I want to preserve the json structure to look like that for each file\r\n\r\n```\r\n{\r\n  &quot;Participant_id&quot;: &quot;P04_00002&quot;,\r\n  &quot;no_of_people&quot;: &quot;Single&quot;,\r\n  &quot;apparent_gender&quot;: &quot;M&quot;,\r\n  &quot;geographic_location&quot;: &quot;AUS&quot;,\r\n  &quot;ethnicity&quot;: &quot;Caucasian&quot;,\r\n  &quot;capture_device_used&quot;: &quot;iOS 14&quot;,\r\n  &quot;camera_orientation&quot;: &quot;Portrait&quot;,\r\n  &quot;camera_position&quot;: &quot;Frontal View&quot;,\r\n  &quot;indoor_outdoor_env&quot;: &quot;Outdoors&quot;,\r\n  &quot;lighting_condition&quot;: &quot;Bright&quot;,\r\n  &quot;Occluded&quot;: &quot;None&quot;,\r\n  &quot;category&quot;: &quot;Animals&quot;,\r\n  &quot;camera_movement&quot;: &quot;Still&quot;,\r\n  &quot;action&quot;: &quot;Small action&quot;,\r\n  &quot;indoor_outdoor_in_moving_car_or_train&quot;: &quot;Outdoor&quot;,\r\n  &quot;daytime_nighttime&quot;: &quot;Daytime&quot;\r\n }\r\n```\r\n\r\nWhat adjustments should I make to the command above to achieve this?\r\nOr maybe there&#39;s an easier way to do this? Thank you!",
        "link": "https://stackoverflow.com/questions/74551827/split-large-json-file-by-using-jq-and-awk",
        "title": "Split large JSON file by using jq and awk"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669239905,
                "last_edit_date": 1669239905,
                "creation_date": 1669239631,
                "answer_id": 74553273,
                "question_id": 74553238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just reshape the objects using `map_values`:\r\n~~~sh\r\njq &#39;INDEX(&quot;\\(.Country)-\\(.Location)&quot;) | map_values({Name, Coordinates})&#39;\r\n~~~\r\n\r\nOr do it all in one go using `reduce`:\r\n~~~sh\r\njq &#39;reduce .[] as $i ({}; .&quot;\\($i.Country)-\\($i.Location)&quot; = ($i|{Name, Coordinates}))&#39;\r\n~~~",
                "title": "Use jq to extract a subset of a nested object&#39;s fields?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669239755,
                "last_edit_date": 1669239755,
                "creation_date": 1669239659,
                "answer_id": 74553278,
                "question_id": 74553238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`map_values`](https://stedolan.github.io/jq/manual/v1.6/#map(x),map_values(x)), which applies to filter to every property&#39;s value in the object:\r\n\r\n```\r\nINDEX(&quot;\\(.Country)-\\(.Location)&quot;) | map_values({Name, Coordinates})\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;AD-CAN&quot;: {\r\n    &quot;Name&quot;: &quot;Canillo&quot;,\r\n    &quot;Coordinates&quot;: &quot;4234N 00135E&quot;\r\n  }\r\n}\r\n```",
                "title": "Use jq to extract a subset of a nested object&#39;s fields?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1669239905,
        "creation_date": 1669239310,
        "last_edit_date": 1669239501,
        "question_id": 74553238,
        "body_markdown": "I have a 26MB JSON file containing UN/LOCODE data that I want to restructure and remove some data from so that it takes less space in my app&#39;s binary package.\r\n\r\nThe JSON contains an array of objects like this:\r\n\r\n```json\r\n{\r\n    &quot;Change&quot;: null,\r\n    &quot;Coordinates&quot;: &quot;4234N 00135E&quot;,\r\n    &quot;Country&quot;: &quot;AD&quot;,\r\n    &quot;Date&quot;: &quot;0307&quot;,\r\n    &quot;Function&quot;: &quot;--3-----&quot;,\r\n    &quot;IATA&quot;: null,\r\n    &quot;Location&quot;: &quot;CAN&quot;,\r\n    &quot;Name&quot;: &quot;Canillo&quot;,\r\n    &quot;NameWoDiacritics&quot;: &quot;Canillo&quot;,\r\n    &quot;Remarks&quot;: null,\r\n    &quot;Status&quot;: &quot;RL&quot;,\r\n    &quot;Subdivision&quot;: null\r\n}\r\n```\r\n\r\nThe desired structure is an object rather than an array, keyed on the concatenation of the Country and Location fields, but the only nested fields that I am interested in are &quot;Name&quot; and &quot;Coordinates&quot;.\r\n\r\nI have been able to accomplish the first step with:\r\n\r\n```\r\njq &#39;INDEX(&quot;\\(.Country)-\\(.Location)&quot;)&#39;\r\n```\r\n\r\ngiving me:\r\n```json\r\n{\r\n    &quot;AD-CAN&quot;: {\r\n        &quot;Change&quot;: null,\r\n        &quot;Coordinates&quot;: &quot;4234N 00135E&quot;,\r\n        &quot;Country&quot;: &quot;AD&quot;,\r\n        &quot;Date&quot;: &quot;0307&quot;,\r\n        &quot;Function&quot;: &quot;--3-----&quot;,\r\n        &quot;IATA&quot;: null,\r\n        &quot;Location&quot;: &quot;CAN&quot;,\r\n        &quot;Name&quot;: &quot;Canillo&quot;,\r\n        &quot;NameWoDiacritics&quot;: &quot;Canillo&quot;,\r\n        &quot;Remarks&quot;: null,\r\n        &quot;Status&quot;: &quot;RL&quot;,\r\n        &quot;Subdivision&quot;: null\r\n   },\r\n   ...\r\n}\r\n```\r\n\r\nbut I cannot figure out how to get only the desired keys from the nested objects inside the new top-level object.\r\n\r\nIf this can&#39;t be done with `jq` I&#39;ll have to resort to a custom script to do it.",
        "link": "https://stackoverflow.com/questions/74553238/use-jq-to-extract-a-subset-of-a-nested-objects-fields",
        "title": "Use jq to extract a subset of a nested object&#39;s fields?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "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": 1669274806,
                "post_id": 74556998,
                "comment_id": 131608420,
                "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": 1669275383,
                "post_id": 74556998,
                "comment_id": 131608595,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1669275305,
                "creation_date": 1669275305,
                "answer_id": 74557113,
                "question_id": 74556998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How about\r\n\r\n    jq -n &#39;$ARGS.positional | map({ (.): env[.] }) | add&#39; --args &quot;${arr[@]}&quot;\r\n\r\nUsing `$ARGS.positional` with `--args` avoids the need to execute jq once per item in the array, and the `env` builtin is the thing you needed to pull values out of the environment.",
                "title": "Create JSON of environment variables name-value pairs from array of environment variable names with jq in bash script"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669280953,
                "last_edit_date": 1669280953,
                "creation_date": 1669280555,
                "answer_id": 74558074,
                "question_id": 74556998,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since by assumption the variables referenced in `arr` are *environment* variables,\r\nyou could use `printf` along the lines of your attempt as follows:\r\n\r\n```\r\nprintf &#39;%s\\n&#39; &quot;${arr[@]}&quot; | jq -nR &#39;[inputs | {(.): env[.] }] | add&#39;\r\n```\r\nThis also works with `gojq` and `fq`, and might be useful if your jq does not support $ARGS\r\n\r\n",
                "title": "Create JSON of environment variables name-value pairs from array of environment variable names with jq in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1669280953,
        "creation_date": 1669274672,
        "question_id": 74556998,
        "body_markdown": "**Requirement:**\r\n\r\nIn a BASH script,\r\n\r\n...iterate over an array of environment variable names as shown below:\r\n\r\n`arr = (&#39;env_var1&#39; &#39;env_var2&#39; &#39;env_var3&#39;)`\r\n\r\nand, using [jq][1] generate a JSON of environment variable name-value pairs like below:\r\n```json\r\n{\r\n &quot;env_var1&quot;: &quot;env_var1_value_is_1&quot;,\r\n &quot;env_var2&quot;: &quot;env_var2_value_is_2&quot;,\r\n &quot;env_var3&quot;: &quot;env_var3_value_is_3&quot;\r\n}\r\n```\r\n\r\n**Current approach:**\r\nUsing this [stackoverflow question&#39;s solution][2] as a reference\r\n```\r\nprintf &#39;%s\\n&#39; &quot;${arr[@]}&quot; |\r\n  xargs -L 1 -I {} jq -sR --arg key {} &#39;{ ($key): . }&#39; | jq -s &#39;add&#39;\r\n```\r\nwhere `arr` array contains the environment variable names for which I want the values, however I am unable to interpolate the `${environment_variable_name}` into the JSON&#39;s `value` in each key-value pair\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://stackoverflow.com/questions/61807377/in-bash-create-json-object-of-key-filename-and-value-file-contents-given-sequen?noredirect=1&amp;lq=1",
        "link": "https://stackoverflow.com/questions/74556998/create-json-of-environment-variables-name-value-pairs-from-array-of-environment",
        "title": "Create JSON of environment variables name-value pairs from array of environment variable names with jq in bash script"
    },
    {
        "tags": [
            "json",
            "range",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1669315696,
                "last_edit_date": 1669315696,
                "creation_date": 1669313141,
                "answer_id": 74564759,
                "question_id": 74564460,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could exploit the circumstance that `to_entries`, when applied to an array, will use the (0-based) item index as `.key`. Add `+1` to make it 1-based.\r\n~~~sh\r\n.data.items |= [to_entries[] | .value + {ranking: (.key+1)}]\r\n~~~\r\n[Demo](https://jqplay.org/s/D9okFNCRb8K)\r\n\r\nFor an approach based on `range(length)`, I&#39;d use `transpose` to zip the items array with the indices array:\r\n~~~sh\r\n.data.items |= ([., [range(length)+1]] | transpose | map(.[0] + {ranking: .[1]}))\r\n~~~\r\n[Demo](https://jqplay.org/s/T5HpxDITlbn)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;items&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-20964274&quot;,\r\n        &quot;size&quot;: &quot;80 ct&quot;,\r\n        &quot;productId&quot;: &quot;20964274&quot;,\r\n        &quot;brandName&quot;: &quot;peets&quot;,\r\n        &quot;brandId&quot;: &quot;25555&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n        &quot;ranking&quot;: 1\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-17284948&quot;,\r\n        &quot;size&quot;: &quot;75 ct&quot;,\r\n        &quot;productId&quot;: &quot;17284948&quot;,\r\n        &quot;legacyId&quot;: &quot;2991007854&quot;,\r\n        &quot;brandName&quot;: &quot;peet&#39;s&quot;,\r\n        &quot;brandId&quot;: &quot;50954&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n        &quot;ranking&quot;: 2\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-19232655&quot;,\r\n        &quot;size&quot;: &quot;3 lb&quot;,\r\n        &quot;productId&quot;: &quot;19232655&quot;,\r\n        &quot;brandName&quot;: &quot;kirkland signature&quot;,\r\n        &quot;brandId&quot;: &quot;7632&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n        &quot;ranking&quot;: 3\r\n      }\r\n    ]\r\n  }\r\n}\r\n~~~\r\n\r\nNote: JSON does not support or recognize the ordering of object fields. Thus, the actual position of the new `ranking` field makes no structural difference. You can, however, tweak jq into changing the textual representation it generates for output. For  instance, to move the `retailer` field to last position, remove it and add it again with `del(.retailer) + {retailer}` (See demos for the [to_entries](https://jqplay.org/s/HOKxtm0hpqD) and the [range/transpose](https://jqplay.org/s/vTrggRk4ZZl) approaches). But keep in mind that this modification is only aesthetical. Any JSON post-processor may disregard this ordering again.\r\n",
                "title": "JQ Add key/value to json object in order to enumerate the objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1669315788,
        "creation_date": 1669311048,
        "question_id": 74564460,
        "body_markdown": "I have a list of objects (20 in total) and I need to insert a new key-value pair with the positional number  of each object (values in range 1 to 20).\r\nI have managed to put together this code, however I end up replicating the objects inside of the array so instead of 20 objects I end up with about 100. \r\n\r\n```\r\njq &quot;(.data.items, .data.primaryItemResultList.items)| values | length as $l | values[] += {ranking: range(1, $l)}| .[]&quot;\r\n```\r\n\r\nWhen I ty to add a static value to the &quot;ranking&quot; it works correctly, however if I use the range function it doesn&#39;t produce the desired output as mentioned before. \r\n\r\nHere is an example of the shortened code:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;items&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-20964274&quot;,\r\n        &quot;size&quot;: &quot;80 ct&quot;,\r\n        &quot;productId&quot;: &quot;20964274&quot;,\r\n        &quot;brandName&quot;: &quot;peets&quot;,\r\n        &quot;brandId&quot;: &quot;25555&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-17284948&quot;,\r\n        &quot;size&quot;: &quot;75 ct&quot;,\r\n        &quot;productId&quot;: &quot;17284948&quot;,\r\n        &quot;legacyId&quot;: &quot;2991007854&quot;,\r\n        &quot;brandName&quot;: &quot;peet&#39;s&quot;,\r\n        &quot;brandId&quot;: &quot;50954&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-19232655&quot;,\r\n        &quot;size&quot;: &quot;3 lb&quot;,\r\n        &quot;productId&quot;: &quot;19232655&quot;,\r\n        &quot;brandName&quot;: &quot;kirkland signature&quot;,\r\n        &quot;brandId&quot;: &quot;7632&quot;,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nWould anyone be able to help with this issue and identify the mistake?\r\n\r\nThe expected output is:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;items&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-20964274&quot;,\r\n        &quot;size&quot;: &quot;80 ct&quot;,\r\n        &quot;productId&quot;: &quot;20964274&quot;,\r\n        &quot;brandName&quot;: &quot;peets&quot;,\r\n        &quot;brandId&quot;: &quot;25555&quot;,\r\n        &quot;ranking&quot;: 1,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-17284948&quot;,\r\n        &quot;size&quot;: &quot;75 ct&quot;,\r\n        &quot;productId&quot;: &quot;17284948&quot;,\r\n        &quot;legacyId&quot;: &quot;2991007854&quot;,\r\n        &quot;brandName&quot;: &quot;peet&#39;s&quot;,\r\n        &quot;brandId&quot;: &quot;50954&quot;,\r\n        &quot;ranking&quot;: 2,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n        },\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;items_10244-19232655&quot;,\r\n        &quot;size&quot;: &quot;3 lb&quot;,\r\n        &quot;productId&quot;: &quot;19232655&quot;,\r\n        &quot;brandName&quot;: &quot;kirkland signature&quot;,\r\n        &quot;brandId&quot;: &quot;7632&quot;,\r\n        &quot;ranking&quot;: 3,\r\n        &quot;retailer&quot;: {\r\n          &quot;isUltrafast&quot;: false,\r\n          &quot;__typename&quot;: &quot;RetailersRetailer&quot;\r\n      }\r\n    ]\r\n  }\r\n```",
        "link": "https://stackoverflow.com/questions/74564460/jq-add-key-value-to-json-object-in-order-to-enumerate-the-objects",
        "title": "JQ Add key/value to json object in order to enumerate the objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669387012,
                "last_edit_date": 1669387012,
                "creation_date": 1669387002,
                "answer_id": 74574352,
                "question_id": 74570585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ok, i have figured it out. I have changed the .Groups[] index like that\r\n\r\n```\r\nupdated_project=$(echo &quot;$projects&quot; | jq &quot;.Projects[] | select(.Project[].KEY==\\&quot;$key\\&quot;) | .Project[].Permissions[].Groups[.Project[].Permissions[].Groups | length] |= $data&quot;)\r\n```\r\n\r\nAnd it gave me the proper output.",
                "title": "JQ merge object into array based on the same key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669387012,
        "creation_date": 1669368304,
        "last_edit_date": 1669368523,
        "question_id": 74570585,
        "body_markdown": "I have a &quot;base&quot; json like this\r\n\r\n```json\r\n{\r\n    &quot;Projects&quot;: [\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;FOO&quot;,\r\n            &quot;Name&quot;: &quot;A new Bitbucket project&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY1&quot;,\r\n            &quot;Name&quot;: &quot;Name1&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY2&quot;,\r\n            &quot;Name&quot;: &quot;Name2&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY3&quot;,\r\n            &quot;Name&quot;: &quot;Name3&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY4&quot;,\r\n            &quot;Name&quot;: &quot;Name4&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY5&quot;,\r\n            &quot;Name&quot;: &quot;Name5&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n```\r\n\r\n\r\nAnd i have a loop that generates objects like this\r\n\r\n\r\n```\r\n{ &quot;Project&quot;: [ { &quot;KEY&quot;: &quot;FOO&quot;, &quot;Name&quot;: &quot;A new Bitbucket project&quot;, &quot;Permissions&quot;: [ { &quot;Groups&quot;: [], &quot;Users&quot;: [] } ] }, { &quot;Permissions&quot;: [ { &quot;group&quot;: { &quot;name&quot;: &quot;test-group-4&quot; }, &quot;permission&quot;: &quot;PROJECT_READ&quot; } ] } ] }\r\n{ &quot;Project&quot;: [ { &quot;KEY&quot;: &quot;KEY2&quot;, &quot;Name&quot;: &quot;Name2&quot;, &quot;Permissions&quot;: [ { &quot;Groups&quot;: [], &quot;Users&quot;: [] } ] }, { &quot;Permissions&quot;: [ { &quot;group&quot;: { &quot;name&quot;: &quot;test-group-1&quot; }, &quot;permission&quot;: &quot;PROJECT_WRITE&quot; } ] } ] }\r\n{ &quot;Project&quot;: [ { &quot;KEY&quot;: &quot;KEY5&quot;, &quot;Name&quot;: &quot;Name5&quot;, &quot;Permissions&quot;: [ { &quot;Groups&quot;: [], &quot;Users&quot;: [] } ] }, { &quot;Permissions&quot;: [ { &quot;group&quot;: { &quot;name&quot;: &quot;test-group-1&quot; }, &quot;permission&quot;: &quot;PROJECT_READ&quot; } ] } ] }\r\n{ &quot;Project&quot;: [ { &quot;KEY&quot;: &quot;KEY5&quot;, &quot;Name&quot;: &quot;Name5&quot;, &quot;Permissions&quot;: [ { &quot;Groups&quot;: [], &quot;Users&quot;: [] } ] }, { &quot;Permissions&quot;: [ { &quot;group&quot;: { &quot;name&quot;: &quot;test-group-2&quot; }, &quot;permission&quot;: &quot;PROJECT_WRITE&quot; } ] } ] }\r\n{ &quot;Project&quot;: [ { &quot;KEY&quot;: &quot;KEY5&quot;, &quot;Name&quot;: &quot;Name5&quot;, &quot;Permissions&quot;: [ { &quot;Groups&quot;: [], &quot;Users&quot;: [] } ] }, { &quot;Permissions&quot;: [ { &quot;group&quot;: { &quot;name&quot;: &quot;test-group-3&quot; }, &quot;permission&quot;: &quot;PROJECT_ADMIN&quot; } ] } ] }\r\n```\r\n\r\n\r\nMy whole bash script looks like this\r\n\r\n\r\n```bash\r\n#!/bin/bash\r\nset -e\r\n\r\nwhile getopts u:p:b: flag; do\r\n    case &quot;${flag}&quot; in\r\n    u) username=${OPTARG} ;;\r\n    p) password=${OPTARG} ;;\r\n    b) url=${OPTARG} ;;\r\n    esac\r\ndone\r\n\r\nkeys=$(curl -s -u $username:$password -X GET -H &quot;Content-Type: application/json&quot; $url/rest/api/1.0/projects/ | jq -r .values[].key)\r\nprojects=&quot;{\\&quot;Projects\\&quot; : []}&quot;\r\n\r\nfor key in $keys; do\r\n\r\n    groups=$(curl -s -u $username:$password -X GET -H &quot;Content-Type: application/json&quot; $url/rest/api/1.0/projects/$key/permissions/groups/ | jq)\r\n    project_name=$(curl -s -u $username:$password -X GET -H &quot;Content-Type: application/json&quot; $url/rest/api/1.0/projects/$key | jq -r .name)\r\n    group_names=$(echo ${groups} | jq -r .values[].group.name)\r\n    group_permissions=$(echo ${groups} | jq -r .values[].permission)\r\n    projects=$(echo &quot;$projects&quot; | jq &quot;.Projects[.Projects| length] |={Project:[{KEY:\\&quot;$key\\&quot;,Name:\\&quot;$project_name\\&quot;,Permissions:[{Groups:[],Users:[]}]}]}&quot;)\r\n\r\n    for group in $group_names; do\r\n\r\n        data=$(echo ${groups} | jq -r --arg GROUP &quot;$group&quot; &#39;.values[] | select(.group.name==$GROUP)&#39;)\r\n        updated_project=$(echo &quot;$projects&quot; | jq &quot;.Projects[] | select(.Project[].KEY==\\&quot;$key\\&quot;) | .Project[].Permissions[.Permissions | length].Groups[.Groups | length] |= $data&quot;)\r\n        projects=$(echo &quot;$projects&quot; | jq &quot;(.Projects[] | select(.Project[].KEY==\\&quot;$key\\&quot;) | . ) |= $updated_project&quot;)\r\n\r\n    done\r\ndone\r\n\r\necho $projects | jq\r\n\r\n```\r\n\r\n\r\nI need to merge those objects into the first json, based on the same KEY value so that it would look like this\r\n\r\n\r\n```json\r\n{\r\n    &quot;Projects&quot;: [\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;FOO&quot;,\r\n            &quot;Name&quot;: &quot;A new Bitbucket project&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-4&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_READ&quot;\r\n                  }\r\n                ],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY1&quot;,\r\n            &quot;Name&quot;: &quot;Name1&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY2&quot;,\r\n            &quot;Name&quot;: &quot;Name2&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-1&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_WRITE&quot;\r\n                  }\r\n                ],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY3&quot;,\r\n            &quot;Name&quot;: &quot;Name3&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY4&quot;,\r\n            &quot;Name&quot;: &quot;Name4&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY5&quot;,\r\n            &quot;Name&quot;: &quot;Name5&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-1&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_READ&quot;\r\n                  },\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-2&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_WRITE&quot;\r\n                  },\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-3&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_ADMIN&quot;\r\n                  }\r\n                ],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n```\r\n\r\nBut all i got is (for when there are multiple same KEY values):\r\n\r\n```json\r\n(...)\r\n      {\r\n        &quot;Project&quot;: [\r\n          {\r\n            &quot;KEY&quot;: &quot;KEY5&quot;,\r\n            &quot;Name&quot;: &quot;Name5&quot;,\r\n            &quot;Permissions&quot;: [\r\n              {\r\n                &quot;Groups&quot;: [\r\n                  {\r\n                    &quot;group&quot;: {\r\n                      &quot;name&quot;: &quot;test-group-3&quot;\r\n                    },\r\n                    &quot;permission&quot;: &quot;PROJECT_ADMIN&quot;\r\n                  }\r\n                ],\r\n                &quot;Users&quot;: []\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n```\r\n\r\nSo only one (last) object was added instead of all of them being appended :/ \r\n\r\nWhen i switch to this in the bash script:\r\n\r\n```\r\nupdated_project=$(echo &quot;$projects&quot; | jq &quot;.Projects[] | select(.Project[].KEY==\\&quot;$key\\&quot;) | .Project[.Project | length].Permissions[.Permissions | length].Groups[.Groups | length] |= $data&quot;)\r\n```\r\n\r\nI end up with something like this:\r\n\r\n\r\n```json\r\n(...)\r\n{\r\n  &quot;Project&quot;: [\r\n    {\r\n      &quot;KEY&quot;: &quot;KEY5&quot;,\r\n      &quot;Name&quot;: &quot;Name5&quot;,\r\n      &quot;Permissions&quot;: [\r\n        {\r\n          &quot;Groups&quot;: [],\r\n          &quot;Users&quot;: []\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Permissions&quot;: [\r\n        {\r\n          &quot;Groups&quot;: [\r\n            {\r\n              &quot;group&quot;: {\r\n                &quot;name&quot;: &quot;test-group-1&quot;\r\n              },\r\n              &quot;permission&quot;: &quot;PROJECT_READ&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Permissions&quot;: [\r\n        {\r\n          &quot;Groups&quot;: [\r\n            {\r\n              &quot;group&quot;: {\r\n                &quot;name&quot;: &quot;test-group-2&quot;\r\n              },\r\n              &quot;permission&quot;: &quot;PROJECT_WRITE&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Permissions&quot;: [\r\n        {\r\n          &quot;Groups&quot;: [\r\n            {\r\n              &quot;group&quot;: {\r\n                &quot;name&quot;: &quot;test-group-3&quot;\r\n              },\r\n              &quot;permission&quot;: &quot;PROJECT_ADMIN&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSo it is under the same Project but as a new object in a list rather than in proper place :/ ",
        "link": "https://stackoverflow.com/questions/74570585/jq-merge-object-into-array-based-on-the-same-key",
        "title": "JQ merge object into array based on the same key"
    },
    {
        "tags": [
            "html",
            "json",
            "jq"
        ],
        "comments": [
            {
                "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": 3,
                "creation_date": 1669386861,
                "post_id": 74571402,
                "comment_id": 131636547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10883446,
                    "reputation": 151,
                    "user_id": 8001672,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/36e7bff4c13b764f6d0e410e68f7ebcb?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "P.Lonnie",
                    "link": "https://stackoverflow.com/users/8001672/p-lonnie"
                },
                "reply_to_user": {
                    "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": 1669596365,
                "post_id": 74571402,
                "comment_id": 131671121,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1669409037,
                "last_edit_date": 1669409037,
                "creation_date": 1669392132,
                "answer_id": 74575303,
                "question_id": 74571402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Extracting the correct values is cumbersome, but possible. Given a _valid_ input JSON:\r\n\r\n```\r\n{\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;ingestionTime&quot;: 1669369490368, \r\n            &quot;timestamp&quot;: 1669369486225, \r\n            &quot;message&quot;: &quot;# Time: 2022-11-25T09:44:46.225359Z\\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\\n# Query_time: 1.000765  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\\nuse mysql;\\nSET timestamp=1669369486;\\nselect sleep(1);&quot;\r\n        }, \r\n        {\r\n            &quot;ingestionTime&quot;: 1669369525539, \r\n            &quot;timestamp&quot;: 1669369520857, \r\n            &quot;message&quot;: &quot;# Time: 2022-11-25T09:45:20.857181Z\\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\\n# Query_time: 1.000153  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\\nuse testDB;\\nSET timestamp=1669369520;\\nselect sleep(1);&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nFirst, transform the input data into an array of arrays of the form …\r\n\r\n```\r\n[\r\n  [ &quot;cell 1.1&quot;, &quot;cell 1.2&quot;, &quot;cell 1.3&quot; ],\r\n  [ &quot;cell 2.1&quot;, &quot;cell 2.2&quot;, &quot;cell 2.3&quot; ],\r\n  [ &quot;cell 3.1&quot;, &quot;cell 3.2&quot;, &quot;cell 3.3&quot; ]\r\n]\r\n```\r\n\r\nThis can be done with the following jq program:\r\n\r\n```\r\n[\r\n    [&quot;Time&quot;,&quot;User@Host&quot;,&quot;ID&quot;,&quot;Query time&quot;,&quot;Lock time&quot;,&quot;Rows sent&quot;,&quot;Rows examined&quot;,&quot;Query&quot;],\r\n    (\r\n        .events[] | .message/&quot;\\n&quot; | map(\r\n            (select(startswith(&quot;# Time: &quot;)) | ltrimstr(&quot;# Time: &quot;)),\r\n            (select(startswith(&quot;# User@Host: &quot;)) | ltrimstr(&quot;# User@Host: &quot;)/&quot;:&quot; | (\r\n                 (first | rtrimstr(&quot;  Id&quot;)),\r\n                 (.[-1] | tonumber | tostring)\r\n            )),\r\n            (select(startswith(&quot;# Query_time&quot;))|[splits(&quot; +&quot;;&quot;&quot;)][2,4,6,8])\r\n        )\r\n        + [.[3:] | join(&quot;\\n&quot;)]\r\n    )\r\n]\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;Time&quot;,\r\n    &quot;User@Host&quot;,\r\n    &quot;ID&quot;,\r\n    &quot;Query time&quot;,\r\n    &quot;Lock time&quot;,\r\n    &quot;Rows sent&quot;,\r\n    &quot;Rows examined&quot;,\r\n    &quot;Query&quot;\r\n  ],\r\n  [\r\n    &quot;2022-11-25T09:44:46.225359Z&quot;,\r\n    &quot;Test[Test] @  [111.111.111.111]&quot;,\r\n    &quot;346&quot;,\r\n    &quot;1.000765&quot;,\r\n    &quot;0.000000&quot;,\r\n    &quot;1&quot;,\r\n    &quot;0&quot;,\r\n    &quot;use mysql;\\nSET timestamp=1669369486;\\nselect sleep(1);&quot;\r\n  ],\r\n  [\r\n    &quot;2022-11-25T09:45:20.857181Z&quot;,\r\n    &quot;Test[Test] @  [111.111.111.111]&quot;,\r\n    &quot;346&quot;,\r\n    &quot;1.000153&quot;,\r\n    &quot;0.000000&quot;,\r\n    &quot;1&quot;,\r\n    &quot;0&quot;,\r\n    &quot;use testDB;\\nSET timestamp=1669369520;\\nselect sleep(1);&quot;\r\n  ]\r\n]\r\n```\r\n\r\nOnce you have a matrix with the correct values, the rest is quite straightforward. Add the html tags (named functions make the code more understandable) and make sure to use the `@html` to escape any HTML entities:\r\n\r\n```\r\ndef to_table: &quot;&lt;table&gt;&quot;, .[] ,&quot;&lt;/table&gt;&quot;;\r\ndef to_row: &quot;&lt;tr&gt;&quot;, .[] ,&quot;&lt;/tr&gt;&quot;;\r\ndef to_header: &quot;&lt;th&gt;&quot;, . ,&quot;&lt;/th&gt;&quot;;\r\ndef to_cell: &quot;&lt;td&gt;&quot;, . ,&quot;&lt;/td&gt;&quot;;\r\n\r\n# previous code ... plus:\r\n| map(map(@html))\r\n| .[0] |= map(to_header)\r\n| .[1:][] |= map(to_cell)\r\n| map(to_row)\r\n| to_table\r\n```\r\n\r\nOutput:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-html --&gt;\r\n\r\n    &lt;table&gt;\r\n    &lt;tr&gt;\r\n    &lt;th&gt;\r\n    Time\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    User@Host\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    ID\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    Query time\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    Lock time\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    Rows sent\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    Rows examined\r\n    &lt;/th&gt;\r\n    &lt;th&gt;\r\n    Query\r\n    &lt;/th&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;\r\n    2022-11-25T09:44:46.225359Z\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    Test[Test] @ [111.111.111.111]\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    346\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    1.000765\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    0.000000\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    1\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    0\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    use mysql;\r\n    SET timestamp=1669369486;\r\n    select sleep(1);\r\n    &lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;tr&gt;\r\n    &lt;td&gt;\r\n    2022-11-25T09:45:20.857181Z\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    Test[Test] @ [111.111.111.111]\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    346\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    1.000153\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    0.000000\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    1\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    0\r\n    &lt;/td&gt;\r\n    &lt;td&gt;\r\n    use testDB;\r\n    SET timestamp=1669369520;\r\n    select sleep(1);\r\n    &lt;/td&gt;\r\n    &lt;/tr&gt;\r\n    &lt;/table&gt;\r\n\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\nAlternatively, build the table output as you go. This might be slightly faster because it does not need to build and rebuild arrays all the time (but it does not separate the HTML formatting and the table transformation is cleanly as the first solution):\r\n\r\n```\r\ndef to_row: &quot;&lt;tr&gt;&quot;, .[] ,&quot;&lt;/tr&gt;&quot;;\r\ndef to_header: &quot;&lt;th&gt;&quot;, . ,&quot;&lt;/th&gt;&quot;;\r\ndef to_cell: &quot;&lt;td&gt;&quot;, . ,&quot;&lt;/td&gt;&quot;;\r\n\r\n&quot;&lt;table&gt;&quot;,\r\n([&quot;Time&quot;,&quot;User@Host&quot;,&quot;ID&quot;,&quot;Query time&quot;,&quot;Lock time&quot;,&quot;Rows sent&quot;,&quot;Rows examined&quot;,&quot;Query&quot;]\r\n| map(@html | to_header) | to_row),\r\n(\r\n    .events[] | .message/&quot;\\n&quot; | map(\r\n        (select(startswith(&quot;# Time: &quot;)) | ltrimstr(&quot;# Time: &quot;)),\r\n        (select(startswith(&quot;# User@Host: &quot;)) | ltrimstr(&quot;# User@Host: &quot;)/&quot;:&quot; | (\r\n             (first | rtrimstr(&quot;  Id&quot;)),\r\n             (.[-1] | tonumber | tostring)\r\n        )),\r\n        (select(startswith(&quot;# Query_time&quot;))|[splits(&quot; +&quot;;&quot;&quot;)][2,4,6,8])\r\n    )\r\n    + [.[3:] | join(&quot;\\n&quot;)]\r\n    | map(@html | to_cell)\r\n    | to_row\r\n),\r\n&quot;&lt;/table&gt;&quot;\r\n```\r\n\r\nNB The program must be called with `--raw-output`/`-r` to remove the double quotes from all top-level strings. Only then will you get valid HTML.",
                "title": "jq - backslash n to column output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669421284,
        "creation_date": 1669372242,
        "last_edit_date": 1669421284,
        "question_id": 74571402,
        "body_markdown": "The CloudWatch log format for Aurora MySQL delayed queries is as follows.\r\n\r\n```\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;ingestionTime&quot;: 1669369490368, \r\n            &quot;timestamp&quot;: 1669369486225, \r\n            &quot;message&quot;: &quot;# Time: 2022-11-25T09:44:46.225359Z\\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\\n# Query_time: 1.000765  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\\nuse mysql;\\nSET timestamp=1669369486;\\nselect sleep(1);&quot;\r\n        }, \r\n        {\r\n            &quot;ingestionTime&quot;: 1669369525539, \r\n            &quot;timestamp&quot;: 1669369520857, \r\n            &quot;message&quot;: &quot;# Time: 2022-11-25T09:45:20.857181Z\\n# User@Host: Test[Test] @  [111.111.111.111]  Id:   346\\n# Query_time: 1.000153  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0\\nuse testDB;\\nSET timestamp=1669369520;\\nselect sleep(1);&quot;\r\n        }\r\n    ], \r\n```\r\n\r\nI want to create html format using jq command.&lt;br&gt;\r\nI want to parse message field and The desired format is:\r\n\r\n|Time|User@Host|ID|Query_time|Lock_time|Rows_sent|Rows_examined|Query|\r\n|---|---|---|---|---|---|---|---|\r\n|2022-11-25T09:44:46.225359|Test[Test] @  [111.111.111.111]|346|1.000765|0.000000|1|0|use mysql;\\nSET timestamp=1669369486;\\nselect sleep(1);|\r\n|2022-11-25T09:45:20.857181|Test[Test] @  [111.111.111.111]|346|1.000153|0.000000|1|0|use testDB;\\nSET timestamp=1669369486;\\nselect sleep(1);|\r\n\r\nI tried to do it, but my knowledge is lacking, so I&#39;m asking for help.&lt;br&gt;\r\nIs it possible to divide it like above or even a column?",
        "link": "https://stackoverflow.com/questions/74571402/jq-backslash-n-to-column-output",
        "title": "jq - backslash n to column output"
    },
    {
        "tags": [
            "json",
            "shell",
            "apache-kafka",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669381372,
                "last_edit_date": 1669381372,
                "creation_date": 1669381005,
                "answer_id": 74573164,
                "question_id": 74573067,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know what all of this means, but to add the missing item of `[3,4,5,6]` to a given array, just add one that values `18` (which is `3+4+5+6`) minus the current sum (`add`) of the array:\r\n~~~sh\r\njq &#39;.partitions[].replicas |= . + [18-add]&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/P0sKFQ37SlJ)\r\n\r\nTo make it more generic, you can provide the full array as parameter using `--argjson`:\r\n~~~sh\r\njq --argjson full &#39;[3,4,5,6]&#39; &#39;\r\n  .partitions[].replicas |= . + [($full | add) - add]\r\n&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/4pAw_S-v9__D)\r\n\r\nOr generate the full list from the arrays at hand by making an array of `unique` values:\r\n~~~\r\njq &#39;\r\n  ([.partitions[].replicas[]] | unique | add) as $sum\r\n  | .partitions[].replicas |= . + [$sum - add]\r\n&#39; file.json\r\n~~~\r\n[Demo](https://jqplay.org/s/1-o-t30ynd-)\r\n",
                "title": "Increase replication factor factor of tipics"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669381372,
        "creation_date": 1669380566,
        "question_id": 74573067,
        "body_markdown": "We have about 1k topics on a live kafka cluster. At the moment we have 6 brokers (Id&#39;s 1,2,3,4,5,6) on 3 Data Centers. Our default replication factor at cluster level is set to 3. \r\nNow due to some unavoidable situation, we are loosing one DC(broker id 1 and2). So we have done the partition reassignment where we have reassigned partitions to brokers 3,4,5 and 6.\r\nIn addition to this for higher fault toleration we want to increase  the replication factor to 4 for all the existing topics\r\n\r\nBelow is a small sample of generated topic partitions. \r\nNow the plan here is to keep the existing partition reassignment and just add the missing broker for e.g.\r\n\r\nmy_topic_1 p0 replicas are [4, 5, 3], and I would like this to be updated to [4, 5, 3, 6]\r\n\r\nmy_topic_2 p0 replicas are [3, 6, 4], and I would like this to be updated to [3, 6, 4, 5]\r\n\r\nmy_topic_2 p0 replicas are [6, 4, 5], and I would like this to be updated to [6, 4, 5, 3]\r\n\r\nSample JSON below.\r\nI have been trying with combination of grep, sed and jq, so that we can just get the replica list for each partition, e.g.\r\n\r\nmy_topic_1 p0 replica list is [4, 5, 3] and compare it with a master list (existing brokers in cluster); [3, 4, 5, 6] and append the missing broker to the partition list,\r\nSo broker 6 is missing from the partition list; hence add 6 so partition list for topic becomes [4, 5, 3, 6]\r\n\r\nAppreciate some suggestions\r\n```\r\n{\r\n\t&quot;version&quot;: 1,\r\n\t&quot;partitions&quot;: [{\r\n\t\t&quot;topic&quot;: &quot;my_topic_1&quot;,\r\n\t\t&quot;partition&quot;: 0,\r\n\t\t&quot;replicas&quot;: [4, 5, 3],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 0,\r\n\t\t&quot;replicas&quot;: [3, 6, 4],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 1,\r\n\t\t&quot;replicas&quot;: [6, 4, 5],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 2,\r\n\t\t&quot;replicas&quot;: [4, 5, 3],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 3,\r\n\t\t&quot;replicas&quot;: [5, 3, 6],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 4,\r\n\t\t&quot;replicas&quot;: [3, 5, 6],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_2&quot;,\r\n\t\t&quot;partition&quot;: 5,\r\n\t\t&quot;replicas&quot;: [6, 3, 4],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 0,\r\n\t\t&quot;replicas&quot;: [4, 6, 5],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 1,\r\n\t\t&quot;replicas&quot;: [5, 4, 3],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 2,\r\n\t\t&quot;replicas&quot;: [3, 5, 6],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 3,\r\n\t\t&quot;replicas&quot;: [6, 3, 4],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 4,\r\n\t\t&quot;replicas&quot;: [4, 6, 5],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}, {\r\n\t\t&quot;topic&quot;: &quot;my_topic_3&quot;,\r\n\t\t&quot;partition&quot;: 5,\r\n\t\t&quot;replicas&quot;: [5, 4, 3],\r\n\t\t&quot;log_dirs&quot;: [&quot;any&quot;, &quot;any&quot;, &quot;any&quot;]\r\n\t}]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/74573067/increase-replication-factor-factor-of-tipics",
        "title": "Increase replication factor factor of tipics"
    },
    {
        "tags": [
            "json",
            "jq",
            "jmespath"
        ],
        "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": 2,
                "creation_date": 1669398349,
                "post_id": 74576298,
                "comment_id": 131639922,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2433008,
                    "reputation": 40025,
                    "user_id": 2123530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/37a7fba006184897e8d74f1795e2835b?s=256&d=identicon&r=PG",
                    "display_name": "β.εηοιτ.βε",
                    "link": "https://stackoverflow.com/users/2123530/%ce%b2-%ce%b5%ce%b7%ce%bf%ce%b9%cf%84-%ce%b2%ce%b5"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669623842,
                "post_id": 74576298,
                "comment_id": 131675662,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669408969,
                "creation_date": 1669408969,
                "answer_id": 74577690,
                "question_id": 74576298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Access the value with `.status.code`:\r\n\r\n```\r\n$ jq &#39;.status.code&#39; &lt;&lt;JSON\r\n{\r\n &quot;kind&quot;:&quot;testObject&quot;,\r\n &quot;spec&quot;:{\r\n },\r\n &quot;status&quot;:{\r\n  &quot;code&quot;:&quot;503&quot;\r\n }\r\n}\r\nJSON\r\n&quot;503&quot;\r\n```\r\n\r\nIf you want your output to be `503` (as compared to `&quot;503&quot;`), use `--raw-output`/`-r`:\r\n\r\n```\r\n$ jq -r &#39;.status.code&#39; &lt;&lt;JSON\r\n{\r\n &quot;kind&quot;:&quot;testObject&quot;,\r\n &quot;spec&quot;:{\r\n },\r\n &quot;status&quot;:{\r\n  &quot;code&quot;:&quot;503&quot;\r\n }\r\n}\r\nJSON\r\n503\r\n```",
                "title": "Parse a value from the json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669432936,
                "creation_date": 1669432936,
                "answer_id": 74579488,
                "question_id": 74576298,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since this question has the [tag:JMESPATH] tag, it is worth pointing out that one could use the JMESPATH command-line tool, jp, as follows:\r\n```\r\njp status.code\r\n```\r\nor to suppress the quotation marks:\r\n```\r\njp -u status.code\r\n```\r\n\r\nSimilarly, using jaq, which has a jq-based syntax, one could write:\r\n\r\n    jaq .status.code\r\n\r\nor to suppress the quotation marks:\r\n\r\n    jaq -r .status.code\r\n\r\n",
                "title": "Parse a value from the json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669623815,
        "creation_date": 1669397998,
        "last_edit_date": 1669623815,
        "question_id": 74576298,
        "body_markdown": "I have a following json\r\n\r\n```json\r\n{\r\n  &quot;kind&quot;:&quot;testObject&quot;,\r\n  &quot;spec&quot;:{\r\n  },\r\n  &quot;status&quot;:{\r\n    &quot;code&quot;:&quot;503&quot;\r\n  }\r\n}\r\n```\r\n\r\nI would like to just retrieve the value of code, so that it would just show `503` as an output. \r\n\r\nI did try with JMESPath, but that binary is out of question, and not sure what to use.",
        "link": "https://stackoverflow.com/questions/74576298/parse-a-value-from-the-json",
        "title": "Parse a value from the json"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq",
            "kubectl"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1669408983,
                "post_id": 74576585,
                "comment_id": 131642135,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1669494307,
                "creation_date": 1669494307,
                "answer_id": 74585371,
                "question_id": 74576585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try\r\n\r\n```\r\nkubectl get secret mysecret -o json | jq --arg secret_base64 &quot;$(echo -n tests | base64)&quot; &#39;.data.test=$secret_base64&#39; | kubectl apply -f -\r\n```\r\n\r\nYou can do it with `kubectl edit secret mysecret` and add a new secret key\r\n```\r\ntest: dGVzdHM= # echo -n tests | base64\r\n```",
                "title": "jq set change to the object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669494307,
        "creation_date": 1669400041,
        "last_edit_date": 1669478428,
        "question_id": 74576585,
        "body_markdown": "I&#39;m trying to update a secret with new key.\r\nThe issue is that when i call again this secret object, it don&#39;t reflect this change.\r\n\r\nI get the secret data:\r\n\r\n    kubectl get secret mysecret --context dev -n dev-test -o jsonpath=\\{$.data\\} | jq\r\n\r\n    {\r\n      &quot;example1&quot;: &quot;Rlc3QuY29taW5hZG1pbn&quot;,\r\n      &quot;example2&quot;: &quot;NYXBiN3c3c1U3NFd&quot;,\r\n      &quot;example3&quot;: &quot;aW5hZG1pbnRlc3QsZGM9Y29tZGM9YWQsZGM9&quot;,\r\n      &quot;example4&quot;: &quot;jMDEuYWQuaW5hZG1pbnRlbGRhcDovL2luYmRc3QuY29tOjMyNjg=&quot;,\r\n      &quot;example5&quot;: &quot;YWxmcmVzY28YWRtaW50ZXN0LmNvbQ==uaW1wb3J0QGlu&quot;\r\n    }\r\n\r\n\r\nI aply the add command with jq :\r\n\r\n    kubectl get secret mysecret --context dev -n dev-test -o jsonpath=\\{$.data\\} | jq &#39; .test = &quot;tests&quot; &#39;\r\n\r\n    {\r\n      &quot;example1&quot;: &quot;Rlc3QuY29taW5hZG1pbn&quot;,\r\n      &quot;example2&quot;: &quot;NYXBiN3c3c1U3NFd&quot;,\r\n      &quot;example3&quot;: &quot;aW5hZG1pbnRlc3QsZGM9Y29tZGM9YWQsZGM9&quot;,\r\n      &quot;example4&quot;: &quot;jMDEuYWQuaW5hZG1pbnRlbGRhcDovL2luYmRc3QuY29tOjMyNjg=&quot;,\r\n      &quot;example5&quot;: &quot;YWxmcmVzY28YWRtaW50ZXN0LmNvbQ==uaW1wb3J0QGlu&quot;,\r\n      &quot;test&quot;: &quot;tests&quot;\r\n    }\r\n\r\nNow, when i call the secret again, the output is like the original and not with the adding key\r\n\r\n    kubectl get secret mysecret --context dev -n dev-test -o jsonpath=\\{$.data\\} | jq\r\n\r\n    {\r\n      &quot;example1&quot;: &quot;Rlc3QuY29taW5hZG1pbn&quot;,\r\n      &quot;example2&quot;: &quot;NYXBiN3c3c1U3NFd&quot;,\r\n      &quot;example3&quot;: &quot;aW5hZG1pbnRlc3QsZGM9Y29tZGM9YWQsZGM9&quot;,\r\n      &quot;example4&quot;: &quot;jMDEuYWQuaW5hZG1pbnRlbGRhcDovL2luYmRc3QuY29tOjMyNjg=&quot;,\r\n      &quot;example5&quot;: &quot;YWxmcmVzY28YWRtaW50ZXN0LmNvbQ==uaW1wb3J0QGlu&quot;\r\n    }\r\n\r\nHow can i set this new key ?\r\nObs: I&#39;m not usin any yaml file.",
        "link": "https://stackoverflow.com/questions/74576585/jq-set-change-to-the-object",
        "title": "jq set change to the object"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1733040,
                    "reputation": 12507,
                    "user_id": 1586221,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/96ab4c67eb62b315a8e7584f7dfd547a?s=256&d=identicon&r=PG",
                    "display_name": "tompave",
                    "link": "https://stackoverflow.com/users/1586221/tompave"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669486939,
                "post_id": 74584586,
                "comment_id": 131653385,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669486937,
                "creation_date": 1669486937,
                "answer_id": 74584626,
                "question_id": 74584586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries` could be one way:\r\n~~~sh\r\n{mods: to_entries | map({name: .key, enabled: .value})}\r\n~~~\r\n[Demo](https://jqplay.org/s/0BpdF06VWCH)\r\n\r\nUsing `keys` or `keys_unsorted` could be another:\r\n~~~sh\r\n{mods: [keys_unsorted[] as $name | {$name, enabled: .[$name]}]}\r\n~~~\r\n[Demo](https://jqplay.org/s/F8A2cxnUDSm)\r\n\r\nOutput:\r\n~~~json\r\n{\r\n  &quot;mods&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;somename&quot;,\r\n      &quot;enabled&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;someothername&quot;,\r\n      &quot;enabled&quot;: false\r\n    }\r\n  ]\r\n}\r\n~~~\r\n",
                "title": "jq: How do I transform an object containing named booleans to an array of `{&quot;name&quot;: &quot;aname&quot;, &quot;enabled&quot;:itsboolean}`s?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1669487553,
        "creation_date": 1669486606,
        "last_edit_date": 1669487553,
        "question_id": 74584586,
        "body_markdown": "I&#39;ve got some json describing plugin states that reads like\r\n\r\n    {\r\n      &quot;mods&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;somename&quot;,\r\n            &quot;enabled&quot;: true\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;someothername&quot;,\r\n            &quot;enabled&quot;: false\r\n        }\r\n      ]\r\n    }\r\n\r\nand I&#39;m attempting to strip the boilerplate out of it for presentation and human editing, then re-insert the boilerplate afterwards.  I&#39;ve got the humanizing transform, that&#39;s pleasingly compact and sensible:\r\n\r\n    jq &#39;[ .mods[]|{(.name): .enabled} ] | add&#39; mod-list.json\r\n\r\n    {\r\n      &quot;somename&quot;: true,\r\n      &quot;someothername&quot;: false\r\n    }\r\n\r\nbut I&#39;m stuck on going the other way: I&#39;m looking to transform the output above back to its input.\r\n\r\nI looked at `keys_unsorted,.[]` but I don&#39;t see how to splice the sequences together and the manual has worrying comments about the keys being &quot;roughly in insertion order&quot;, leaving me to longing for some more explicit guarantee that the keys and values sequences from that construct will at least be in the same order if not the original one.\r\n\r\nI also tried foreach and reduce, and they&#39;re tantalizingly close but (a) they gangbang the keys into an array, and (b) I don&#39;t see how to get the corresponding values:\r\n\r\n    jq &#39;foreach keys as $key ({};{name:$key, enabled:false}&#39;\r\n\r\nSo that&#39;s where I&#39;m stuck.",
        "link": "https://stackoverflow.com/questions/74584586/jq-how-do-i-transform-an-object-containing-named-booleans-to-an-array-of-nam",
        "title": "jq: How do I transform an object containing named booleans to an array of `{&quot;name&quot;: &quot;aname&quot;, &quot;enabled&quot;:itsboolean}`s?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669518054,
                "last_edit_date": 1669518054,
                "creation_date": 1669515903,
                "answer_id": 74587067,
                "question_id": 74587054,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `if`, make one branch provide an empty object `{}` which wouldn&#39;t contain the extra field:\r\n~~~sh\r\nmap({value: .a} + if .a &gt; 1 then {X: &quot;Y&quot;} else {} end)\r\n~~~\r\n[Demo](https://jqplay.org/s/O11MA4l5Azl)\r\n\r\nAlternatively, equip only `select`ed items with the extra field:\r\n~~~sh\r\nmap({value: .a} | select(.value &gt; 1).X = &quot;Y&quot;)\r\n~~~\r\n[Demo](https://jqplay.org/s/1rjolXHjqNQ)\r\n\r\nOutput:\r\n~~~json\r\n[\r\n  {\r\n    &quot;value&quot;: 5,\r\n    &quot;X&quot;: &quot;Y&quot;\r\n  },\r\n  {\r\n    &quot;value&quot;: 1\r\n  }\r\n]\r\n~~~\r\n",
                "title": "Conditionally output a field?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669518054,
        "creation_date": 1669515696,
        "question_id": 74587054,
        "body_markdown": "In this example I only want isGreaterThanOne field to be shown if it&#39;s true. Here&#39;s what I started with (always shown)\r\n\r\n    echo &#39;[{&quot;a&quot;:5},{&quot;a&quot;:1}]&#39; | jq &#39;[.[] | {value:.a, isGreaterThanOne:(.a&gt;1)}]&#39;\r\n\r\nI inserted an if statement\r\n\r\n    echo &#39;[{&quot;a&quot;:5},{&quot;a&quot;:1}]&#39; | jq &#39;[.[] | {value:.a, X:(if .a&gt;1 then &quot;Y&quot; else &quot;N&quot; end) }]&#39;\r\n\r\nThen got stuck trying to move the field into the conditional. Also it seems like I must have an else with an if\r\n\r\n    echo &#39;[{&quot;a&quot;:5},{&quot;a&quot;:1}]&#39; | jq &#39;[.[] | {value:.a, (if .a&gt;1 then (K:&quot;Y)&quot; else (L:&quot;N&quot;) end) }]&#39;\r\n\r\n\r\nI want the below as the result (doesn&#39;t need to be pretty printed)\r\n\r\n\t[\r\n\t{\r\n\t\t&quot;value&quot;: 5,\r\n\t\t&quot;X&quot;: &quot;Y&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;value&quot;: 1,\r\n\t}\r\n\t]",
        "link": "https://stackoverflow.com/questions/74587054/conditionally-output-a-field",
        "title": "Conditionally output a field?"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669527654,
                "creation_date": 1669527654,
                "answer_id": 74587771,
                "question_id": 74587622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When adding arrays, make sure that all parts have brackets:\r\n~~~sh\r\nyq -o csv &#39;\r\n  .ProductLine.ADO_FeedsList[] | [.organizationName] + (\r\n    .Project[] | [.ProjectName] + (.ProjectFeedsName[] | [.])\r\n  )\r\n&#39; test.yaml\r\n~~~\r\n~~~csv\r\nbb,cc,dd\r\nbb,cc,ee\r\nbb,ff,gg\r\nbb,ff,hh\r\n~~~",
                "title": "How to convert the yaml to csv with array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669706648,
                "last_edit_date": 1669706648,
                "creation_date": 1669548168,
                "answer_id": 74589594,
                "question_id": 74587622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could also use gojq, the Go implementation of jq; if you don&#39;t mind the way `@csv` quotes fields, you could consider:\r\n\r\n```\r\ngojq -r --yaml-input &#39;\r\n.ProductLine.ADO_FeedsList[]\r\n| [.organizationName] + \r\n  ( .Project[] | [.ProjectName] + (.ProjectFeedsName[]|[.]) )\r\n| @csv\r\n```\r\n\r\nIf you do mind, then perhaps replacing `@csv` by `| join(&quot;,&quot;)` will suffice.",
                "title": "How to convert the yaml to csv with array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1669706648,
        "creation_date": 1669525267,
        "last_edit_date": 1669535881,
        "question_id": 74587622,
        "body_markdown": "The example:\r\n```\r\nProductLine:\r\n  ProductLineName: aa\r\n  ADO_FeedsList:\r\n    - organizationName: bb\r\n      Project:\r\n        - ProjectName: cc\r\n          ProjectFeedsName: \r\n          - dd\r\n          - ee\r\n        - ProjectName: ff\r\n          ProjectFeedsName:\r\n          - gg\r\n          - hh\r\n  OtherInfo: N/A\r\n```\r\n\r\nI expected the following output:\r\n```\r\nbb,cc,dd\r\nbb,cc,ee\r\nbb,ff,gg\r\nbb,ff,hh\r\n```\r\n\r\nI have tried :\r\n```\r\nyq -o csv &#39;.ProductLine.ADO_FeedsList[] |[.organizationName] + (.Project[]|.ProjectName)&#39; test.yaml\r\n```\r\nIt can output:\r\n```\r\nbb,cc\r\nbb,ff\r\n```\r\n Then i tried:\r\n```\r\nyq -o csv &#39;.ProductLine.ADO_FeedsList[] |[.organizationName] + (.Project[]|.ProjectName) + (.Project[]|.ProjectFeedsName[]|[.])&#39; test.yaml\r\n```\r\nError: !!seq (ProductLine.ADO_FeedsList.0.Project.0.ProjectFeedsName.0) cannot be added to a !!str (ProductLine.ADO_FeedsList.0.Project.0.ProjectName)\r\n\r\nHow to write the ProjectFeedsName array command?\r\n\r\nI am a yq new user,could you share the method to format this yaml ?\r\nOr is there any other way to format this yaml to csv?",
        "link": "https://stackoverflow.com/questions/74587622/how-to-convert-the-yaml-to-csv-with-array",
        "title": "How to convert the yaml to csv with array?"
    },
    {
        "tags": [
            "json",
            "regex",
            "amazon-web-services",
            "jq",
            "amazon-ecr"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669590045,
                "last_edit_date": 1669590045,
                "creation_date": 1669559875,
                "answer_id": 74590909,
                "question_id": 74590808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems you want s.t. like:\r\n```\r\njq &#39;.imageDetails[] \r\n  | {tag: .imageTags, sha: .imageDigest, date_pushed: .imagePushedAt} \r\n  | select( any(.tag[]; test(&quot;prod-build&quot;)?))\r\n  | .tag |= map(select(test(&quot;^[^-]+$&quot;)? ))&#39;\r\n```\r\n\r\nYou will have to tweak this if you want to avoid selecting any objects for which .tag would otherwise be the empty array.",
                "title": "jq regex test() selecting unexpected values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669565930,
                "creation_date": 1669565930,
                "answer_id": 74591704,
                "question_id": 74590808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a variant using `contains` for both checks, with the second one negated using `not`:\r\n~~~sh\r\njq &#39;.imageDetails[] | select(.imageTags | any(contains(&quot;prod-build&quot;))) | {\r\n  tag: .imageTags | map(select(contains(&quot;-&quot;) | not)),\r\n  sha: .imageDigest,\r\n  date_pushed: .imagePushedAt\r\n}&#39;\r\n~~~\r\n~~~json\r\n{\r\n  &quot;tag&quot;: [\r\n    &quot;6debaabc26cc82a4011ea9c71854cebac7a57250&quot;\r\n  ],\r\n  &quot;sha&quot;: &quot;sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b&quot;,\r\n  &quot;date_pushed&quot;: &quot;2020-12-21T03:11:52-05:00&quot;\r\n}\r\n~~~\r\n[Demo](https://jqplay.org/s/7by82OiuQL3)",
                "title": "jq regex test() selecting unexpected values"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669569323,
                "creation_date": 1669569323,
                "answer_id": 74592148,
                "question_id": 74590808,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `del` to delete all tags that match a certain criterion:\r\n\r\n```\r\n.imageDetails[]\r\n| {\r\n    tag: .imageTags,\r\n    sha: .imageDigest,\r\n    date_pushed: .imagePushedAt\r\n}\r\n| select(.tag | contains([&quot;prod-build&quot;]))\r\n| del(.tag[] | select(contains(&quot;-&quot;)))\r\n```\r\n\r\nFirst selects those objects with a &quot;prod-build&quot; tag and then deletes all other tags from the list.\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;tag&quot;: [\r\n    &quot;6debaabc26cc82a4011ea9c71854cebac7a57250&quot;\r\n  ],\r\n  &quot;sha&quot;: &quot;sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b&quot;,\r\n  &quot;date_pushed&quot;: &quot;2020-12-21T03:11:52-05:00&quot;\r\n}\r\n```",
                "title": "jq regex test() selecting unexpected values"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1669590045,
        "creation_date": 1669559030,
        "question_id": 74590808,
        "body_markdown": "I am trying to parse the JSON from `aws ecr describe-images`, and return a result with a specific image tag, matching a pattern, from the list. In particular I get an array with many of these entries:\r\n\r\n```json\r\n{\r\n  &quot;imageDetails&quot;: [\r\n    {\r\n      &quot;registryId&quot;: &quot;997652729005&quot;,\r\n      &quot;repositoryName&quot;: &quot;events&quot;,\r\n      &quot;imageDigest&quot;: &quot;sha256:5b649219a3abc5e903b27fd947f375df8634c883432a69e40d245ac2393d67b2&quot;,\r\n      &quot;imageTags&quot;: [\r\n        &quot;events-test-build-340&quot;\r\n      ],\r\n      &quot;imageSizeInBytes&quot;: 314454408,\r\n      &quot;imagePushedAt&quot;: &quot;2021-01-12T10:42:51-05:00&quot;,\r\n      &quot;imageScanStatus&quot;: {\r\n        &quot;status&quot;: &quot;COMPLETE&quot;,\r\n        &quot;description&quot;: &quot;The scan was completed successfully.&quot;\r\n      },\r\n      &quot;imageScanFindingsSummary&quot;: {\r\n        &quot;imageScanCompletedAt&quot;: &quot;2021-01-12T10:43:00-05:00&quot;,\r\n        &quot;vulnerabilitySourceUpdatedAt&quot;: &quot;2021-01-12T04:45:25-05:00&quot;,\r\n        &quot;findingSeverityCounts&quot;: {}\r\n      },\r\n      &quot;imageManifestMediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n      &quot;artifactMediaType&quot;: &quot;application/vnd.docker.container.image.v1+json&quot;\r\n    },\r\n    {\r\n      &quot;registryId&quot;: &quot;997652729005&quot;,\r\n      &quot;repositoryName&quot;: &quot;events&quot;,\r\n      &quot;imageDigest&quot;: &quot;sha256:0fae259bcfe02c8cf0ec3746aae668b3166960e7119467496df9aedfbc2c8c5b&quot;,\r\n      &quot;imageTags&quot;: [\r\n        &quot;6debaabc26cc82a4011ea9c71854cebac7a57250-433&quot;,\r\n        &quot;6debaabc26cc82a4011ea9c71854cebac7a57250&quot;,\r\n        &quot;6debaabc26cc82a4011ea9c71854cebac7a57250-433-dev&quot;,\r\n        &quot;events-prod-build-433&quot;\r\n      ],\r\n      &quot;imageSizeInBytes&quot;: 316110570,\r\n      &quot;imagePushedAt&quot;: &quot;2020-12-21T03:11:52-05:00&quot;,\r\n      &quot;imageScanStatus&quot;: {\r\n        &quot;status&quot;: &quot;COMPLETE&quot;,\r\n        &quot;description&quot;: &quot;The scan was completed successfully.&quot;\r\n      },\r\n      &quot;imageScanFindingsSummary&quot;: {\r\n        &quot;imageScanCompletedAt&quot;: &quot;2020-12-21T03:12:02-05:00&quot;,\r\n        &quot;vulnerabilitySourceUpdatedAt&quot;: &quot;2020-11-03T20:21:09-05:00&quot;,\r\n        &quot;findingSeverityCounts&quot;: {}\r\n      },\r\n      &quot;imageManifestMediaType&quot;: &quot;application/vnd.docker.distribution.manifest.v2+json&quot;,\r\n      &quot;artifactMediaType&quot;: &quot;application/vnd.docker.container.image.v1+json&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like the output to be something like this:\r\n\r\n```json\r\n{\r\n  &quot;tag&quot;: [\r\n    &quot;6debaabc26cc82a4011ea9c71854cebac7a57250&quot;\r\n  ],\r\n  &quot;sha&quot;: &quot;sha256:5b649219a3abc5e903b27fd947f375df8634c883432a69e40d245ac2393d67b2&quot;,\r\n  &quot;imagePushedAt&quot;: &quot;2021-01-12T10:42:51-05:00&quot;\r\n}\r\n```\r\n\r\nThe challenge is to pick the images that have a tag whose name includes **`*prod-build*`** (a deployed production build), but then return a the tag having **no dashes** in it, which is the tag we actually use.  (Yes, this is entirely defective, I know).\r\n\r\nI have gotten pretty far:\r\n\r\n```shell\r\ncat ecr-describe-images-events.json \r\n  | jq &#39;.imageDetails[] \r\n  | {tag: .imageTags, sha: .imageDigest, date_pushed: .imagePushedAt} \r\n  | select( .tag | contains([&quot;prod-build&quot;])) \r\n  .tag[] |= walk(\r\n    if type==&quot;string&quot; then \r\n      select(\r\n        match(&quot;^[^-]+$&quot;)\r\n      ) \r\n    else \r\n      null \r\n    end\r\n  )&#39;\r\n```\r\n\r\nSo, from the `imageDetails` array, get and name elements, then from the array of tags select the nodes that have a tag with the string `prod-build`. From these nodes, find the  \r\n`tags` array element whose name does not include dashes, and return that.\r\n\r\nThe last part, which I have done with `select`, `walk`, and `match` is behaving differently than I expect.  I am getting:\r\n\r\n```json\r\n{\r\n  &quot;tag&quot;: [\r\n    &quot;events-test-build-340&quot;\r\n  ],\r\n  &quot;sha&quot;: &quot;sha256:5b649219a3abc5e903b27fd947f375df8634c883432a69e40d245ac2393d67b2&quot;,\r\n  &quot;date_pushed&quot;: &quot;2021-01-12T10:42:51-05:00&quot;\r\n}\r\n{\r\n  &quot;tag&quot;: [\r\n    &quot;6debaabc26cc82a4011ea9c71854cebac7a57250&quot;,\r\n    &quot;events-prod-build-433&quot;,\r\n    null,\r\n    null\r\n  ],\r\n  &quot;sha&quot;: &quot;sha256:8638389b7d83869b17b1c74ff30740d7cf8eff4574100c1270f20d4686252552&quot;,\r\n  &quot;date_pushed&quot;: &quot;2021-02-17T13:11:42-05:00&quot;\r\n}\r\n```\r\n\r\nIf I don&#39;t include the last part, starting `walk(...)` I get the correct nodes.  But when I do use `walk` with match or test, I get back array elements that don&#39;t match my regexp.\r\n\r\nI am not fixed on my approach, or on the output format: I just need the three fields in some structure. What have I failed to understand?\r\n    \r\n",
        "link": "https://stackoverflow.com/questions/74590808/jq-regex-test-selecting-unexpected-values",
        "title": "jq regex test() selecting unexpected values"
    },
    {
        "tags": [
            "jq",
            "aws-cli",
            "amazon-cloudtrail"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1669565056,
                "creation_date": 1669565056,
                "answer_id": 74591590,
                "question_id": 74591535,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t give any conditions how to select the nodes, or how to format your output. So, how about just traversing to their locations. With the `--raw-output` (or `-r`) option, jq will output their decoded values. Making it a stream in the filter (by separating them with commas `,`) will make it a newline-separated list in the output.\r\n~~~sh\r\njq --raw-output &#39;\r\n  .userIdentity.sessionContext.attributes.mfaAuthenticated,\r\n  .eventSource,\r\n  .eventType\r\n&#39;\r\n~~~\r\n~~~\r\nfalse\r\nsignin.amazonaws.com\r\nAwsConsoleSignIn\r\n~~~",
                "title": "Extract key values from CloudTrail Lookup-Events from AWS-CLI using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669565056,
        "creation_date": 1669564675,
        "question_id": 74591535,
        "body_markdown": "i ran the command to get the lookup-events for ConsoleLogin activities in AWS Account.I want to extract the key values for mfaAuthenticated , eventSource and eventType from this given json output\r\n\r\n\r\n\r\nThe output i got from the above command \r\n```\r\n{\r\n  &quot;eventVersion&quot;: &quot;1.08&quot;,\r\n  &quot;userIdentity&quot;: {\r\n    &quot;type&quot;: &quot;AssumedRole&quot;,\r\n    &quot;principalId&quot;: &quot;XXXXXXXXXXXXXXXXX:dkboss&quot;,\r\n    &quot;arn&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXX/dkboss&quot;,\r\n    &quot;accountId&quot;: &quot;XXXXXXXXXXXXXXXX&quot;,\r\n    &quot;sessionContext&quot;: {\r\n      &quot;sessionIssuer&quot;: {\r\n        &quot;type&quot;: &quot;Role&quot;,\r\n        &quot;principalId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;arn&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;accountId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;userName&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;\r\n      },\r\n      &quot;webIdFederationData&quot;: {},\r\n      &quot;attributes&quot;: {\r\n        &quot;creationDate&quot;: &quot;2022-11-27T15:24:28Z&quot;,\r\n        &quot;mfaAuthenticated&quot;: &quot;false&quot;             ---------&gt; i want this key value\r\n      }\r\n    }\r\n  },\r\n  &quot;eventTime&quot;: &quot;2022-11-27T15:24:29Z&quot;,\r\n  &quot;eventSource&quot;: &quot;signin.amazonaws.com&quot;, ---------&gt; i want this key value\r\n  &quot;eventName&quot;: &quot;ConsoleLogin&quot;,\r\n  &quot;awsRegion&quot;: &quot;us-east-1&quot;,\r\n  &quot;sourceIPAddress&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;userAgent&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;requestParameters&quot;: null,\r\n  &quot;responseElements&quot;: {\r\n    &quot;ConsoleLogin&quot;: &quot;Success&quot;\r\n  },\r\n  &quot;additionalEventData&quot;: {\r\n    &quot;MobileVersion&quot;: &quot;No&quot;,\r\n    &quot;MFAUsed&quot;: &quot;No&quot;\r\n  },\r\n  &quot;eventID&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;readOnly&quot;: false,\r\n  &quot;eventType&quot;: &quot;AwsConsoleSignIn&quot;,      ---------&gt; i want this key value\r\n  &quot;managementEvent&quot;: true,\r\n  &quot;recipientAccountId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;eventCategory&quot;: &quot;Management&quot;,\r\n  &quot;tlsDetails&quot;: {\r\n    &quot;tlsVersion&quot;: &quot;TLSv1.2&quot;,\r\n    &quot;cipherSuite&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n    &quot;clientProvidedHostHeader&quot;: &quot;signin.aws.amazon.com&quot;\r\n  }\r\n}\r\n```\r\n\r\n\r\nI ran this command  to get the above json output : \r\n\r\naws cloudtrail --region us-east-1  lookup-events --lookup-attributes AttributeKey=EventName,AttributeValue=ConsoleLogin   --start-time $(date -d &quot;-60 minutes&quot; +%s)  --query &#39;Events[].CloudTrailEvent.attributes&#39; --output text  | jq",
        "link": "https://stackoverflow.com/questions/74591535/extract-key-values-from-cloudtrail-lookup-events-from-aws-cli-using-jq",
        "title": "Extract key values from CloudTrail Lookup-Events from AWS-CLI using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669611807,
                "creation_date": 1669611807,
                "answer_id": 74596192,
                "question_id": 74595941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do it:\r\n```\r\nwith_entries(\r\n    .key as $key\r\n    | .value |= map(\r\n         {parent: $key,\r\n          key: ($key + (tostring)), \r\n          value: .}) )\r\n```",
                "title": "jq - Iterate over objects, add key to each item of array in value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1669611807,
        "creation_date": 1669609321,
        "question_id": 74595941,
        "body_markdown": "New to jq here. \r\n\r\nI just want to ask how to add the key of an object to each item of its value and convert it to an array of objects instead. I have the following JSON format:\r\n\r\n```\r\n{\r\n\t&quot;key1&quot; : [\r\n\t\t&quot;key1item1&quot;,\r\n\t\t&quot;key1item2&quot;,\r\n\t\t&quot;key1item3&quot;,\r\n\t\t&quot;key1item4&quot;,\r\n\t\t...\r\n\t],\r\n\t&quot;key2&quot; : [\r\n\t\t&quot;key2item1&quot;,\r\n\t\t&quot;key2item2&quot;,\r\n\t\t...\r\n\t]\r\n}\r\n```\r\n\r\nWhat I want to achieve is this:\r\n\r\n```\r\n{\r\n\t&quot;key1&quot; : [\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key1&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key1_key1item1&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key1_item1&#39;,\r\n\t\t},\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key1&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key1_key1item2&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key1_item2&#39;,\r\n\t\t}\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key1&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key1_key1item3&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key1_item3&#39;,\r\n\t\t}\r\n\t],\r\n\t&quot;key2&quot; : [\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key2&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key2_key2item1&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key2_item1&#39;,\r\n\t\t},\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key2&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key2_key2item2&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key2_item2&#39;,\r\n\t\t}\r\n\t\t{\r\n\t\t\t&#39;parent&#39;: &#39;key2&#39;,\r\n\t\t\t&#39;key&#39;: &#39;key2_key2item3&#39;,\r\n\t\t\t&#39;value&#39;: &#39;key2_item3&#39;,\r\n\t\t}\r\n\t]\r\n```",
        "link": "https://stackoverflow.com/questions/74595941/jq-iterate-over-objects-add-key-to-each-item-of-array-in-value",
        "title": "jq - Iterate over objects, add key to each item of array in value"
    },
    {
        "tags": [
            "jq",
            "aws-cdk",
            "amazon-kinesis-firehose"
        ],
        "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": 0,
                "creation_date": 1669648855,
                "post_id": 74602745,
                "comment_id": 131684072,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669656961,
                "creation_date": 1669656961,
                "answer_id": 74604443,
                "question_id": 74602745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have to group your expression with parentheses:\r\n\r\n```\r\n{\r\n    tlsDetais : .tlsDetails.tlsVersion,\r\n    OptionalKey : (.OptionalKey // &quot;undefined&quot;)\r\n}\r\n```",
                "title": "Extracting an optional field or default value in AWS ProcessingConfigurationProperty field"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669656961,
        "creation_date": 1669648710,
        "question_id": 74602745,
        "body_markdown": "I am working with AWS kinesis stream to create prefix for delivery output (S3), I chose JQ as parser and one of the prefix key is optional and I tried alternative option provided by jq but it is giving me an error. I have attached random AWS cloudtrail and the code snippet.\r\n\r\n`\r\n```\r\n{\r\n  &quot;eventVersion&quot;: &quot;1.08&quot;,\r\n  &quot;OptionalKey&quot;: &quot;Optional&quot; ---&gt; I want to get the optional field and if it does not exist return &quot;undefined&quot;\r\n  &quot;userIdentity&quot;: {\r\n    &quot;type&quot;: &quot;AssumedRole&quot;,\r\n    &quot;principalId&quot;: &quot;XXXXXXXXXXXXXXXXX:dkboss&quot;,\r\n    &quot;arn&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXX/dkboss&quot;,\r\n    &quot;accountId&quot;: &quot;XXXXXXXXXXXXXXXX&quot;,\r\n    &quot;sessionContext&quot;: {\r\n      &quot;sessionIssuer&quot;: {\r\n        &quot;type&quot;: &quot;Role&quot;,\r\n        &quot;principalId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;arn&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;accountId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n        &quot;userName&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;\r\n      },\r\n      &quot;webIdFederationData&quot;: {},\r\n      &quot;attributes&quot;: {\r\n        &quot;creationDate&quot;: &quot;2022-11-27T15:24:28Z&quot;,\r\n        &quot;mfaAuthenticated&quot;: &quot;false&quot;            }\r\n    }\r\n  },\r\n  &quot;eventTime&quot;: &quot;2022-11-27T15:24:29Z&quot;,\r\n  &quot;eventSource&quot;: &quot;signin.amazonaws.com&quot;, \r\n  &quot;eventName&quot;: &quot;ConsoleLogin&quot;,\r\n  &quot;awsRegion&quot;: &quot;us-east-1&quot;,\r\n  &quot;sourceIPAddress&quot;: &quot;1.1.1.1&quot;,\r\n  &quot;userAgent&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;requestParameters&quot;: null,\r\n  &quot;responseElements&quot;: {\r\n    &quot;ConsoleLogin&quot;: &quot;Success&quot;\r\n  },\r\n  &quot;additionalEventData&quot;: {\r\n    &quot;MobileVersion&quot;: &quot;No&quot;,\r\n    &quot;MFAUsed&quot;: &quot;No&quot;\r\n  },\r\n  &quot;eventID&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;readOnly&quot;: false,\r\n  &quot;eventType&quot;: &quot;AwsConsoleSignIn&quot;,      \r\n  &quot;managementEvent&quot;: true,\r\n  &quot;recipientAccountId&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n  &quot;eventCategory&quot;: &quot;Management&quot;,\r\n  &quot;tlsDetails&quot;: {\r\n    &quot;tlsVersion&quot;: &quot;TLSv1.2&quot;,\r\n    &quot;cipherSuite&quot;: &quot;XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX&quot;,\r\n    &quot;clientProvidedHostHeader&quot;: &quot;signin.aws.amazon.com&quot;\r\n  }\r\n}\r\n```\r\n`\r\nI want to get build S3 prefix, but I couldn&#39;t figure out how optional values are supported. \r\n\r\n\r\n\r\n\r\n`\r\n```\r\n\r\n\r\n CfnDeliveryStream.ProcessorParameterProperty(\r\n                            parameter_name=&quot;MetadataExtractionQuery&quot;,\r\n                            parameter_value=&quot;{&quot;\r\n                            &quot;tlsDetais : .tlsDetails.tlsVersion,&quot;\r\n                            &#39;OptionalKey : .OptionalKey // &quot;undefined&quot;,&#39;\r\n&quot;}&quot;\r\n```\r\n` \r\nInside ProcessorParameterProperty, But it failed with the following error:\r\n\r\n```\r\nJQ Subprocess failed due to: jq: error: syntax error, unexpected //, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, \r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/74602745/extracting-an-optional-field-or-default-value-in-aws-processingconfigurationprop",
        "title": "Extracting an optional field or default value in AWS ProcessingConfigurationProperty field"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1669656846,
                "last_edit_date": 1669656846,
                "creation_date": 1669656621,
                "answer_id": 74604379,
                "question_id": 74604351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use\r\n```\r\njq -r &#39;.[][].name&#39; mydata.json\r\n```\r\nalong with `Raw Output` option to get rid of wrapper quotes\r\n\r\n&lt;kbd&gt;[Online Demo](https://jqplay.org/s/YK2L5Q-_6b3)&lt;/kbd&gt;",
                "title": "Get values from under different keys in JSON with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669711173,
                "creation_date": 1669711173,
                "answer_id": 74611196,
                "question_id": 74604351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might also wish to consider:\r\n\r\n    jq -r &#39;..|.name?&#39; mydata.json\r\n\r\n",
                "title": "Get values from under different keys in JSON with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669711173,
        "creation_date": 1669656475,
        "last_edit_date": 1669702118,
        "question_id": 74604351,
        "body_markdown": "When I have an following JSON,\r\n```json\r\n{\r\n  &quot;group1&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;name_AAA&quot;,\r\n      &quot;size&quot;: 1\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;name_BBB&quot;,\r\n      &quot;size&quot;: 2\r\n    }\r\n  ],\r\n  &quot;group2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;name_CCC&quot;,\r\n      &quot;size&quot;: 3\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;name_DDD&quot;,\r\n      &quot;size&quot;: 4\r\n    }\r\n  ]\r\n}\r\n```\r\nI want to get following values with `jq` command.\r\n```\r\nname_AAA\r\nname_BBB\r\nname_CCC\r\nname_DDD\r\n```\r\nI tried following but returned unexpected value.\r\n```terminal\r\n$ jq -r &#39;.group1[] * .group2[] | .name&#39; &lt; &quot;mydata.json&quot;\r\nname_CCC\r\nname_CCC\r\nname_DDD\r\nname_DDD\r\n```\r\n\r\nHow can I get value which I wanted??\r\n",
        "link": "https://stackoverflow.com/questions/74604351/get-values-from-under-different-keys-in-json-with-jq",
        "title": "Get values from under different keys in JSON with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669657951,
                "post_id": 74604480,
                "comment_id": 131687408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1669659432,
                "last_edit_date": 1669659432,
                "creation_date": 1669657575,
                "answer_id": 74604556,
                "question_id": 74604480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` which will use the array&#39;s index as key:\r\n\r\n```\r\n.median as $median\r\n| .values\r\n| to_entries[]\r\n| &quot;At \\(.key+1) it is \\(if .value &gt;= $median then &quot;expensive&quot; else &quot;cheap&quot; end)&quot;\r\n```\r\n\r\nYou could also modify key and value before interpolating the string:\r\n\r\n```\r\n.median as $median\r\n| .values\r\n| to_entries[]\r\n| .key += 1\r\n| .value |= if . &gt;= $median then &quot;expensive&quot; else &quot;cheap&quot; end\r\n| &quot;At \\(.key) it is \\(.value)&quot;\r\n```\r\n\r\n***\r\n\r\nI doubt that your data starts at 01:00 and ends at 00:00 (24:00), but if it did, here&#39;s how you would format it:\r\n\r\n```\r\n.median as $median\r\n| .values\r\n| to_entries[]\r\n| .ampm = if (.key+1)%24 &gt;= 12 then &quot;pm&quot; else &quot;am&quot; end\r\n| .key %= 12\r\n| .key += 1\r\n| .value |= if . &gt;= $median then &quot;expensive&quot; else &quot;cheap&quot; end\r\n| &quot;At \\(.key)\\(.ampm) it is \\(.value)&quot;\r\n```\r\n\r\nBut I would assume at starts at 00:00 and ends at 23:00, which makes the code a lot simpler.\r\n\r\nOutput when running with `jq -r` (`--raw-output`):\r\n\r\n```\r\nAt 1am it is cheap\r\nAt 2am it is cheap\r\nAt 3am it is cheap\r\nAt 4am it is cheap\r\nAt 5am it is cheap\r\nAt 6am it is cheap\r\nAt 7am it is cheap\r\nAt 8am it is cheap\r\nAt 9am it is cheap\r\nAt 10am it is cheap\r\nAt 11am it is cheap\r\nAt 12pm it is cheap\r\nAt 1pm it is expensive\r\nAt 2pm it is expensive\r\nAt 3pm it is expensive\r\nAt 4pm it is expensive\r\nAt 5pm it is expensive\r\nAt 6pm it is expensive\r\nAt 7pm it is expensive\r\nAt 8pm it is expensive\r\nAt 9pm it is expensive\r\nAt 10pm it is expensive\r\nAt 11pm it is expensive\r\nAt 12am it is expensive\r\n```",
                "title": "Check values in JSON file array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1669658447,
                "creation_date": 1669658447,
                "answer_id": 74604711,
                "question_id": 74604480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way (assuming the first entry corresponds to 12am):\r\n~~~sh\r\n(.values | to_entries)[] as {$key, $value}\r\n| &quot;At \\($key * 3600 | strftime(&quot;%l %P&quot;)) it is \\(\r\n    if $value &lt; .median then &quot;cheap&quot; else &quot;expensive&quot; end\r\n  )&quot;\r\n~~~\r\n~~~\r\nAt 12 am it is cheap\r\nAt  1 am it is cheap\r\nAt  2 am it is cheap\r\nAt  3 am it is cheap\r\nAt  4 am it is cheap\r\nAt  5 am it is cheap\r\nAt  6 am it is cheap\r\nAt  7 am it is cheap\r\nAt  8 am it is cheap\r\nAt  9 am it is cheap\r\nAt 10 am it is cheap\r\nAt 11 am it is cheap\r\nAt 12 pm it is expensive\r\nAt  1 pm it is expensive\r\nAt  2 pm it is expensive\r\nAt  3 pm it is expensive\r\nAt  4 pm it is expensive\r\nAt  5 pm it is expensive\r\nAt  6 pm it is expensive\r\nAt  7 pm it is expensive\r\nAt  8 pm it is expensive\r\nAt  9 pm it is expensive\r\nAt 10 pm it is expensive\r\nAt 11 pm it is expensive\r\n~~~\r\n[Demo](https://jqplay.org/s/KKAgQ3q5k1a)",
                "title": "Check values in JSON file array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1669659432,
        "creation_date": 1669657151,
        "question_id": 74604480,
        "body_markdown": "I&#39;m a beginner and I&#39;m trying to make a bash script that downloads data from a website and tells me hourly prices of a service and tells me when it is cheap and when it is expensive.\r\n\r\n\r\n```\r\ncurl -s https://something.json | jq &#39;.tomorrow[] | select(.region==&quot;region3&quot;) | {values, median}&#39;\r\n```\r\n\r\nFrom that command I get this:\r\n\r\n\r\n```\r\n{\r\n  &quot;values&quot;: [\r\n    71.65,\r\n    70.76,\r\n    70.63,\r\n    71.43,\r\n    73.47,\r\n    84.35,\r\n    88.18,\r\n    97.98,\r\n    112.65,\r\n    155.36,\r\n    155.32,\r\n    207.12,\r\n    252.48,\r\n    311.12,\r\n    350.38,\r\n    452.02,\r\n    461.86,\r\n    503.09,\r\n    487.77,\r\n    465.18,\r\n    401.17,\r\n    335.88,\r\n    298.53,\r\n    255.61\r\n  ],\r\n  &quot;median&quot;: 243.08\r\n}\r\n```\r\n\r\n\r\nand I want to check each value compared to the median and print out something like \r\n\r\n```\r\nAt 1am it is cheap\r\n...\r\nAt 5pm it is expensive\r\n...\r\nAt 11pm it is cheap\r\n...\r\n```\r\n\r\nI tried this, but it didn&#39;t work\r\n\r\n```\r\ncurl -s https://something.json | jq &#39;.tomorrow[] | select(.region==&quot;region3&quot;) | {values, median} | if .values &gt;= .median then &quot;Expensive&quot; elif .values &lt;= .median then &quot;Cheap&quot;&#39;\r\n```\r\n\r\nI thought about using walk() aswell but couldn&#39;t quite figure it out.",
        "link": "https://stackoverflow.com/questions/74604480/check-values-in-json-file-array-using-jq",
        "title": "Check values in JSON file array using jq"
    },
    {
        "tags": [
            "jq",
            "rdap"
        ],
        "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": 0,
                "creation_date": 1669727189,
                "post_id": 74613915,
                "comment_id": 131704186,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 259315,
                    "reputation": 528,
                    "user_id": 542112,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/54f829b188cd1c48a431f636ec4740ea?s=256&d=identicon&r=PG",
                    "display_name": "mjf",
                    "link": "https://stackoverflow.com/users/542112/mjf"
                },
                "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": 1669728315,
                "post_id": 74613915,
                "comment_id": 131704622,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 259315,
                    "reputation": 528,
                    "user_id": 542112,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/54f829b188cd1c48a431f636ec4740ea?s=256&d=identicon&r=PG",
                    "display_name": "mjf",
                    "link": "https://stackoverflow.com/users/542112/mjf"
                },
                "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": 1669728792,
                "post_id": 74613915,
                "comment_id": 131704788,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1669729527,
                "creation_date": 1669729527,
                "answer_id": 74615083,
                "question_id": 74613915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.entities[].entities[] | select(.roles | index(&quot;abuse&quot;)).vcardArray[1][] | select(.[0] == &quot;email&quot;) | last\r\n```\r\n\r\nWill output `&quot;network-abuse@google.com&quot;` since:\r\n\r\n* We loop over all the `.entities[].entities[]`\r\n* Select those where `.roles` includes an index with the value `abuse`\r\n* Get the fields from the vcardArray: `.vcardArray[1]`\r\n* Select those where the first index `.[0]` matches `email`\r\n* Take the last value of that array\r\n\r\n\r\n----------\r\n\r\n\r\n### [Try it online](https://jqplay.org/s/bzINtT-5EGI)",
                "title": "How to get the abuse contact email from RDAP JSON using jq(1)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1669729527,
        "creation_date": 1669724014,
        "last_edit_date": 1669725170,
        "question_id": 74613915,
        "body_markdown": "Having a RDAP JSON similar to [this one](https://rdap.arin.net/registry/ip/8.8.8.8),\r\nhow do I get the abuse email address(es) (the `vCardArray` entry/entries with the [role](https://www.rfc-editor.org/rfc/rfc7483#section-10.2.4) set to &quot;abuse&quot;, if there is any) using `jq(1)`? Thank you.\r\n\r\nP.S.: Of course I tried myself but I failed completely to get what I need from the JSON. (I am mostly used to use `jq(1)` only as a pretty-printer for JSON. This is the second time I try to do something more complex than just `jq &lt; ugly.json` with it, because I need to parse JSON very rarely in practice.)",
        "link": "https://stackoverflow.com/questions/74613915/how-to-get-the-abuse-contact-email-from-rdap-json-using-jq1",
        "title": "How to get the abuse contact email from RDAP JSON using jq(1)?"
    },
    {
        "tags": [
            "amazon-web-services",
            "amazon-dynamodb",
            "jq",
            "aws-cli",
            "dynamodb-queries"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7392763,
                    "reputation": 3737,
                    "user_id": 5625696,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://graph.facebook.com/1157900344239720/picture?type=large",
                    "display_name": "Borislav Stoilov",
                    "link": "https://stackoverflow.com/users/5625696/borislav-stoilov"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669734382,
                "post_id": 74615824,
                "comment_id": 131706964,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22071747,
                    "reputation": 2260,
                    "user_id": 16332641,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0e75ca2c0b0cb923cc89e663ed443d6d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jpseng",
                    "link": "https://stackoverflow.com/users/16332641/jpseng"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1669735571,
                "post_id": 74615824,
                "comment_id": 131707452,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1669737515,
                "creation_date": 1669737515,
                "answer_id": 74616835,
                "question_id": 74615824,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe that is a query that I wrote previously that does not work on nested attributes. You will have to modify it accordingly. \r\n",
                "title": "AWS CLI - Extracting the result of a dynamodb query to csv file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1669737515,
        "creation_date": 1669733117,
        "question_id": 74615824,
        "body_markdown": "I&#39;m having an error when I run a command to extract data to a csv file, using the AWS CLI with jq.&lt;br&gt;\r\n\r\nCommand:&lt;br&gt;\r\n`aws dynamodb scan --table-name MyTable --select ALL_ATTRIBUTES --page-size 500 --max-items 100000 --output json --profile production | jq -r &#39;.Items&#39; | jq -r &#39;(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ].S])[] | @csv&#39; &gt; export.my-table.csv`\r\n\r\nError:&lt;br&gt;\r\n`&#39;charmap&#39; codec can&#39;t encode characters in position 1-3: character maps to &lt;undefined&gt;\r\nparse error: Unfinished JSON term at EOF at line 5097, column 21`\r\n",
        "link": "https://stackoverflow.com/questions/74615824/aws-cli-extracting-the-result-of-a-dynamodb-query-to-csv-file",
        "title": "AWS CLI - Extracting the result of a dynamodb query to csv file"
    }
]