[
    {
        "tags": [
            "json",
            "csv",
            "select",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700363522,
                "creation_date": 1700363522,
                "answer_id": 77509488,
                "question_id": 77509326,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were quite close.  Here we use `first` to obtain the first url that meets the condition, on the assumption that there is at least one:\r\n```\r\n.MediaContainer.Metadata[]\r\n| [.Key, first(.Image[].url | select(test(&quot;fanart&quot;) ) ) ]\r\n| @tsv\r\n```\r\n\r\nThe above might still be acceptable if no .url satisfies the selection criterion, but if not, it should be easy to add your tweak.",
                "title": "Selecting the first item with a matching term in an array using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1700366907,
        "creation_date": 1700358914,
        "last_edit_date": 1700366907,
        "question_id": 77509326,
        "body_markdown": "I have the following JSON format:\r\n```\r\n    &quot;MediaContainer&quot;: {\r\n        &quot;Metadata&quot;: [\r\n            {\r\n                &quot;Key&quot;: &quot;5d77682c151a60001f24bbe8&quot;,\r\n                &quot;Image&quot;: [\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;background&quot;,\r\n                        &quot;url&quot;: &quot;https://image.tmdb.org/t/p/original/f8Q3Sug5Sa42psw2b3Gdd1aT8t.jpg&quot;\r\n                    },\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;clearLogoWide&quot;,\r\n                        &quot;url&quot;: &quot;http://assets.fanart.tv/fanart/movies/2639/hdmovielogo/deconstructing-harry-60f13837ee6aa.png&quot;\r\n                    },\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;coverArt&quot;,\r\n                        &quot;url&quot;: &quot;https://metadata-static.imdb.com/4/gracenote/44a1852151a726d730c214b97986c27e.jpg&quot;\r\n                    },\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;coverPoster&quot;,\r\n                        &quot;url&quot;: &quot;https://image.tmdb.org/t/p/original/i7Z5DdznqANJUjqWISEFu9bw6J7.jpg&quot;\r\n                    },\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;coverSquare&quot;,\r\n                        &quot;url&quot;: &quot;https://metadata-static.imdb.com/c/gracenote/c8c351b348baf43a909e4a3b1c60a443.jpg&quot;\r\n                    },\r\n                    {\r\n                        &quot;alt&quot;: &quot;image&quot;,\r\n                        &quot;type&quot;: &quot;snapshot&quot;,\r\n                        &quot;url&quot;: &quot;https://metadata-static.imdb.com/a/gracenote/ab5a905958de8d43c763d74153242690.jpg&quot;\r\n                    }\r\n                ],\r\n            },\r\n\r\n```\r\n\r\nI am trying to output TSV where each line contains the &quot;Key&quot; and the first &quot;url&quot; value in the &quot;Image&quot; array that contains the string &quot;fanart&quot;. So for instance with the above JSON, the output I&#39;m looking for is:\r\n\r\n```\r\n5d77682c151a60001f24bbe8 http://assets.fanart.tv/fanart/movies/2639/hdmovielogo/deconstructing-harry-60f13837ee6aa.png\r\n```\r\n\r\n\r\n\r\nHere&#39;s my failed attempt, which just spits out compile errors:\r\n\r\n`\r\njq -r &#39;.MediaContainer.Metadata[] | [.ratingKey,.Image[] | select( .url as $items | &quot;fanart&quot; | IN($items[]) )] | @tsv&#39; &#39;trending.json&#39;\r\n`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77509326/selecting-the-first-item-with-a-matching-term-in-an-array-using-jq",
        "title": "Selecting the first item with a matching term in an array using JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9353011,
                    "reputation": 65,
                    "user_id": 6942049,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SQma7Pg4Cxk/AAAAAAAAAAI/AAAAAAAAHZI/JcvlUl-1ICE/s256-rj/photo.jpg",
                    "display_name": "Haim Marko",
                    "link": "https://stackoverflow.com/users/6942049/haim-marko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700403668,
                "post_id": 77511091,
                "comment_id": 136647562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700610963,
                "post_id": 77511091,
                "comment_id": 136675368,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700403631,
                "creation_date": 1700403631,
                "answer_id": 77511114,
                "question_id": 77511091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`leaf_paths` was deprecated in favor of the (more universal) `paths(scalars)`. With jq 1.7 use:\r\n```sh\r\njq &#39;[paths(scalars) as $path | {key: $path | join(&quot;^&quot;), value: getpath($path)}]&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;0^key&quot;,\r\n    &quot;value&quot;: &quot;momo^koko^yoyo^jojo1^access&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;0^value&quot;,\r\n    &quot;value&quot;: &quot;modify&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;1^key&quot;,\r\n    &quot;value&quot;: &quot;momo^koko^yoyo^jojo2^access&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;1^value&quot;,\r\n    &quot;value&quot;: &quot;modify&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/DRPM53F6V4q)",
                "title": "jq leaf_paths builtin function is not longer working in jq 1.7, any way to solve it?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1700411356,
        "creation_date": 1700403332,
        "last_edit_date": 1700411356,
        "question_id": 77511091,
        "body_markdown": "I&#39;m using the builtin `leaf_paths` function for long time. \r\n\r\nRecently upgrade for `node.js` modules causing this function to stop working (any json input will work).\r\n\r\nI could notice this stopped working (with the same error message between `jq` 1.6 to 1.7) \r\n\r\nI still can use the expression on the CLI on `jq` version 1.6: \r\n\r\n```\r\n# jq &#39;.|[leaf_paths as $path|{&quot;key&quot;: $path | join(&quot;^&quot;), &quot;value&quot;: getpath($path)}]&#39; /tmp/a.json\r\n [\r\n  {\r\n   &quot;key&quot;: &quot;momo^koko^yoyo^jojo1^access&quot;,\r\n   &quot;value&quot;: &quot;modify&quot;\r\n  },\r\n  {\r\n   &quot;key&quot;: &quot;momo^koko^yoyo^jojo2^access&quot;,\r\n   &quot;value&quot;: &quot;modify&quot;\r\n  }\r\n ]\r\n\r\n# jq --version\r\njq-1.6\r\n```\r\nWhen I upgrade `jq` to 1.7 (which is probably used for the newer `node-jq` module) I&#39;m getting the following:\r\n```\r\n# /tmp/jq-linux-amd64 &#39;. | [leaf_paths as $path | {&quot;key&quot;: $path | join(&quot;^&quot;), &quot;value&quot;: getpath($path)}]&#39; /tmp/a.json\r\njq: error: leaf_paths/0 is not defined at &lt;top-level&gt;, line 1:\r\n. | [leaf_paths as $path | {&quot;key&quot;: $path | join(&quot;^&quot;), &quot;value&quot;: getpath($path)}]\r\njq: 1 compile error\r\n\r\n# /tmp/jq-linux-amd64 --version\r\njq-1.7\r\n```\r\nAnything I can do to fix it or get the same results using 1.7 (flatten my json into single key value structure) \r\n\r\nthanks!",
        "link": "https://stackoverflow.com/questions/77511091/jq-leaf-paths-builtin-function-is-not-longer-working-in-jq-1-7-any-way-to-solve",
        "title": "jq leaf_paths builtin function is not longer working in jq 1.7, any way to solve it?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1700430423,
                "creation_date": 1700430423,
                "answer_id": 77512635,
                "question_id": 77512617,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either explicitly [check for the existence of the field using `has`](https://jqlang.github.io/jq/manual/#has):\r\n```sh\r\n.rules[] | select(has(&quot;primaryRefs&quot;))\r\n| .primaryRefs[] | select(.name == &quot;b&quot;).weight\r\n```\r\n[Demo](https://jqplay.org/s/qRj8so-CGJf)\r\n\r\nOr use the [error suppression operator `?`](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator):\r\n```sh\r\n.rules[].primaryRefs[]? | select(.name == &quot;b&quot;).weight\r\n```\r\n[Demo](https://jqplay.org/s/0fDgb19EvrV)",
                "title": "How to select a attribute in a list of list using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1700430423,
        "creation_date": 1700430035,
        "question_id": 77512617,
        "body_markdown": "**Example**\r\n\r\nWith this input:\r\n\r\n    {\r\n        &quot;rules&quot;: [\r\n            {\r\n                &quot;primaryRefs&quot;: [\r\n                    {\r\n                       &quot;name&quot;: &quot;a&quot;,\r\n                    },\r\n                    {\r\n                       &quot;name&quot;: &quot;b&quot;,\r\n                       &quot;weight&quot;: 20\r\n                    },\r\n                ],\r\n                &quot;siblingRefs&quot;: [\r\n                   {\r\n                       &quot;name&quot;: &quot;d&quot;,\r\n                    },\r\n                    {\r\n                       &quot;name&quot;: &quot;e&quot;,\r\n                       &quot;weight&quot;: 90\r\n                    },\r\n                ]\r\n            },\r\n            {\r\n                &quot;siblingRefs&quot;: [\r\n                   {\r\n                       &quot;name&quot;: &quot;d&quot;,\r\n                    },\r\n                    {\r\n                       &quot;name&quot;: &quot;e&quot;,\r\n                       &quot;weight&quot;: 90\r\n                    },\r\n                ]\r\n            },\r\n        ]\r\n    }\r\n\r\nI would like to find `weight` in `rules.primaryRefs` whose `name` is `b`\r\n\r\nIn this example, it should return `20`\r\n\r\nI solve it by iterating every \r\n\r\n    {\r\n        &quot;name&quot;: xx,\r\n        &quot;weight&quot;: xx\r\n    }\r\n\r\nunit in `primaryRefs`\r\n\r\nMy filter is \r\n```\r\nFILTER=&#39;.rules[].primaryRefs[] | select(.name == &quot;b&quot;) | .weight’\r\n```\r\n\r\nIt returns the right result, However it returns an error if `primaryRefs` doesn&#39;t exist\r\n```\r\njq: error (at &lt;stdin&gt;:85): Cannot iterate over null (null)\r\n```\r\n\r\nI would like to not error out or return null when `primaryRefs` or `b` doesn&#39;t exist. \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77512617/how-to-select-a-attribute-in-a-list-of-list-using-jq",
        "title": "How to select a attribute in a list of list using jq"
    },
    {
        "tags": [
            "json",
            "bigdata",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1702982732,
                "last_edit_date": 1702982732,
                "creation_date": 1700652158,
                "answer_id": 77529523,
                "question_id": 77528680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s first assume the input JSON is small enough that we don&#39;t have to use the streaming parser.\r\n\r\nFor simplicity, let&#39;s also assume that the queries are presented as JSON arrays with &quot;*&quot; as the wildcard.\r\nSo the first query would be: `[&quot;data&quot;, &quot;*&quot;, &quot;things&quot;, &quot;*&quot;]`\r\n\r\nNext, let&#39;s define a helper function:\r\n```\r\n# matchesQuery($array) evaluates to true iff the input is an array that matches the array $array\r\n# in the sense that there is elementwise matching of as many elements as there are in $array,\r\n# it being understood that &quot;*&quot; in $array is like a wildcard.\r\ndef matchesQuery($array):\r\n  . as $in\r\n  | type == &quot;array&quot;\r\n    and length &gt;= ($array|length)\r\n    and all(range(0; $array|length); . as $i | $array[$i] | IN(&quot;*&quot;, $in[$i]));\r\n```\r\n\r\nThe following filter can then be used to pose queries:\r\n```\r\ndef query($query):\r\n  . as $in\r\n  | ($query|length) as $ql\r\n  | paths\r\n  | select(length == $ql and matchesQuery($query)) as $path\r\n  | ($in | getpath($path)) as $value\r\n  | {$path, $value} ;\r\n```\r\n\r\nFor example, executing `query( [&quot;data&quot;, &quot;*&quot;, &quot;things&quot;, &quot;*&quot;] )` against\r\nthe first file produces the desired output.\r\n\r\nWe can next adapt the above for use with jq&#39;s streaming parser by wrapping `query/1` as follows:\r\n```\r\ndef streamQuery($query):\r\n  fromstream(inputs\r\n    | . as $in\r\n    | if ( length == 2 )\r\n      then select( .[0] | matchesQuery($query))\r\n      else . \r\n      end )\r\n  | query($query);\r\n```\r\nFinally, let&#39;s add a &quot;main&quot; program\r\n```\r\nstreamQuery( $query )\r\n```\r\nso that we can specify the query on the command line:\r\n\r\n```\r\njq -n --stream --argjson query &#39;[&quot;data&quot;, &quot;*&quot;, &quot;things&quot;, &quot;*&quot;]&#39; -c -f streamQuery.jq  file1.json\r\n```\r\n",
                "title": "Include path of any object when streaming out JSON from JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1703004186,
        "creation_date": 1700644844,
        "last_edit_date": 1703004186,
        "question_id": 77528680,
        "body_markdown": "I&#39;d like to be able to extract specific JSON objects from huge (100GB+) JSON files by specifying a wildcard lookup.\r\n(While my end goal is having a path type string for lookups, I&#39;m more than happy to process this string into a `jq` filter - the `jq` filter for streaming is what I&#39;m having issues with).\r\nIdeally I&#39;d like to only use `jq`.\r\n\r\nThe format of my files are the following:\r\n\r\nFile 1:\r\n\r\n```json\r\n{\r\n   &quot;data&quot;: {\r\n      &quot;&lt;userId1&gt;&quot;: {\r\n         &quot;things&quot;: {\r\n            &quot;&lt;thingId1&gt;&quot;: {\r\n               &quot;subfield1&quot;: &quot;blah1&quot;,\r\n               &quot;subfield3&quot;: &quot;foobar&quot;\r\n            },\r\n            &quot;&lt;thingId2&gt;&quot;: {\r\n               &quot;subfield2&quot;: &quot;blah2&quot;\r\n            }\r\n         }\r\n      },\r\n      &quot;&lt;userId2&gt;&quot;: {\r\n         &quot;things&quot;: {\r\n            &quot;&lt;thingId1&gt;&quot;: {\r\n               &quot;subfield4&quot;: &quot;blah3&quot;\r\n            },\r\n            &quot;&lt;thingId2&gt;&quot;: {\r\n               &quot;subfield3&quot;: &quot;blah4&quot;\r\n            }\r\n         }\r\n      }\r\n   },\r\n   &quot;users&quot;: {\r\n      &quot;&lt;userId1&gt;&quot;: {\r\n         &quot;name&quot;: &quot;user1&quot;,\r\n         &quot;email&quot;: &quot;foo@bar.com&quot;\r\n      },\r\n      &quot;&lt;userId2&gt;&quot;: {\r\n         &quot;name&quot;: &quot;user2&quot;\r\n      },\r\n      &quot;&lt;userId3&gt;&quot;: {\r\n         &quot;email&quot;: &quot;hello@world.com&quot;\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nFile 2 (a more simple list of objects by keys):\r\n\r\n```json\r\n{\r\n   &quot;&lt;key1&gt;&quot;: {\r\n      &quot;subfield1&quot;: &quot;blah1&quot;,\r\n      &quot;subfield3&quot;: &quot;foobar&quot;\r\n   },\r\n   &quot;&lt;key2&gt;&quot;: {\r\n      &quot;subfield2&quot;: &quot;blah2&quot;\r\n   }\r\n}\r\n```\r\n\r\nFile 3 (a deeply keyed list of objects):\r\n\r\n```json\r\n{\r\n   &quot;&lt;key1&gt;&quot;: {\r\n      &quot;&lt;subKey1A&gt;&quot;: {\r\n         &quot;&lt;deeperKey1A&gt;&quot;: {\r\n            &quot;subfield1&quot;: &quot;blah1&quot;,\r\n            &quot;subfield3&quot;: &quot;foobar&quot;\r\n         },\r\n         &quot;&lt;deeperKey2A&gt;&quot;: {\r\n            &quot;subfield1&quot;: &quot;blah1&quot;,\r\n            &quot;subfield4&quot;: &quot;foobar4&quot;\r\n         }\r\n      },\r\n      &quot;&lt;subKey2A&gt;&quot;: {\r\n         &quot;&lt;deeperKey2A&gt;&quot;: {\r\n            &quot;subfield4&quot;: &quot;foobar4&quot;\r\n         }\r\n      }\r\n   },\r\n   &quot;&lt;key2&gt;&quot;: {\r\n      &quot;&lt;subKey1B&gt;&quot;: {\r\n         &quot;&lt;deeperKey2B&gt;&quot;: {\r\n            &quot;subfield1&quot;: &quot;blah1&quot;,\r\n            &quot;subfield4&quot;: &quot;foobar4&quot;\r\n         }\r\n      },\r\n      &quot;&lt;subKey2B&gt;&quot;: {\r\n         &quot;&lt;deeperKey1B&gt;&quot;: {\r\n            &quot;subfield1&quot;: &quot;blah1&quot;,\r\n            &quot;subfield3&quot;: &quot;foobar&quot;\r\n         },\r\n         &quot;&lt;deeperKey3B&gt;&quot;: {\r\n            &quot;subfield4&quot;: &quot;foobar6&quot;\r\n         }\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nIn both the above cases any `&lt;blah&gt;` keys are arbitrary IDs.\r\n\r\nI&#39;d like the output for the following files - the search is the wildcard type look up I&#39;d like to achieve - think of the `$&lt;&gt;` paths as &quot;this matches anything&quot; (maybe using `*` is clearer but I like that it helps identify what the wildcard component is when reading it...).\r\nI&#39;ve also included the specific `jq` filters for each case I&#39;ve gotten to work.\r\n\r\nFile 1 - for the `data/$userId/things/$thingId` search:\r\n\r\n```ndjson\r\n{ &quot;path&quot;: [&quot;data&quot;, &quot;&lt;userId1&gt;&quot;, &quot;things&quot;, &quot;&lt;thingId1&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;data&quot;, &quot;&lt;userId1&gt;&quot;, &quot;things&quot;, &quot;&lt;thingId2&gt;&quot;], &quot;value&quot;: { &quot;subfield2&quot;: &quot;blah2&quot; } }\r\n{ &quot;path&quot;: [&quot;data&quot;, &quot;&lt;userId2&gt;&quot;, &quot;things&quot;, &quot;&lt;thingId1&gt;&quot;], &quot;value&quot;: { &quot;subfield4&quot;: &quot;blah3&quot; } }\r\n{ &quot;path&quot;: [&quot;data&quot;, &quot;&lt;userId2&gt;&quot;, &quot;things&quot;, &quot;&lt;thingId1&gt;&quot;], &quot;value&quot;: { &quot;subfield3&quot;: &quot;blah4&quot; } \r\n\r\n```\r\n\r\n`jq` filter:\r\n\r\n```jq\r\nforeach (\r\n\r\n  ( inputs | select(has(1) and ((.[0] | length) &gt;= 4) and .[0][0] == &quot;data&quot; and .[0][2] == &quot;things&quot;)\r\n  | (first | [rindex(&quot;things&quot;)] | max | values) as $p\r\n  | [.[0][$p+2:], .[0][:$p+2], .[1]]), [[]]\r\n\r\n) as [$vpath, $path, $value] ([];\r\n\r\n  if [first.path, $path] | unique[1]\r\n  then [{$path}, first] else .[:1] end\r\n  | first.value |= setpath($vpath; $value);\r\n\r\n  .[1] | values\r\n)\r\n```\r\n\r\nFile 1 - for the `users/$userId` search:\r\n\r\n```ndjson\r\n{ &quot;path&quot;: [&quot;users&quot;, &quot;&lt;userId1&gt;&quot;], &quot;value&quot;: { &quot;name&quot;: &quot;user1&quot;, &quot;email&quot;: &quot;foo@bar.com&quot; } }\r\n{ &quot;path&quot;: [&quot;users&quot;, &quot;&lt;userId2&gt;&quot;], &quot;value&quot;: { &quot;name&quot;: &quot;user2&quot; } }\r\n{ &quot;path&quot;: [&quot;users&quot;, &quot;&lt;userId3&gt;&quot;], &quot;value&quot;: { &quot;email&quot;: &quot;hello@world.com&quot; } }\r\n```\r\n\r\n`jq` filter:\r\n\r\n```jq\r\nforeach (\r\n\r\n  ( inputs | select(has(1) and ((.[0] | length) &gt;= 1) and .[0][0] == &quot;users&quot;)\r\n  | (first | [rindex(&quot;users&quot;)] | max | values) as $p\r\n  | [.[0][$p+2:], .[0][:$p+2], .[1]]), [[]]\r\n\r\n) as [$vpath, $path, $value] ([];\r\n\r\n  if [first.path, $path] | unique[1]\r\n  then [{$path}, first] else .[:1] end\r\n  | first.value |= setpath($vpath; $value);\r\n\r\n  .[1] | values\r\n)\r\n```\r\n\r\nFile 2 - for the `$key` search:\r\n\r\n```ndjson\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key2&gt;&quot;], &quot;value&quot;: { &quot;subfield2&quot;: &quot;blah2&quot; } }\r\n```\r\n\r\nI stumbled on to a partial solution for this while messing around with adapting the above filters:\r\n\r\n```jq\r\nforeach (\r\n\r\n  ( inputs | select(has(1) and ((.[0] | length) &gt;= 1))\r\n  | (first | [-1] | max | values) as $p\r\n  | [.[0][$p+2:], .[0][:$p+2], .[1]]), [[]]\r\n\r\n) as [$vpath, $path, $value] ([];\r\n\r\n  if [first.path, $path] | unique[1]\r\n  then [{$path}, first] else .[:1] end\r\n  | first.value |= setpath($vpath; $value);\r\n\r\n  .[1] | values\r\n)\r\n```\r\n\r\nThis almost works, but outputs duplicate entries (the same number as the number of keys in the child object):\r\n\r\n```ndjson\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key2&gt;&quot;], &quot;value&quot;: { &quot;subfield2&quot;: &quot;blah2&quot; } }\r\n```\r\n\r\nI don&#39;t really understand why replacing `[rindex(&quot;some-key&quot;)]` with `[-1]` produces this output!\r\n\r\nFile 3 - for the `$key/$subKey/$deeperKey` search:\r\n\r\n```nsjson\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;, &quot;&lt;subKey1A&gt;&quot;, &quot;&lt;deeperKey1A&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;, &quot;&lt;subKey1A&gt;&quot;, &quot;&lt;deeperKey2A&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield4&quot;: &quot;foobar4&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key1&gt;&quot;, &quot;&lt;subKey2A&gt;&quot;, &quot;&lt;deeperKey2A&gt;&quot;], &quot;value&quot;: { &quot;subfield4&quot;: &quot;foobar4&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key2&gt;&quot;, &quot;&lt;subKey1B&gt;&quot;, &quot;&lt;deeperKey2B&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield4&quot;: &quot;foobar4&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key2&gt;&quot;, &quot;&lt;subKey2B&gt;&quot;, &quot;&lt;deeperKey1B&gt;&quot;], &quot;value&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } }\r\n{ &quot;path&quot;: [&quot;&lt;key2&gt;&quot;, &quot;&lt;subKey2B&gt;&quot;, &quot;&lt;deeperKey1C&gt;&quot;], &quot;value&quot;: { &quot;subfield4&quot;: &quot;foobar6&quot; } }\r\n```\r\n\r\nI&#39;ve managed to get this to work a bit with the above filters again, but all that I could get printed out was the first key (`&lt;key1&gt;`) with `value` being the object nested under its parent paths (`{ &quot;&lt;subKey1A&gt;&quot;: { &quot;&lt;deeperKey1A&gt;&quot;: { &quot;subfield1&quot;: &quot;blah1&quot;, &quot;subfield3&quot;: &quot;foobar&quot; } } }`).\r\n\r\n### Note\r\n\r\nThis could be classed as a duplicate of [my original question](https://stackoverflow.com/questions/76905501/include-path-of-object-when-streaming-out-json-from-jq), and while that has a great answer I still need some more flexibility and didn&#39;t want to go changing that question (which I already had once) removing meaning from the excellent answer.",
        "link": "https://stackoverflow.com/questions/77528680/include-path-of-any-object-when-streaming-out-json-from-jq",
        "title": "Include path of any object when streaming out JSON from JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700651643,
                "last_edit_date": 1700651643,
                "creation_date": 1700649574,
                "answer_id": 77529203,
                "question_id": 77529089,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Building on the ideas of https://stackoverflow.com/questions/73893818/reusable-function-to-group-by-but-return-an-object-with-group-as-key:\r\n\r\n```\r\ndef group(k;v):\r\n  group_by(k) | map({ key: first|k, value: map(v) }) | from_entries;\r\ndef group(k): group(k; .);\r\n  \r\ngroup(.muleVersion; .s2iVersion)\r\n| to_entries\r\n| map({ muleVersion: .key, s2iVersions: (.value|unique) })\r\n```\r\n\r\nOr using `group_by` directly and mapping the result:\r\n\r\n```\r\ngroup_by(.muleVersion)\r\n| map({ muleVersion: first.muleVersion, s2iVersions: (map(.s2iVersion)|unique) })\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.4.0-85&quot;,\r\n      &quot;4.4.0-87&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.5.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.5.0-05&quot;\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "Merging array of objects based on values in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1700649969,
                "creation_date": 1700649969,
                "answer_id": 77529241,
                "question_id": 77529089,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `group_by/1`, `map` and `unique`\r\n\r\n```none\r\ngroup_by(.muleVersion) | \r\n  map({&quot;muleVersion&quot;: .[0].muleVersion, s2iVersions: (map(.s2iVersion) | unique)})\r\n```",
                "title": "Merging array of objects based on values in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1700651643,
        "creation_date": 1700648632,
        "question_id": 77529089,
        "body_markdown": "I&#39;ve created a JSON array that contains objects I want group and nest based on a shared value, and then have an array with a list of matching values under this. I just can&#39;t figure it out.\r\n\r\n\r\nHere is my input data:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;pcmp-ingestion-master&quot;,\r\n    &quot;s2iVersion&quot;: &quot;4.5.0-05&quot;,\r\n    &quot;muleVersion&quot;: &quot;4.5.0&quot;,\r\n    &quot;imageSha&quot;: &quot;sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;pcmp-ingestion-syst&quot;,\r\n    &quot;s2iVersion&quot;: &quot;4.4.0-87&quot;,\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;imageSha&quot;: &quot;sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;pcmp-ingestion-uat&quot;,\r\n    &quot;s2iVersion&quot;: &quot;4.4.0-87&quot;,\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;imageSha&quot;: &quot;sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;qualityofhire-uat&quot;,\r\n    &quot;s2iVersion&quot;: &quot;4.4.0-85&quot;,\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;imageSha&quot;: &quot;sha256:baabd127862667b17bda7ff278144314469205c12d1445295dc3cf0001ac79db&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;virtual-assist-uat&quot;,\r\n    &quot;s2iVersion&quot;: &quot;4.4.0-85&quot;,\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;imageSha&quot;: &quot;sha256:b82d58aa174fe668061e41453d11212e9162381f8b20a2db3b9a525e6b981140&quot;\r\n  }\r\n]\r\n```\r\n\r\nHere is what I&#39;d ultimately like to have as an output from JQ.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.4.0-87&quot;,\r\n      &quot;4.4.0-85&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.6.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.6.0-01&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\nI&#39;ve tried a few things but can only mange to map these down flat and select unique values, without combining them, like so:\r\n\r\n\r\n```\r\nmap( { muleVersion: .muleVersion, &quot;s2iVersions&quot;: ([.s2iVersion])}) | unique_by(.s2iVersions)\r\n```\r\n\r\nWhich gives this output\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.4.0-85&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.4.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.4.0-87&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;muleVersion&quot;: &quot;4.6.0&quot;,\r\n    &quot;s2iVersions&quot;: [\r\n      &quot;4.6.0-01&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\nI feel like the solution to this is probably blindingly obvious, but I&#39;m in a rut. Does anyone have any pointers?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77529089/merging-array-of-objects-based-on-values-in-jq",
        "title": "Merging array of objects based on values in JQ"
    },
    {
        "tags": [
            "github-actions",
            "jq",
            "github-cli",
            "nektos-act"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1700652406,
                "creation_date": 1700652406,
                "answer_id": 77529543,
                "question_id": 77529334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems like your problem is _only_ with authenticating when running the workflow locally. Per [the `act` documentation][1]:\r\n\r\n&gt; ### `GITHUB_TOKEN`\r\n&gt; \r\n&gt; GitHub [automatically provides][2] a `GITHUB_TOKEN` secret when\r\n&gt; running workflows inside GitHub.\r\n&gt; \r\n&gt; If your workflow depends on this token, you need to create a [personal\r\n&gt; access token][3] and pass it to `act` as a secret:\r\n&gt; \r\n&gt;     act -s GITHUB_TOKEN=[insert token or leave blank and omit equals for secure input]\r\n&gt; \r\n&gt; If [GitHub CLI][4] is installed, the [`gh auth token`][5] command can\r\n&gt; be used to automatically pass the token to act\r\n&gt; \r\n&gt;     act -s GITHUB_TOKEN=&quot;$(gh auth token)&quot;\r\n&gt; \r\n&gt; **WARNING**: `GITHUB_TOKEN` will be logged in shell history if not inserted through secure input or (depending on your shell config) the\r\n&gt; command is prefixed with a whitespace.\r\n\r\nYou&#39;re missing this `-s` parameter to provide valid token locally. Alternatively, if you have e.g. a `.env` file, you can use `--secret-file`, again per [the docs][6]:\r\n\r\n&gt; ### Secrets\r\n&gt; \r\n&gt; To run `act` with secrets, you can enter them interactively, supply\r\n&gt; them as environment variables or load them from a file. The following\r\n&gt; options are available for providing secrets:\r\n&gt; \r\n&gt; - `act -s MY_SECRET=somevalue` - use `somevalue` as the value for `MY_SECRET`.\r\n&gt; - `act -s MY_SECRET` - check for an environment variable named `MY_SECRET` and use it if it exists. If the environment variable is\r\n&gt; not defined, prompt the user for a value.\r\n&gt; - `act --secret-file my.secrets` - load secrets values from `my.secrets` file.\r\n&gt;     - secrets file format is the same as `.env` format\r\n\r\n[1]: https://github.com/nektos/act#github_token\r\n[2]: https://docs.github.com/en/actions/security-guides/automatic-token-authentication#about-the-github_token-secret\r\n[3]: https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens\r\n[4]: https://cli.github.com/\r\n[5]: https://cli.github.com/manual/gh_auth_token\r\n[6]: https://github.com/nektos/act#secrets",
                "title": "Implement workflow to label Issue as &quot;blocked&quot; based on dependencies"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1700655009,
        "creation_date": 1700650666,
        "last_edit_date": 1700655009,
        "question_id": 77529334,
        "body_markdown": "I am trying to implement a GitHub Actions workflow  that automatically labels an issue as &quot;blocked&quot; if it has dependencies on tasks that are still in progress. The action should be triggered when an issue is opened, edited, or reopened. Technical solution:\r\n\r\n- Create a YAML file in the `.github/workflows` directory of the repository.\r\n- The workflow should be triggered on issue events: opened, edited, and reopened.\r\n- Use the GitHub CLI tool to fetch the state of dependent issues.\r\n- Use jq to parse and filter JSON data.\r\n- If a dependent issue is found to be open, label the current issue as &quot;blocked&quot;.\r\n\r\n\r\nSo far I have\r\n\r\n- Created file `label-blocked-issues.yml` in `.github/workflows`:\r\n\r\n    ```yaml\r\n    on:\r\n      issues:\r\n        types:\r\n          - opened\r\n          - edited\r\n          - reopened\r\n    \r\n    jobs:\r\n      label-blocked-issues:\r\n        runs-on: ubuntu-latest\r\n        steps:\r\n          - name: Checkout Repository\r\n            uses: actions/checkout@v3\r\n    \r\n          - name: Install GitHub CLI\r\n            run: |\r\n              sudo apt-get update\r\n              sudo apt-get install gh\r\n    \r\n          - name: Authenticate with GitHub\r\n            run: |\r\n              echo -e &quot;machine github.com\\nlogin $GITHUB_ACTOR\\npassword ${{ secrets.GITHUB_TOKEN }}&quot; &gt; ~/.netrc\r\n              chmod 600 ~/.netrc\r\n    \r\n          - name: Find and Label Blocked Issues\r\n            id: find-blocked-issues\r\n            run: |\r\n              body=$(jq -r .issue.body $GITHUB_EVENT_PATH)\r\n              dependencies=$(echo &quot;$body&quot; | grep -oE &quot;#[0-9]+&quot; | sed &#39;s/#//g&#39; || true)\r\n              \r\n              found_blocked=false\r\n              for issue in $dependencies; do\r\n                status=$(curl -s -H &quot;Authorization: Bearer $GITHUB_TOKEN&quot; \\\r\n                  -H &quot;Accept: application/vnd.github.v3+json&quot; \\\r\n                  &quot;https://api.github.com/repos/${{ github.repository }}/issues/$issue&quot; | jq -r .state)\r\n              \r\n                if [ &quot;$status&quot; != &quot;closed&quot; ]; then\r\n                  echo &quot;Issue #$issue is still open&quot;\r\n                  found_blocked=true\r\n                fi\r\n              done\r\n              \r\n              if [[ &quot;$found_blocked&quot; == true ]]; then\r\n                echo &quot;::set-output name=blocked::true&quot;\r\n              fi\r\n    \r\n          - name: Label Issue as Blocked if\r\n            if: steps.find-blocked-issues.outputs.blocked == &#39;true&#39;\r\n            run: |\r\n              echo &quot;Labeling issue as blocked...&quot;\r\n              echo &quot;GitHub Repository: ${{ github.repository }}&quot;\r\n              echo &quot;Issue Number: ${{ github.event.issue.number }}&quot;\r\n    \r\n              # Use the GitHub token directly in the command\r\n              gh api --method POST \\\r\n                -H &quot;Accept: application/vnd.github+json&quot; \\\r\n                -H &quot;X-GitHub-Api-Version: 2022-11-28&quot; \\\r\n                -H &quot;Authorization: Bearer ${{ secrets.GITHUB_TOKEN }}&quot; \\\r\n                /repos/${{ github.repository }}/issues/${{ github.event.issue.number }}/labels \\\r\n                -f &quot;labels[]=blocked&quot;\r\n    ```\r\n\r\n- Created file `test-event.json` within same directory:\r\n\r\n    ```json\r\n    {\r\n      &quot;action&quot;: &quot;opened&quot;,\r\n      &quot;issue&quot;: {\r\n        &quot;number&quot;: 1,\r\n        &quot;title&quot;: &quot;Test Issue&quot;,\r\n        &quot;body&quot;: &quot;Depends on #123&quot;,\r\n        &quot;state&quot;: &quot;open&quot;\r\n      }\r\n    }\r\n    ```\r\n\r\n- Tested steps from file `label-blocked-issues.yml` together with `test-event.json` using Nektos/Act tool with Act Commands: \r\n\r\n    `act -v -e .github/workflows/test-event.json -W . -j label-blocked-issues`\r\n\r\n    or for simplicity:\r\n\r\n    `act -e .github/workflows/test-event.json -W . -j label-blocked-issues`\r\n\r\n\r\n    All steps runs and passed successfully, except of the last one _&quot;Label Issue as Blocked if&quot;_, when this step runs I get the following output:\r\n    \r\n    ```none\r\n    [label-blocked-issues.yml/label-blocked-issues] ⭐ Run Main Label Issue as Blocked if\r\n    [label-blocked-issues.yml/label-blocked-issues]   &#128051;  docker exec cmd=[bash --noprofile --norc -e -o pipefail /var/run/act/workflow/4] user= workdir=\r\n    | Labeling issue as blocked...\r\n    | GitHub Repository: treasure-house-of-projects/skarb-ngo\r\n    | Issue Number: 1\r\n    | Welcome to GitHub CLI!\r\n    | \r\n    | To authenticate, please run `gh auth login`.\r\n    [label-blocked-issues.yml/label-blocked-issues]   ❌  Failure - Main Label Issue as Blocked if\r\n    [label-blocked-issues.yml/label-blocked-issues] exitcode &#39;4&#39;: failure\r\n    [label-blocked-issues.yml/label-blocked-issues] &#127937;  Job failed\r\n    Error: Job &#39;label-blocked-issues&#39; failed\r\n    ```\r\n    \r\n    So I am not able to pass GitHub CLI authentication. \r\n\r\nI have tried different approaches related to `GITHUB_TOKEN`, `secrets.GITHUB_TOKEN`, etc., also I try to include the authentication directly in the steps where it&#39;s needed: \r\n\r\n```bash\r\ngh auth login --with-token ${{ secrets.GITHUB_TOKEN }}\r\n```\r\n\r\nBut nothing that I have done can pass the GitHub CLI authentication withing Nektos/Act test tool.",
        "link": "https://stackoverflow.com/questions/77529334/implement-workflow-to-label-issue-as-blocked-based-on-dependencies",
        "title": "Implement workflow to label Issue as &quot;blocked&quot; based on dependencies"
    },
    {
        "tags": [
            "jq",
            "webvtt"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700675310,
                "creation_date": 1700675310,
                "answer_id": 77532165,
                "question_id": 77529561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The [WebVTT file format](https://developer.mozilla.org/en-US/docs/Web/API/WebVTT_API) allows for many more content items, e.g. text headers, cue settings, `NOTE` blocks, `STYLE` blocks, etc., even a BOM at the beginning. But if you&#39;re happy considering only the subset used in your example (backed by your statement that your sample filter produces the desired output), have a look atthe following rewrite:\r\n\r\n#### Line endings\r\n\r\n&gt; `rtrim` is used in case the WebVTT file has DOS `\\r\\n` line endings.\r\n\r\nYou could read the entire input into one string using `jq --raw-input --slurp`, then remove all carriage return characters using `gsub(&quot;\\r&quot;; &quot;&quot;)`, so from then on you only have to deal with newline characters.\r\n\r\n#### Final newline\r\n\r\n&gt; Filter requires an extra newline at the end of the file to emit the last cue.\r\n\r\nTo partition the long string into empty-line-delimited blocks, it can be split into an array at any occurrence of at least two consecutive newline characters (i.e. at least one empty line) using the regex `\\n\\n+`. That way, it doesn&#39;t matter if there is no newline at the end. Combine it with the regex `\\n$` to also catch (and eliminate) a single newline ending: `splits(&quot;\\n(\\n+|$)&quot;)`\r\n\r\n#### Output composition\r\n\r\nThe `first` block of text is considered to be the line containing the `.filetype`, and the remaining items in the `.[1:]` array are the blocks that become the items in the `.cues` array. Use `map` to transform each item by first splitting them again into lines using `/`, then drop any items that had no lines using `select(has(0))`, and distribute the first (`.[0]`), second (`.[1]`) and all remaining lines (`.[2:]`) to `.uid`, `.timeline`, and `.subtitles`, respectively.\r\n\r\n```sh\r\n# jq -Rs\r\n\r\ngsub(&quot;\\r&quot;; &quot;&quot;) | [splits(&quot;\\n(\\n+|$)&quot;)] | {\r\n  filename: input_filename, filetype: first,\r\n  cues: .[1:] | map(. / &quot;\\n&quot; | select(has(0)) | {\r\n    uid: .[0], timeline: .[1], subtitles: .[2:]\r\n  })\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;filename&quot;: &quot;&lt;stdin&gt;&quot;,\r\n  &quot;filetype&quot;: &quot;WEBVTT&quot;,\r\n  &quot;cues&quot;: [\r\n    {\r\n      &quot;uid&quot;: &quot;dc9af9e8-8909-11ee-80b1-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:00:08.280 --&gt; 00:00:08.880&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;Good morning Mr. Phelps.&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;uid&quot;: &quot;ddf6092c-8909-11ee-bc4f-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:00:09.720 --&gt; 00:00:12.840&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;Your mission, should you choose to&quot;,\r\n        &quot;accept it,&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;uid&quot;: &quot;e03b2da2-8909-11ee-a212-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:17:52.052 --&gt; 00:17:55.586&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;This tape will self-destruct in 5&quot;,\r\n        &quot;seconds.&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/H1CUGv_8Tco)",
                "title": "WebVTT to JSON using `jq`"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700694628,
                "last_edit_date": 1700694628,
                "creation_date": 1700694311,
                "answer_id": 77533527,
                "question_id": 77529561,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I really like [@pmf&#39;s answer](https://stackoverflow.com/a/77532165/1409374) - it&#39;s clear and concise.  For very large files (e.g. from hours of interviews, documentaries), making a single pass through the file will speed up the processing considerably.\r\n\r\nBelow is a much improved filter (compared to the one in the question), that uses a small FIFO to collect each cue, and then emit it when there&#39;s a line break.  A problem with this filter and an input file that has no trailing newlines, is that the last cue won&#39;t get emitted on its own.  To workaround that, some newlines can be appended to `jq`&#39;s input stream.  Here&#39;s how I did that using input file process substitution:\r\n```\r\n$ jq the_options the_filter the_WebVTT_file &lt;(echo -e &quot;\\n&quot;)\r\n```\r\nImproved filter (using `--null-input --raw-input`):\r\n```\r\ninput | rtrimstr(&quot;\\r&quot;) |\r\n{\r\n  filename: input_filename,\r\n  filetype: .,\r\n  cues: [\r\n    foreach inputs as $i\r\n      ( {fifo:[], emit: false};\r\n        if .emit then .emit=false|.fifo=[] else . end |\r\n        if ($i|test(&quot;^\\\\s*$&quot;)) and (.fifo|length &gt; 0)\r\n        then .emit=true\r\n        else\r\n          if ($i|test(&quot;^\\\\s*$&quot;)|not)\r\n          then .fifo+=[$i|rtrimstr(&quot;\\r&quot;)]\r\n          else .\r\n          end\r\n        end;\r\n        if .emit then {uid:.fifo[0], timeline:.fifo[1], subtitles:.fifo[2:] } else empty end\r\n      )\r\n  ]\r\n}\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/hvVqz836ZYB &quot;Click me!&quot;).",
                "title": "WebVTT to JSON using `jq`"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1700694628,
        "creation_date": 1700652589,
        "question_id": 77529561,
        "body_markdown": "I&#39;d like to convert some WebVTT to JSON.  I have a `jq` filter, but it could be improved.\r\n[jqplay.org example](https://jqplay.org/s/jAHQOeysY-p)\r\n\r\nHere&#39;s a snippet of example WebVTT.\r\n```\r\nWEBVTT\r\n\r\ndc9af9e8-8909-11ee-80b1-44850052397e\r\n00:00:08.280 --&gt; 00:00:08.880\r\nGood morning Mr. Phelps.\r\n\r\nddf6092c-8909-11ee-bc4f-44850052397e\r\n00:00:09.720 --&gt; 00:00:12.840\r\nYour mission, should you choose to\r\naccept it,\r\n\r\ne03b2da2-8909-11ee-a212-44850052397e\r\n00:17:52.052 --&gt; 00:17:55.586\r\nThis tape will self-destruct in 5\r\nseconds.\r\n\r\n```\r\nUsing this filter (with `--null-input --raw-input` options),\r\n```\r\ndef rtrim: rtrimstr(&quot;\\r&quot;);\r\ninput|rtrim|{filename: input_filename, filetype: ., cues:\r\n[foreach inputs as $i\r\n  ( {start:false, theEnd:false};\r\n    if ($i|test(&quot;^[a-f0-9]{8}-&quot;))\r\n    then .start=true|.theEnd=false|.out={uid: $i|rtrim, timeline: input|rtrim, subtitles: [input|rtrim]} \r\n    else\r\n      if ($i|test(&quot;^\\\\s*$&quot;))\r\n      then .theEnd=.start\r\n      else if .start then .out+={subtitles: (.out.subtitles+[$i|rtrim])} else .theEnd=false end\r\n      end\r\n    end;\r\n    if (.start and .theEnd) then [.out] else empty end\r\n  )\r\n| add]\r\n}\r\n```\r\n... the desired output is produced for my example files.\r\n```lang-json\r\n{\r\n  &quot;filename&quot;: &quot;&lt;stdin&gt;&quot;,\r\n  &quot;filetype&quot;: &quot;WEBVTT&quot;,\r\n  &quot;cues&quot;: [\r\n    {\r\n      &quot;uid&quot;: &quot;dc9af9e8-8909-11ee-80b1-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:00:08.280 --&gt; 00:00:08.880&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;Good morning Mr. Phelps.&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;uid&quot;: &quot;ddf6092c-8909-11ee-bc4f-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:00:09.720 --&gt; 00:00:12.840&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;Your mission, should you choose to&quot;,\r\n        &quot;accept it,&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;uid&quot;: &quot;e03b2da2-8909-11ee-a212-44850052397e&quot;,\r\n      &quot;timeline&quot;: &quot;00:17:52.052 --&gt; 00:17:55.586&quot;,\r\n      &quot;subtitles&quot;: [\r\n        &quot;This tape will self-destruct in 5&quot;,\r\n        &quot;seconds.&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n`rtrim` is used in case the WebVTT file has DOS `\\r\\n` line endings.  All `if` statements have an `else` clause since some versions of `jq` require it.\r\n\r\n#### Issues\r\n1. Filter requires an extra newline at the end of the file to emit the last cue.\r\n2. Filter is mostly sufficient, but a bit of a mess. It was patched until the desired output appeared.  It could be improved.\r\n\r\nI know there are other solutions/libraries/apps to process WebVTT, but I&#39;m curious to know if `jq` can do it on its own.\r\n",
        "link": "https://stackoverflow.com/questions/77529561/webvtt-to-json-using-jq",
        "title": "WebVTT to JSON using `jq`"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonlines"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1700673358,
                "creation_date": 1700673358,
                "answer_id": 77531956,
                "question_id": 77531885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could read the banned ids using `--rawfile`, split it at newline characters, and compare each JSON line read if its `.id` is contained:\r\n```sh\r\njq -c --rawfile b banned_list.txt &#39;select(IN(.id; $b | (. / &quot;\\n&quot;)[]) | not)&#39; source.jsonl\r\n```\r\n\r\nThis, however, would split the list of banned ids over and over on each input line, so it&#39;d be better to prepare it beforehand into a proper JSON array using another call to jq, and `--slurpfile` to read the JSON strings into an array:\r\n```sh\r\njq -c --slurpfile b &lt;(jq -R . banned_list.txt) &#39;select(IN(.id; $b[]) | not)&#39; source.jsonl\r\n```\r\n\r\nOutput:\r\n```json\r\n{&quot;id&quot;:&quot;y88979&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n{&quot;id&quot;:&quot;h93794&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n{&quot;id&quot;:&quot;i8408&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n```\r\n\r\nYou could even improve on this by sorting the list of banned ids, and use `bsearch` for a binary search.",
                "title": "deleting lines from jsonl file with matching key/value using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700717967,
                "last_edit_date": 1700717967,
                "creation_date": 1700699627,
                "answer_id": 77533788,
                "question_id": 77531885,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I will explain how implement a blacklist (your interest) and a whitelist:\r\n\r\n    $ cat banned_list.txt\r\n    k9489\r\n    p48947\r\n\r\nYou can create a simple json-list : (Note: the awk ensures no &#39;\\r&#39; chars ):\r\n\r\n    $ awk &#39;{gsub(/\\r/,&quot;&quot;,$0);print $0}&#39; banned_list.txt  | jq --raw-input &#39;.&#39; | jq &#39;.&#39; -s &gt; list.json\r\n    \r\n    $ cat list.json\r\n    [\r\n      &quot;k9489&quot;,\r\n      &quot;p48947&quot;\r\n    ]\r\n\r\nBlacklist implementation:\r\n\r\nSelect all objects with the &quot;.id&quot; not in the $ban array.\r\nHere we read list.json into &quot;black&quot; jq-variable:\r\n\r\n\r\n    $ jq --argfile black list.json &#39;select(.id|IN($black[])|not) &#39; source.jsonl -c\r\n    {&quot;id&quot;:&quot;y88979&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n    {&quot;id&quot;:&quot;h93794&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n    {&quot;id&quot;:&quot;i8408&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n\r\nWhitelist implementation:\r\n\r\nSelect all objects with the &quot;.id&quot; in the $ban array. \r\nHere we read list.json into &quot;white&quot; jq-variable:\r\n\r\n    $ jq --argfile white list.json &#39;select(.id|IN($white[])) &#39; source.jsonl -c\r\n    {&quot;id&quot;:&quot;k9489&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n    {&quot;id&quot;:&quot;p48947&quot;,&quot;content&quot;:&quot;content goes here&quot;}\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "deleting lines from jsonl file with matching key/value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1700717967,
        "creation_date": 1700672706,
        "question_id": 77531885,
        "body_markdown": "I have a large jsonl file like so:\r\n\r\n```\r\n# source.jsonl\r\n{&quot;id&quot;: &quot;y88979&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;h93794&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;k9489&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;p48947&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;i8408&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n```\r\n\r\nI have a banned id list like so:\r\n\r\n```\r\n#banned_list.txt\r\nk9489\r\np48947\r\n&lt;/snip&gt;\r\n```\r\n\r\nI want to now delete the lines where the &quot;id&quot; matches any of the id on the banned list text file. So I am looking for the result:\r\n\r\n```\r\n{&quot;id&quot;: &quot;y88979&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;h93794&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n{&quot;id&quot;: &quot;i8408&quot;, &quot;content&quot;: &quot;content goes here&quot;}\r\n```\r\n\r\nPython would be too slow to iterate over this jsonl file (20gb) and I see that `jq` is the best for doing this but unsure about the syntax which will allow it to take all ids from a list.. :(\r\n",
        "link": "https://stackoverflow.com/questions/77531885/deleting-lines-from-jsonl-file-with-matching-key-value-using-jq",
        "title": "deleting lines from jsonl file with matching key/value using jq"
    },
    {
        "tags": [
            "bash",
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700686433,
                "post_id": 77533031,
                "comment_id": 136686481,
                "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": 1700687414,
                "post_id": 77533031,
                "comment_id": 136686642,
                "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": 1700687466,
                "post_id": 77533031,
                "comment_id": 136686648,
                "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": 1700687541,
                "post_id": 77533031,
                "comment_id": 136686665,
                "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": 1700687601,
                "post_id": 77533031,
                "comment_id": 136686675,
                "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": 1700687682,
                "post_id": 77533031,
                "comment_id": 136686692,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700688783,
                "last_edit_date": 1700688783,
                "creation_date": 1700687887,
                "answer_id": 77533141,
                "question_id": 77533031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way uses [`getpath()`][1] to extract the paths of the input JSON based on a variable (Or other string):\r\n\r\n```sh\r\n$ jq --arg path &quot;rec_9M.rec_E&quot; --arg i 555 &#39;getpath($path | split(&quot;.&quot;))[] += {id: $i}&#39; config.json\r\n{\r\n  &quot;rec_9M&quot;: {\r\n    &quot;id&quot;: &quot;000&quot;,\r\n    &quot;rec_E&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nNote leaving the trailing `[]` off the path; this only works with paths through object elements that end in an array of objects.\r\n\r\nAnother, more flexible but also more fragile approach involves putting the path held in the shell variable directly in the `jq` program:\r\n\r\n```sh\r\n$ path_var=&quot;.rec_9M.rec_E[].id&quot;\r\n$ jq --arg i 555 &quot;$path_var&quot;&#39; |= $i&#39; config.json\r\n{\r\n  &quot;rec_9M&quot;: {\r\n    &quot;id&quot;: &quot;000&quot;,\r\n    &quot;rec_E&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\n\r\nNote having to put a leading `.` in the path expression.\r\n\r\n\r\n---\r\n\r\n`echo $(cat config.json)` has so many things wrong with it. `jq` takes the file names of JSON documents as arguments; use that. Or even a Useless Use of Cat like `cat config.json | jq ...` for example purposes is fine if you intend to replace the `cat` part with something more complex like a `curl` request or other command that outputs JSON... but don&#39;t combine it with `echo`. Besides introducing needless steps, if your shell&#39;s version of `echo` does things like replace `\\n` with a literal newline, it&#39;s going to break everything else if escape sequences are present in strings in the JSON.\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#getpath",
                "title": "Can jq parse more than one level key from variable?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700688783,
        "creation_date": 1700686318,
        "last_edit_date": 1700686467,
        "question_id": 77533031,
        "body_markdown": "I have a json file:\r\n\r\n```\r\n{\r\n  &quot;rec_9M&quot;:\r\n    {\r\n    &quot;id&quot;:&quot;000&quot;,\r\n    &quot;rec_E&quot;:\r\n        [\r\n          {\r\n            &quot;id&quot;:&quot;111&quot;\r\n          } ,\r\n          {\r\n            &quot;id&quot;:&quot;222&quot;\r\n          }           \r\n        ]\r\n    }\r\n}\r\n```\r\nI need to change values rec_9M.rec_E[].id but I need to use a universal bash function for that, which can be using for changing values on different levels (rec_9M.id or rec_9M.rec_E[].files[].id)\r\n\r\n\r\n\r\nI tryed:\r\n\r\n```\r\nVAR=rec_9M.rec_E[]\r\nNUM=555\r\n\r\necho $(cat config.json) | jq --arg VAR_I $VAR --arg NUM_I $NUM &#39;.[$VAR_I].id = $NUM_I&#39; &gt; config_t.json\r\ncat config_t.json \r\n```\r\nExpect:\r\n[enter image description here](https://i.sstatic.net/PsLMU.png)\r\n```\r\n{\r\n  &quot;rec_9M&quot;: {\r\n    &quot;id&quot;: &quot;000&quot;,\r\n    &quot;rec_E&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;555&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nReality:\r\n[enter image description here](https://i.sstatic.net/FZq1W.png)\r\n```\r\n{\r\n  &quot;rec_9M&quot;: {\r\n    &quot;id&quot;: &quot;000&quot;,\r\n    &quot;rec_E&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;111&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;222&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;rec_9M.rec_E[]&quot;: {\r\n    &quot;id&quot;: &quot;555&quot;\r\n  }\r\n}\r\n```\r\nIf key was hardcoded - everything works correctly.:\r\n```\r\necho $(cat config.json) | jq --arg VAR_I $VAR --arg NUM_I $NUM &#39;.rec_9M.rec_E[].id = $NUM_I&#39; &gt; config_t.json\r\n```\r\n\r\nAlso I tryed any combinations of using VAR_I in jq with quotes and special symbols, for example &quot;\\($VAR_I)&quot;. Results are the same or jq parsing errors.\r\n\r\nMaybe anybody know a solution?",
        "link": "https://stackoverflow.com/questions/77533031/can-jq-parse-more-than-one-level-key-from-variable",
        "title": "Can jq parse more than one level key from variable?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1700687995,
                "post_id": 77533126,
                "comment_id": 136686741,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1700688109,
                "post_id": 77533126,
                "comment_id": 136686756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700735236,
                "last_edit_date": 1700735236,
                "creation_date": 1700690315,
                "answer_id": 77533297,
                "question_id": 77533126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Any suggestions please?\r\n\r\nApart from the suggestions made by @CharlesDuffy, first note\r\nthat assuming input.txt is a simple text file using &quot;newline&quot; as a delimiter of the relevant strings, then you&#39;d want to gather those into a suitable JSON structure, such as an array:\r\n```\r\n ($foo / &quot;\\n&quot; | map(select(length&gt;0))) as $ok\r\n```\r\n\r\nNext, if you wanted to check for equality, consider using `IN/1`, along the lines of:\r\n\r\n```\r\nselect(.metadata.name | IN($ok[]) )\r\n```\r\n\r\nIf you really want to use `contains`, then presumably you&#39;d want something like:\r\n```\r\nselect(.metadata.name as $name\r\n| any($ok[]; . as $s | $name | contains($s)) ) \r\n```\r\nFinally, you should consider combining your two invocations of jq into one.\r\n\r\n",
                "title": "bash jq pass map as argument"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1700735236,
        "creation_date": 1700687685,
        "last_edit_date": 1700687934,
        "question_id": 77533126,
        "body_markdown": "I have this bash line containg jq that works fine:\r\n```bash\r\nkubectl --namespace=default get -o=json services | \\\r\n  jq &#39;del( .items[] |\r\n           select(.metadata.name | contains(&quot;something&quot;,&quot;otherthing&quot;)))&#39; | \\\r\n  jq &#39;.items[].metadata.name&#39; | \\\r\n  wc -l\r\n```\r\nAnd I would like to pass to `contains` many words. So I made a file named input.txt that contains these words and I am trying to pass this file to `contains` expression but with no luck:\r\n```bash\r\nkubectl --namespace=default get -o=json services | \\\r\n  jq -Rs --rawfile foo ./input.txt &#39;\r\n    del( .items[] |\r\n         select(.metadata.name | contains($foo)))&#39; | \\\r\n  jq &#39;.items[].metadata.name&#39; | \\\r\n  wc -l\r\n```\r\n\r\n...but this fails with `\r\njq: error (at &lt;stdin&gt;:7490): Cannot index string with string &quot;items&quot;`\r\n\r\nAny suggestions please?\r\n",
        "link": "https://stackoverflow.com/questions/77533126/bash-jq-pass-map-as-argument",
        "title": "bash jq pass map as argument"
    },
    {
        "tags": [
            "curl",
            "makefile",
            "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": 1700726213,
                "post_id": 77533956,
                "comment_id": 136690285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13243529,
                    "reputation": 3681,
                    "user_id": 9563318,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MnYi1.jpg?s=256",
                    "display_name": "Jon",
                    "link": "https://stackoverflow.com/users/9563318/jon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700732652,
                "post_id": 77533956,
                "comment_id": 136691490,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8832612,
                    "reputation": 13,
                    "user_id": 6598308,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6d6c8cd9ef7ef5cebcd07e0246ed4ca4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RooTShell",
                    "link": "https://stackoverflow.com/users/6598308/rootshell"
                },
                "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": 1700767134,
                "post_id": 77533956,
                "comment_id": 136697493,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8832612,
                    "reputation": 13,
                    "user_id": 6598308,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6d6c8cd9ef7ef5cebcd07e0246ed4ca4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "RooTShell",
                    "link": "https://stackoverflow.com/users/6598308/rootshell"
                },
                "reply_to_user": {
                    "account_id": 13243529,
                    "reputation": 3681,
                    "user_id": 9563318,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MnYi1.jpg?s=256",
                    "display_name": "Jon",
                    "link": "https://stackoverflow.com/users/9563318/jon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700767235,
                "post_id": 77533956,
                "comment_id": 136697504,
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700794219,
                "post_id": 77533956,
                "comment_id": 136699748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13243529,
                    "reputation": 3681,
                    "user_id": 9563318,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MnYi1.jpg?s=256",
                    "display_name": "Jon",
                    "link": "https://stackoverflow.com/users/9563318/jon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1700818542,
                "post_id": 77533956,
                "comment_id": 136702325,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700874146,
                "creation_date": 1700874146,
                "answer_id": 77546300,
                "question_id": 77533956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You say: _when I try to do it in bash from within a MAKE file I get an error._\r\n\r\nBut, `make` does not invoke bash.  Make invokes `/bin/sh`.  One some systems, such as Red Hat and derived systems, `/bin/sh` is actually bash.  But on other systems, such as Debian and derived systems (including Ubuntu), `/bin/sh` is a simple POSIX shell (typically `dash`) which doesn&#39;t have all of bash&#39;s extra features.\r\n\r\nYou don&#39;t say what operating system you&#39;re testing on so I have no idea of this is actually your problem, but instead of writing your script at the command prompt for testing with make you should test it using `/bin/sh -c &#39;my command&#39;` because that&#39;s how make will invoke it.\r\n\r\nIf you want to have your recipes run with bash instead of the POSIX standard `/bin/sh` you must set it in your makefile:\r\n\r\n    SHELL := /bin/bash",
                "title": "Error parsing JSON output from curl with jq in MAKEFILE"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700874146,
        "creation_date": 1700704308,
        "last_edit_date": 1700794684,
        "question_id": 77533956,
        "body_markdown": "I&#39;m trying to parse a JSON response from Github&#39;s API inside a MAKE file but I&#39;m unable to do it. I can easily make it work in pure bash but when I try to do it in bash from within a MAKE file I get an error.\r\n\r\nThe error I get is: \r\n\r\n&gt;     Invalid string: control characters from U+0000 through U+001F must be escaped \r\n&gt;     at line 322, column 22\r\n\r\nHere&#39;s the code in my MAKE file\r\n\r\n\r\n```sh\r\nget_assets:\r\n    @json=$$(curl -s &quot;https://api.github.com/repos/realm/realm-swift/releases/latest&quot;); \\\r\n\techo &quot;$${json}&quot; | jq -r &#39;.assets[] | .name, .browser_download_url&#39; | while read -r name ; do \\\r\n\t\tread -r url; \\\r\n\t\techo &quot;$$name&quot; &quot;$$url&quot;; \\\r\n\tdone; \\\r\n```\r\n\r\n\r\nI tried a bunch of stuff like using printf instead of echo to pipe the output to jq, using `jq -Rr`, etc. to no avail.\r\n\r\n**UPDATE**\r\n\r\nIf I save the cURL output to a file and then pipe the contents of that file using cat into jq all works as intended.\r\n\r\n```sh\r\nget_assets:\r\n    @curl -s &quot;https://api.github.com/repos/realm/realm-swift/releases/latest&quot; &gt; /tmp/realm.txt; \\\r\n\tcat /tmp/realm.txt | jq -r &#39;.assets[] | .name, .browser_download_url&#39; | while read -r name ; do \\\r\n\t\tread -r url; \\\r\n\t\techo &quot;$$name&quot; &quot;$$url&quot;; \\\r\n\tdone; \\\r\n```\r\n\r\nThe above code works correctly but I would rather pipe the cURL output directly into jq instead of having to first save it into a file...\r\n",
        "link": "https://stackoverflow.com/questions/77533956/error-parsing-json-output-from-curl-with-jq-in-makefile",
        "title": "Error parsing JSON output from curl with jq in MAKEFILE"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700740043,
                "post_id": 77536544,
                "comment_id": 136692923,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700742038,
                "creation_date": 1700742038,
                "answer_id": 77536826,
                "question_id": 77536544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Why is my shell script splitting my JSON object in the middle of a string?\r\n\r\nBecause unquoted command substitution `$(...)` is split a space `t&quot;:&quot;don&#39;t read&quot;}` into two elements.\r\n\r\n&gt; Can i escape the space somehow?\r\n\r\nNo, word splitting on unquoted expansion ignores any escapes. Additionally, filename expansion also runs on unquoted expansion. Instead, you have to use a completely different method, where you do not use the result from an unquoted expansion. What code actually to write, depends on the result that you want to get.\r\n\r\nRemember to check your scripts with `shellcheck`, which helps to protect also against unquoted expansions.",
                "title": "Why is my shell script splitting my JSON object in the middle of a string?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1700742061,
                "creation_date": 1700742061,
                "answer_id": 77536829,
                "question_id": 77536544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could convert each item into a JSON-encoded string using `@json`, and escape that for shell using `@sh`. Then, On the shell&#39;s side, use `declare -a` to declare the indexed Bash array.\r\n\r\n```sh\r\nunset entries\r\ndeclare -a entries=&quot;($(\r\n  jq -r &#39;.[] | @json | @sh&#39; ../ext/js/language/languages.json\r\n))&quot;\r\necho &quot;[1] ${entries[1]}&quot;\r\n```\r\n```\r\n[1] {&quot;iso&quot;:&quot;en&quot;,&quot;language&quot;:&quot;English&quot;,&quot;flag&quot;:&quot;&#127482;&#127480;&#127468;&#127463;&quot;,&quot;exampleText&quot;:&quot;don&#39;t read&quot;}\r\n```",
                "title": "Why is my shell script splitting my JSON object in the middle of a string?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1700742061,
        "creation_date": 1700739307,
        "question_id": 77536544,
        "body_markdown": "I am having problems parsing a JSON file using jq from a .sh script. When the object contains a space, shell splits it into two. Can i escape the space somehow?\r\n\r\nFrom command line:\r\n\r\n`echo $(jq &#39;.&#39; ../ext/js/language/languages.json) | jq -c &#39;.[1]&#39;\r\n`\r\nreturns:\r\n\r\n`{&quot;iso&quot;:&quot;en&quot;,&quot;language&quot;:&quot;English&quot;,&quot;flag&quot;:&quot;&#127482;&#127480;&#127468;&#127463;&quot;,&quot;exampleText&quot;:&quot;don&#39;t read&quot;}\r\n`\r\n\r\nwhich is what i want (languages.json contains an array of such objects)\r\n\r\nFrom shell:\r\n\r\n```\r\nentries=($(jq -c &#39;.[]&#39; ../ext/js/language/languages.json))\r\necho &quot;[1] ${entries[1]}&quot;\r\necho &quot;[2] ${entries[2]}&quot;\r\n```\r\n\r\n```\r\n[1] {&quot;iso&quot;:&quot;en&quot;,&quot;language&quot;:&quot;English&quot;,&quot;flag&quot;:&quot;&#127482;&#127480;&#127468;&#127463;&quot;,&quot;exampleText&quot;:&quot;don&#39;t\r\n[2] read&quot;}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77536544/why-is-my-shell-script-splitting-my-json-object-in-the-middle-of-a-string",
        "title": "Why is my shell script splitting my JSON object in the middle of a string?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700748963,
                "creation_date": 1700748963,
                "answer_id": 77537598,
                "question_id": 77537504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To only trigger the lookup if the value is a string, you can use `select(type == &quot;string&quot;)`, which also has the `strings` shortcut. So, in your first attempt, just replace `.[1:]` with `strings[1:]`, and you should be good to go.\r\n\r\n```sh\r\njq -r &#39;[ .Parameters | to_entries[] | .value |= (env[strings[1:]] // .) | [.key, .value] | join(&quot;=&quot;) ] | @sh&#39; &lt; myfile.json\r\n```",
                "title": "Convert json structure and conditional update values using environment variables with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700748963,
        "creation_date": 1700748161,
        "question_id": 77537504,
        "body_markdown": "I have the following json:\r\n\r\n```json\r\n{\r\n  &quot;Parameters&quot;: {\r\n    &quot;AmiId&quot;: &quot;/my/image/id/latest&quot;,\r\n    &quot;InstanceType&quot;: &quot;t3.medium&quot;,\r\n    &quot;Environment&quot;: &quot;$ENV_DEFINITION&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnd I have exported the `$ENV_DEFINITION` with the value `dev`.\r\n\r\nNOTE: I want to keep the literal value `$ENV_DEFINTION` if the environment variable is not set. That&#39;s why I&#39;m using the `// .` part when accessing the `env[]` array in the command below.\r\n\r\nI need to obtain the following output:\r\n\r\n```bash\r\n&#39;AmiId=/my/image/id/latest&#39; &#39;InstanceType=t3.medium&#39; &#39;Environment=dev&#39;\r\n```\r\n\r\nI&#39;m able to get the above output witht he following `jq` command:\r\n\r\n```bash\r\njq -r &#39;[ .Parameters | to_entries[] | .value |= (env[.[1:]] // .) | [.key, .value] | join(&quot;=&quot;) ] | @sh&#39; &lt; myfile.json\r\n```\r\n\r\nBut then I needed to add a few more parameters to json:\r\n\r\n```json\r\n{\r\n  &quot;Parameters&quot;: {\r\n    &quot;AmiId&quot;: &quot;/my/image/id/latest&quot;,\r\n    &quot;InstanceType&quot;: &quot;t3.medium&quot;,\r\n    &quot;Environment&quot;: &quot;$ENV_DEFINITION&quot;,\r\n    &quot;MinSize&quot;: 0,\r\n    &quot;MaxSize&quot;: 0,\r\n    &quot;DesiredCapacity&quot;: 0,\r\n  }\r\n}\r\n```\r\n\r\nAnd `jq` started to fail with the following message:\r\n\r\n```bash\r\njq: error (at myfile:10): Cannot index number with object\r\n```\r\n\r\nWell, looks like it fails when the json values are integer as it cannont index integer values at the following place: `env[.[1:]]`.\r\n\r\nThen I came up with this new `jq` command:\r\n\r\n```bash\r\njq -r &#39;[ .Parameters | to_entries[] | select((.value|tostring)|startswith(&quot;$&quot;)) |= (env[.[1:]] // .) | [.key, .value] | join(&quot;=&quot;) ] | @sh&#39; &lt; myfile.json\r\n```\r\n\r\nBut now, this fail when trying to replace the `$ENV_DEFINITION`. If I take it out of the json file, the above command works.\r\n\r\nThe error message is:\r\n\r\n```bash\r\njq: error (at myfile.json:5): Cannot index object with object\r\n```\r\n\r\nI have tried the following\r\n\r\n```bash\r\njq -r &#39;[ .Parameters | to_entries[] | .value |= if ((.value|tostring)|startswith(&quot;$&quot;)) then (env[.[1:]] // .) else . end | [.key, .value] | join(&quot;=&quot;) ]&#39; &lt; myfile.json\r\n```\r\n\r\nBut:\r\n\r\n```bash\r\njq: error (at myfile.json:5): Cannot index string with string &quot;value&quot;\r\n```\r\n\r\nI&#39;m still fighting with `jq` and it&#39;s documentation here to figure out what to do but any help will be welcome.",
        "link": "https://stackoverflow.com/questions/77537504/convert-json-structure-and-conditional-update-values-using-environment-variables",
        "title": "Convert json structure and conditional update values using environment variables with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1700830138,
                "post_id": 77543097,
                "comment_id": 136704195,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2685390,
                    "reputation": 244,
                    "user_id": 2319900,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8fe89867fde630466bd8f83ce4f60061?s=256&d=identicon&r=PG",
                    "display_name": "beks6",
                    "link": "https://stackoverflow.com/users/2319900/beks6"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700863427,
                "post_id": 77543097,
                "comment_id": 136708692,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700829193,
                "last_edit_date": 1700829193,
                "creation_date": 1700828811,
                "answer_id": 77543129,
                "question_id": 77543097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one approach using `to_entries` to access keys and values. The `.key` is split at dots using `/`, the parts looking like numbers converted to numbers representing array indices, and used as path to set the `.value` with `setpath`. Using a `reduce` iteration successively builds up the result objects, for each item in the `.Employees` array. The only caveat is that the zeroth item in the `.contactDetails` array (unaddressed in the input data, but necessary to include higher indices) is not automatically populated with the keys of its sibling item (and empty string values, i.e. `{&quot;phone&quot;: &quot;&quot;, &quot;mail&quot;: &quot;&quot;}`) which you would have to provide separately.\r\n\r\n```sh\r\n.Employees[] |= (\r\n  reduce to_entries[] as $e (null;\r\n    setpath($e.key / &quot;.&quot; | map(tonumber? // .); $e.value)\r\n  )\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;First&quot;,\r\n      &quot;lastName&quot;: &quot;Last&quot;,\r\n      &quot;birthday&quot;: &quot;1990-01-01&quot;,\r\n      &quot;account&quot;: &quot;true&quot;,\r\n      &quot;address&quot;: {\r\n        &quot;street&quot;: &quot;Street&quot;,\r\n        &quot;addition&quot;: &quot;1&quot;,\r\n        &quot;zipCode&quot;: &quot;1000&quot;,\r\n        &quot;city&quot;: &quot;Vienna&quot;,\r\n        &quot;region&quot;: &quot;AT&quot;\r\n      },\r\n      &quot;contactDetails&quot;: [\r\n        null,\r\n        {\r\n          &quot;phone&quot;: &quot;+431234567&quot;,\r\n          &quot;mail&quot;: &quot;first.last@mail.com&quot;\r\n        }\r\n      ],\r\n      &quot;organisations&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;departments&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;roles&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/i8bCSKGJns-)",
                "title": "jq - JSON convert keys into objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1700845865,
                "creation_date": 1700845865,
                "answer_id": 77544708,
                "question_id": 77543097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach using [streaming](https://jqlang.github.io/jq/manual/#streaming).  Streaming produces an array for each leaf-value. The path (also an array) is the first element in the array and the leaf-value is the second element in the array.  Splitting the _dotted_ path elements to produce more path elements creates the structure you are looking for.  After processing the paths, `fromstream` reconstructs the desired JSON output.\r\n\r\nN.B.:  Missing array elements produce `null` elements in the output.\r\n```\r\nfromstream(\r\n  tostream\r\n  |[(.[0] | map((splits(&quot;\\\\.&quot;)? // .) | (tonumber? // .))), (.[1] // empty)]\r\n)\r\n```\r\nExample output:\r\n```lang-json\r\n{\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;First&quot;,\r\n      &quot;lastName&quot;: &quot;Last&quot;,\r\n      &quot;birthday&quot;: &quot;1990-01-01&quot;,\r\n      &quot;account&quot;: &quot;true&quot;,\r\n      &quot;address&quot;: {\r\n        &quot;street&quot;: &quot;Street&quot;,\r\n        &quot;addition&quot;: &quot;1&quot;,\r\n        &quot;zipCode&quot;: &quot;1000&quot;,\r\n        &quot;city&quot;: &quot;Vienna&quot;,\r\n        &quot;region&quot;: &quot;AT&quot;\r\n      },\r\n      &quot;contactDetails&quot;: [\r\n        null,\r\n        {\r\n          &quot;phone&quot;: &quot;+431234567&quot;,\r\n          &quot;mail&quot;: &quot;first.last@mail.com&quot;\r\n        }\r\n      ],\r\n      &quot;organisations&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;departments&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;roles&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/c6A5oLvrU5P &quot;Click me!&quot;).",
                "title": "jq - JSON convert keys into objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1700845865,
        "creation_date": 1700828468,
        "question_id": 77543097,
        "body_markdown": "I&#39;m trying to reformat a big JSON from an Excel to JSON conversion into a valid JSON for import.\r\nIn my research I came across jq and hope some one more deep into can help me.\r\n\r\nI have an Array of Employees like this one\r\n\r\n```\r\n{\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;First&quot;,\r\n      &quot;lastName&quot;: &quot;Last&quot;,\r\n      &quot;birthday&quot;: &quot;1990-01-01&quot;,\r\n      &quot;account&quot;: &quot;true&quot;,\r\n      &quot;address.street&quot;: &quot;Street&quot;,\r\n      &quot;address.addition&quot;: &quot;1&quot;,\r\n      &quot;address.zipCode&quot;: &quot;1000&quot;,\r\n      &quot;address.city&quot;: &quot;Vienna&quot;,\r\n      &quot;address.region&quot;: &quot;AT&quot;,\r\n      &quot;contactDetails.1.phone&quot;: &quot;+431234567&quot;,\r\n      &quot;contactDetails.1.mail&quot;: &quot;first.last@mail.com&quot;,\r\n      &quot;organisations.0.id&quot;: 1,\r\n      &quot;departments.0.id&quot;: 1,\r\n      &quot;roles.0.id&quot;: 1\r\n    },\r\n  ]\r\n}\r\n```\r\n\r\nthe output should look as follows for each Employee\r\n\r\n```\r\n{\r\n  &quot;Employees&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;First&quot;,\r\n      &quot;lastName&quot;: &quot;Last&quot;,\r\n      &quot;birthday&quot;: &quot;1990-01-01&quot;,\r\n      &quot;account&quot;: &quot;true&quot;,\r\n      &quot;address&quot;: {\r\n        &quot;street&quot;: &quot;Street&quot;,\r\n        &quot;addition&quot;: &quot;1&quot;,\r\n        &quot;zipCode&quot;: &quot;1000&quot;,\r\n        &quot;city&quot;: &quot;Vienna&quot;,\r\n        &quot;region&quot;: &quot;AT&quot;\r\n      },\r\n      &quot;contactDetails&quot;: [\r\n        {\r\n          &quot;phone&quot;: &quot;&quot;,\r\n          &quot;mail&quot;: &quot;&quot;\r\n        },\r\n        {\r\n          &quot;phone&quot;: &quot;+431234567&quot;,\r\n          &quot;mail&quot;: &quot;first.last@mail.com&quot;\r\n        }\r\n      ],\r\n      &quot;organisations&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;departments&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ],\r\n      &quot;roles&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nis this possible with jq or any ideas how to achieve this?",
        "link": "https://stackoverflow.com/questions/77543097/jq-json-convert-keys-into-objects",
        "title": "jq - JSON convert keys into objects"
    },
    {
        "tags": [
            "json",
            "join",
            "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": 3,
                "creation_date": 1700847189,
                "post_id": 77544567,
                "comment_id": 136706899,
                "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": 1700854677,
                "post_id": 77544567,
                "comment_id": 136707763,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2475364,
                    "reputation": 1256,
                    "user_id": 2156115,
                    "user_type": "registered",
                    "accept_rate": 15,
                    "profile_image": "https://www.gravatar.com/avatar/5f7e6a4827dde9fd15ff95efc3cb0aee?s=256&d=identicon&r=PG",
                    "display_name": "user2156115",
                    "link": "https://stackoverflow.com/users/2156115/user2156115"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700856440,
                "post_id": 77544567,
                "comment_id": 136707976,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2475364,
                    "reputation": 1256,
                    "user_id": 2156115,
                    "user_type": "registered",
                    "accept_rate": 15,
                    "profile_image": "https://www.gravatar.com/avatar/5f7e6a4827dde9fd15ff95efc3cb0aee?s=256&d=identicon&r=PG",
                    "display_name": "user2156115",
                    "link": "https://stackoverflow.com/users/2156115/user2156115"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700858188,
                "post_id": 77544567,
                "comment_id": 136708182,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700861207,
                "creation_date": 1700861207,
                "answer_id": 77545728,
                "question_id": 77544567,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Finally, after reading JQ docs many times I fond a solution to my question:\r\n\r\n        cat example.json| jq -r &#39;(.included | map({(.id): .}) | add)  as $inc | .data[] | {&quot;run-id&quot;: .id , message: .message, &quot;created-by&quot;: .&quot;created-by&quot;, cv: .relationships.&quot;configuration-version&quot;.data.id, branch: $inc[.relationships.&quot;configuration-version&quot;.data.id].attributes.branch, &quot;commit-message&quot;:$inc[.relationships.&quot;configuration-version&quot;.data.id].attributes.&quot;commit-message&quot;, &quot;sender-username&quot;: $inc[.relationships.&quot;configuration-version&quot;.data.id].attributes.&quot;sender-username&quot;  }&#39;\r\n    {\r\n      &quot;run-id&quot;: &quot;run-12345&quot;,\r\n      &quot;message&quot;: &quot;some message&quot;,\r\n      &quot;created-by&quot;: &quot;me&quot;,\r\n      &quot;cv&quot;: &quot;cv-23198&quot;,\r\n      &quot;branch&quot;: &quot;prod&quot;,\r\n      &quot;commit-message&quot;: &quot;Commit message 1&quot;,\r\n      &quot;sender-username&quot;: &quot;Name Surname&quot;\r\n    }\r\n    {\r\n      &quot;run-id&quot;: &quot;run-67891&quot;,\r\n      &quot;message&quot;: &quot;some message&quot;,\r\n      &quot;created-by&quot;: &quot;me&quot;,\r\n      &quot;cv&quot;: &quot;cv-12198&quot;,\r\n      &quot;branch&quot;: &quot;dev&quot;,\r\n      &quot;commit-message&quot;: &quot;Commit message 3&quot;,\r\n      &quot;sender-username&quot;: &quot;Joe Sur&quot;\r\n    }\r\n\r\n",
                "title": "How to use jq to map values between two large keys containing related data"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701078362,
                "creation_date": 1701078362,
                "answer_id": 77555903,
                "question_id": 77544567,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simplified version thanks to rickhg12hs:\r\n\r\n    cat filtered.json | jq -r &#39;(.included | \r\n      map({(.id): .}) | add) as $inc | \r\n      .data[] | {\r\n        &quot;run-id&quot;: .id, \r\n        &quot;time&quot;: .attributes.&quot;status-timestamps&quot;\r\n      } + \r\n      ($inc[$inc[.relationships.&quot;configuration-version&quot;.data.id].relationships.&quot;ingress-attributes&quot;.data.id].attributes |\r\n      {\r\n        branch, \r\n        &quot;commit-message&quot;, \r\n        &quot;sender-username&quot;,\r\n        &quot;clone-url&quot;\r\n      })&#39;\r\n\r\n",
                "title": "How to use jq to map values between two large keys containing related data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1701078362,
        "creation_date": 1700844099,
        "last_edit_date": 1700856600,
        "question_id": 77544567,
        "body_markdown": "I am doing `curl` request and getting response:\r\n```lang-json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;run-12345&quot;,\r\n      &quot;message&quot;: &quot;some message&quot;,\r\n      &quot;created-by&quot;: &quot;me&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;is-cancelable&quot;: false,\r\n        &quot;is-confirmable&quot;: false,\r\n        &quot;is-discardable&quot;: false,\r\n        &quot;is-force-cancelable&quot;: false\r\n      },\r\n      &quot;relationships&quot;: {\r\n        &quot;configuration-version&quot;: {\r\n          &quot;data&quot;: {\r\n            &quot;id&quot;: &quot;cv-23198&quot;,\r\n            &quot;type&quot;: &quot;configuration-version&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;run-67891&quot;,\r\n      &quot;message&quot;: &quot;some message&quot;,\r\n      &quot;created-by&quot;: &quot;me&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;is-cancelable&quot;: false,\r\n        &quot;is-confirmable&quot;: false,\r\n        &quot;is-discardable&quot;: false,\r\n        &quot;is-force-cancelable&quot;: false\r\n      },\r\n      &quot;relationships&quot;: {\r\n        &quot;configuration-version&quot;: {\r\n          &quot;data&quot;: {\r\n            &quot;id&quot;: &quot;cv-12198&quot;,\r\n            &quot;type&quot;: &quot;configuration-version&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  ],\r\n  &quot;included&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;cv-23198&quot;,\r\n      &quot;type&quot;: &quot;ingress-attributes&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;branch&quot;: &quot;prod&quot;,\r\n        &quot;clone-url&quot;: &quot;ssh://git@github/project/repo-awesome.git&quot;,\r\n        &quot;commit-message&quot;: &quot;Commit message 1&quot;,\r\n        &quot;commit-sha&quot;: &quot;4444444444444444444444f601bb4bcd5e07f02a&quot;,\r\n        &quot;sender-username&quot;: &quot;Name Surname&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;cv-12198&quot;,\r\n      &quot;type&quot;: &quot;ingress-attributes&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;branch&quot;: &quot;dev&quot;,\r\n        &quot;clone-url&quot;: &quot;ssh://git@github/project/less-awesome.git&quot;,\r\n        &quot;commit-message&quot;: &quot;Commit message 3&quot;,\r\n        &quot;commit-sha&quot;: &quot;eeeeeeeeeeeeeeeeeeee44f601bb4bcd5e07f02a&quot;,\r\n        &quot;sender-username&quot;: &quot;Joe Sur&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nMy goal is to use `jq` to kind of iterate over key `&quot;data&quot;` and select important info about particular `&quot;id&quot;` and then some additional information related to this very `&quot;id&quot;` is also stored in this other main key `&quot;included&quot;` and it is `id`&#39;ed via `&quot;ww-212121&quot;`.\r\n\r\nIs there any way to kind of get or map data from this two sources together ?\r\n\r\nI tried something like this but it obviously does not work\r\n\r\n```lang-bash\r\ncurl &lt;http://...&gt;| jq -r &#39;.data[] | {&quot;run-id&quot;: .id , message: .message, &quot;created-by&quot;: .&quot;created-by&quot;, cv: .relationships.&quot;configuration-version&quot;.data.id}&#39;\r\n{\r\n  &quot;run-id&quot;: &quot;run-12345&quot;,\r\n  &quot;message&quot;: &quot;some message&quot;,\r\n  &quot;created-by&quot;: &quot;me&quot;,\r\n  &quot;cv&quot;: &quot;cv-23198&quot;,\r\n  &quot;branch&quot;: &quot;prod&quot;,\r\n  &quot;sender-username&quot;: &quot;Name Surname&quot;\r\n}\r\n{\r\n  &quot;run-id&quot;: &quot;run-67891&quot;,\r\n  &quot;message&quot;: &quot;some message&quot;,\r\n  &quot;created-by&quot;: &quot;me&quot;,\r\n  &quot;cv&quot;: &quot;cv-12198&quot;,\r\n  &quot;branch&quot;: &quot;dev&quot;,\r\n  &quot;sender-username&quot;: &quot;Joe Sur&quot;\r\n\r\n}\r\n\r\n```\r\n\r\nI cannot find a way how to enrich this jq so I will have the info about a branch and sender-username taken from keyword &quot;included&quot;",
        "link": "https://stackoverflow.com/questions/77544567/how-to-use-jq-to-map-values-between-two-large-keys-containing-related-data",
        "title": "How to use jq to map values between two large keys containing related data"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq",
            "kubernetes-secrets"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1700848519,
                "creation_date": 1700848519,
                "answer_id": 77544902,
                "question_id": 77544622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to use `jq` would be to do below.\r\n\r\n```none\r\n.spec.template.spec.containers[].env[] |= {name} + \r\nif .name | test(&quot;SECRET|PASSWORD|KEY&quot;) then \r\n    .valueFrom |= ( \r\n        with_entries(\r\n            if .key == &quot;configMapKeyRef&quot; then .key = &quot;secretKeyRef&quot; end | \r\n                .value |= {key} + {name: .key|ascii_downcase}\r\n        )\r\n    )\r\nend\r\n```\r\n\r\njqplay demo - https://jqplay.org/s/UfYQYpJIa6o",
                "title": "transforming configMapKeyRef into secretKeyRef with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700850829,
                "last_edit_date": 1700850829,
                "creation_date": 1700848635,
                "answer_id": 77544915,
                "question_id": 77544622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "- Navigate to the desired locations: `.spec.template.spec.containers[].env[]?`\r\n- Filter for those matching your criteria: `select(.name | test(&quot;SECRET|PASSWORD|KEY&quot;))`\r\n- Take those results and go deeper: `(…).valueFrom`\r\n- Update it with access to `.key` and `.value`: `|= with_entries(…)`\r\n- Only if the key matches that name: `select(.key == &quot;configMapKeyRef&quot;) |= …`\r\n- By redefining key and value: `{key: &quot;secretKeyRef&quot;, value: …}`\r\n- The new value is based on the previous value, and assigns the lowercase key to name: `.value | .name = (.key | ascii_downcase)`\r\n```sh\r\n(\r\n    .spec.template.spec.containers[].env[]?\r\n    | select(.name | test(&quot;SECRET|PASSWORD|KEY&quot;))\r\n)\r\n\r\n.valueFrom |= with_entries(select(.key == &quot;configMapKeyRef&quot;) |= {\r\n    key: &quot;secretKeyRef&quot;, value: (.value | .name = (.key | ascii_downcase))\r\n})\r\n```\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n  &quot;kind&quot;: &quot;Deployment&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;replicas&quot;: 1,\r\n    &quot;selector&quot;: {\r\n      &quot;matchLabels&quot;: {\r\n        &quot;io.kompose.service&quot;: &quot;item-api&quot;\r\n      }\r\n    },\r\n    &quot;strategy&quot;: {\r\n      &quot;type&quot;: &quot;Recreate&quot;\r\n    },\r\n    &quot;template&quot;: {\r\n      &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n          {\r\n            &quot;env&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;APP_JWTSECRET&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;secretKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;APP_JWTSECRET&quot;,\r\n                    &quot;name&quot;: &quot;app_jwtsecret&quot;\r\n                  }\r\n                }\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;SPRING_DATASOURCE_BASEXML_JDBCURL&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;configMapKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;SPRING_DATASOURCE_BASEXML_JDBCURL&quot;,\r\n                    &quot;name&quot;: &quot;item-api-env&quot;\r\n                  }\r\n                }\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/ZEOS0v0QDOU)\r\n\r\nNote: I regarded the change from `app_jwtsecret` to `app-jwtsecret` a typo.",
                "title": "transforming configMapKeyRef into secretKeyRef with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700848868,
                "creation_date": 1700848868,
                "answer_id": 77544932,
                "question_id": 77544622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you could do it.  The `containers` and `env` array are rewritten with the desired modification, or kept _&quot;as is&quot;_ if the condition isn&#39;t met.\r\n\r\n```lang-jq\r\n.spec.template.spec.containers\r\n|= map(\r\n    (.env\r\n     |= map(\r\n          if (.name|test(&quot;SECRET|PASSWORD|KEY&quot;))\r\n          then .valueFrom\r\n            |= with_entries(.key=&quot;secretKeyRef&quot;\r\n                 |.value.name=(.value.key|ascii_downcase|gsub(&quot;_&quot;;&quot;-&quot;))\r\n               )\r\n          else .\r\n          end\r\n        )\r\n    )? // .\r\n)\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/nqtiSZplJga &quot;Click me!&quot;).",
                "title": "transforming configMapKeyRef into secretKeyRef with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1700850829,
        "creation_date": 1700844611,
        "question_id": 77544622,
        "body_markdown": "Here is my deploy input\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n  &quot;kind&quot;: &quot;Deployment&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;replicas&quot;: 1,\r\n    &quot;selector&quot;: {\r\n      &quot;matchLabels&quot;: {\r\n        &quot;io.kompose.service&quot;: &quot;item-api&quot;\r\n      }\r\n    },\r\n    &quot;strategy&quot;: {\r\n      &quot;type&quot;: &quot;Recreate&quot;\r\n    },\r\n    &quot;template&quot;: {\r\n      &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n          {\r\n            &quot;env&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;APP_JWTSECRET&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;configMapKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;APP_JWTSECRET&quot;,\r\n                    &quot;name&quot;: &quot;item-api-env&quot;\r\n                  }\r\n                }\r\n              },\r\n              {\r\n                &quot;name&quot;: &quot;SPRING_DATASOURCE_BASEXML_JDBCURL&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;configMapKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;SPRING_DATASOURCE_BASEXML_JDBCURL&quot;,\r\n                    &quot;name&quot;: &quot;item-api-env&quot;\r\n                  }\r\n                }\r\n              }\r\n...\r\n```\r\nFor each item into `env`, I&#39;d like to transform the `configMapKeyRef` into `secretKeyRef`if name contains (SECRET|PASSWORD|KEY) pattern and then replace the secretKeyRef name by the key name into lowcase.\r\n\r\nfor example:\r\n```json\r\n                &quot;name&quot;: &quot;APP_JWTSECRET&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;configMapKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;APP_JWTSECRET&quot;,\r\n                    &quot;name&quot;: &quot;item-api-env&quot;\r\n                  }\r\n                }\r\n              }\r\n```\r\nwould be transformed into\r\n```json\r\n                &quot;name&quot;: &quot;APP_JWTSECRET&quot;,\r\n                &quot;valueFrom&quot;: {\r\n                  &quot;secretKeyRef&quot;: {\r\n                    &quot;key&quot;: &quot;APP_JWTSECRET&quot;,\r\n                    &quot;name&quot;: &quot;app-jwtsecret&quot;\r\n                  }\r\n                }\r\n              }\r\n```\r\n\r\nI tried some kind of manipulation with `with_entries` without any success:\r\n```jq\r\njq -r &#39;.spec.template.spec.containers[].env[]|with_entries(.key |test(PASSWORD|SECRET))&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77544622/transforming-configmapkeyref-into-secretkeyref-with-jq",
        "title": "transforming configMapKeyRef into secretKeyRef with jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 73996,
                    "reputation": 68279,
                    "user_id": 212858,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1166c87b6f3fc2e6746da96b60fefb46?s=256&d=identicon&r=PG",
                    "display_name": "Useless",
                    "link": "https://stackoverflow.com/users/212858/useless"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1701080179,
                "post_id": 77556057,
                "comment_id": 136726269,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701094713,
                "post_id": 77556057,
                "comment_id": 136728802,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1701081429,
                "last_edit_date": 1701081429,
                "creation_date": 1701080900,
                "answer_id": 77556160,
                "question_id": 77556057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can alter your JQ command by looping over the items (`[]`), then use `split()` and `[-1]` to select the task id&#39;s:\r\n```none\r\njq -r &#39;.taskArns[] | split(&quot;/&quot;)[-1]&#39;\r\n```\r\n\r\nThis gives us a list of the task id&#39;s:\r\n```none\r\n1f3761101efd439f9d8959901e8f6095\r\n2bfb7cdfb9e64362b4df6b7f7e829236\r\n408879277ab24490b1b911b119c81414\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nAfterwards you can [iterate](https://stackoverflow.com/questions/33950596/iterating-through-json-array-in-shell-script) over the result using `.. | while read task_id; do`:\r\n\r\n```\r\njq -r &#39;.taskArns[] | split(&quot;/&quot;)[-1]&#39; &quot;$(aws ecs list-tasks --cluster dev-ec2s )&quot; \\   \r\n    |  while read task_id; do \r\n           aws ecs describe-tasks --cluster dev-ec2-cls --tasks &quot;$task_id&quot;;\r\n       done\r\n```",
                "title": "How to loop over items from AWS CLI output?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1701082155,
        "creation_date": 1701079829,
        "last_edit_date": 1701082155,
        "question_id": 77556057,
        "body_markdown": "`aws ecs list-tasks --cluster dev-ec2s`\r\n\r\nthis shows the list like this below, in this case three lines, but it can change.\r\n\r\n    &quot;taskArns&quot;: [\r\n        &quot;arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/1f3761101efd439f9d8959901e8f6095&quot;,\r\n        &quot;arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/2bfb7cdfb9e64362b4df6b7f7e829236&quot;,\r\n        &quot;arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/408879277ab24490b1b911b119c81414&quot;,\r\n\r\n\r\nthen I made this script,\r\n\r\ntask id such as `408879277ab24490b1b911b119c81414` is set as environment variable and throw to next command.\r\n\r\n```\r\ntask_id=(aws ecs list-tasks --cluster dev-ec2s |\r\njq &#39;.taskArns[0] | split(\\&quot;/\\&quot;)[-1]&#39; |\r\nawk &#39;{print substr($0, 2, length($0)-2)}&#39;)\r\naws ecs describe-tasks --cluster dev-ec2-cls --tasks &quot;$task_id&quot;,\r\n```\r\nIt can work on first row.\r\n\r\nHowever I want to do this for every row.\r\n\r\nHow can I do this?",
        "link": "https://stackoverflow.com/questions/77556057/how-to-loop-over-items-from-aws-cli-output",
        "title": "How to loop over items from AWS CLI output?"
    },
    {
        "tags": [
            "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": 3,
                "creation_date": 1701109565,
                "post_id": 77559130,
                "comment_id": 136731900,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1284195,
                    "reputation": 3273,
                    "user_id": 1237617,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/751d2ec3098e48dbe032d9f533c158a6?s=256&d=identicon&r=PG",
                    "display_name": "Jakub Bochenski",
                    "link": "https://stackoverflow.com/users/1237617/jakub-bochenski"
                },
                "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": 1701110341,
                "post_id": 77559130,
                "comment_id": 136732027,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1701112577,
                "creation_date": 1701112577,
                "answer_id": 77559397,
                "question_id": 77559130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As your set of keys seems to be static, you _could_ (whether you also should is on another page, though) prefix your jq filters with a static set of bindings off of the imported arguments object. For example, statically prepend your unchanged jq code once with `$args as {$foo, $baz} |`, and use `--argjson args …` to import the set at once:\r\n\r\n```sh\r\njq -n --argjson args &#39;{&quot;foo&quot;: &quot;bar&quot;, &quot;baz&quot;: 123}&#39; &#39;$args as {$foo, $baz} |&#39;\\\r\n&#39;\r\n  &quot;\\($foo) is \\($baz)&quot;\r\n&#39;\r\n```\r\n```\r\n&quot;bar is 123&quot;\r\n```\r\n\r\n",
                "title": "Named arguments from file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701373727,
                "last_edit_date": 1701373727,
                "creation_date": 1701120816,
                "answer_id": 77560068,
                "question_id": 77559130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your list of named jq arguments is in arguments.json,\r\n\r\nyou can define a shell function as follows :\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\njq2(){\r\n    local arguments=$1 args; shift\r\n    mapfile -t args &lt; &lt;(jq -r &#39;to_entries[] | &quot;--argjson&quot;, .key, (.value|@json)&#39; $arguments)\r\n    jq &quot;${args[@]}&quot; &quot;$@&quot;\r\n}\r\n\r\njq2 arguments.json -n &#39;&quot;\\($foo) is \\($baz)&quot;&#39;\r\n```\r\n\r\nOutput :\r\n```\r\n&quot;bar is 123&quot;\r\n```\r\n\r\nIf the value of baz is `&quot;Hello \\n\\&quot;&#39;$var&#39;\\&quot;\\t\\\\ World!&quot;`, containing a lot of special characters, the output is correctly produced :\r\n\r\n```\r\n&quot;bar is Hello \\n\\&quot;&#39;$var&#39;\\&quot;\\t\\\\ World!&quot;\r\n```",
                "title": "Named arguments from file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1701373727,
        "creation_date": 1701109330,
        "last_edit_date": 1701111114,
        "question_id": 77559130,
        "body_markdown": "I&#39;d like to have a list of named jq arguments in a file, e.g so that using a file like\r\n\r\n```\r\n{ &quot;foo&quot; : &quot;bar&quot;, &quot;baz&quot;: 123 }\r\n```\r\n\r\nWould be equivalent to invoking `jq --argjson foo &#39;&quot;bar&quot;&#39; --argjson baz 123`\r\n\r\nIs this possible? \r\n\r\nI guess I could use jq to parse the file and emit the arguments part of the CLI, but it feels bad.\r\n\r\nIn the end I want to run a jq program with several different sets of arguments. E.g.\r\n\r\n```\r\njq -n --argjson foo &#39;&quot;bar&quot;&#39; --argjson baz 123 &#39;&quot;\\($foo) is \\($baz)&quot;&#39;\r\njq -n --argjson foo &#39;&quot;RAB&quot;&#39; --argjson baz 321 &#39;&quot;\\($foo) is \\($baz)&quot;&#39;\r\n```\r\n\r\nbut each set of arguments taken from separate file instead of specifying them on the command line.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77559130/named-arguments-from-file",
        "title": "Named arguments from file"
    },
    {
        "tags": [
            "python",
            "jq",
            "py-langchain",
            "jsonloader"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701174605,
                "post_id": 77562545,
                "comment_id": 136740223,
                "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": 1701174752,
                "post_id": 77562545,
                "comment_id": 136740249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1718168484,
                "creation_date": 1718168484,
                "answer_id": 78610697,
                "question_id": 77562545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For those looking to run `jq` on **Windows**, there&#39;s a wheel available for `jq` at https://jeffreyknockel.com/jq/. The author mentions that there are not many tests done on this yet . So, if you do choose to work with it, it&#39;s at your own risks. Been using it, so far, no issue. How to go about it?\r\n- Download the `.whl`file matching your Python version\r\n- Install it: \r\n  ```bash\r\n     pip install [PATH TO .WHL FILE]\r\n  ```\r\nRef: https://github.com/mwilliamson/jq.py/issues/20#issuecomment-1411157736",
                "title": "Unable to pip install jq on Windows"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1718168484,
        "creation_date": 1701162625,
        "question_id": 77562545,
        "body_markdown": "I wrote this code in Python(using Langchain) in order to load different types of documents and retrieve a proper ai answer related to a question asked before. It was working okay until I decided that I need to implement history, so that the AI Model have information it can relate to.\r\nIt throws an error saying &#39;pip install jq&#39; but whenever I try to it does not work and prompts &#39;Failed to build jq\r\nERROR: Could not build wheels for jq, which is required to install pyproject.toml-based projects&#39;\r\nI think it is not available for Windows, bc I have tried downloading it with winget, manually downloading jq file and setting a path, but I need to install it as a package, so that JSONLoader can call it on just 1 line. It needs to be  a JSON Loader since all the other document loaders are type Loader. \r\n\r\n\r\nI am sending a list of messages(chat history) and in the PHP Laravel back-end I encode it into json using:\r\n\r\n \r\n```\r\n$jsonHistory = json_encode($request[&#39;chatHistory&#39;], JSON_PRETTY_PRINT);\r\n```\r\n\r\nAfter that I receive the chat history as a str in the Python back-end:\r\n\r\n```\r\nclass Request(BaseModel):\r\n        ai_input: str //these two are not important for that\r\n        company: str //\r\n        chatHistory: str\r\n\r\nclass AiModel:\r\n async def get_answer(request: Request):\r\n txt_loader = DirectoryLoader(f&quot;{request.company}/&quot;, glob=&quot;**/*.txt&quot;, loader_cls=TextLoader)\r\n        pdf_loader = DirectoryLoader(f&quot;{request.company}/&quot;, glob=&quot;**/*.pdf&quot;, loader_cls=PyMuPDFLoader)\r\n        csv_loader = DirectoryLoader(f&quot;{request.company}/&quot;, glob=&quot;**/*.csv&quot;, loader_cls=CSVLoader)\r\n        json_loader = JSONLoader(request.chatHistory, jq_schema=&#39;.input[]content&#39;)\r\n\r\nloadersList = [txt_loader, pdf_loader, csv_loader, json_loader]\r\n        index = VectorstoreIndexCreator().from_loaders(loadersList)\r\n        llm = ChatOpenAI\r\n        if request.ai_input:\r\n query = request.ai_input \r\n         answer =  index.query(query, llm=llm)\r\nreturn {&quot;answer&quot;:answer}\r\n\r\n\r\n```\r\n\r\nAny ideas How can I proceed, so that I can load the json file with the rest of the docs?\r\n",
        "link": "https://stackoverflow.com/questions/77562545/unable-to-pip-install-jq-on-windows",
        "title": "Unable to pip install jq on Windows"
    },
    {
        "tags": [
            "json",
            "jq",
            "counter"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1701199720,
                "creation_date": 1701199720,
                "answer_id": 77566658,
                "question_id": 77566633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the approach suggested by [this solution](https://stackoverflow.com/a/45171347/3390419):\r\n\r\n```bash\r\n$ jq &#39;def counter(stream):\r\nreduce stream as $s ({}; .[$s|tostring] += 1);\r\ncounter(.[].status)&#39; test.json\r\n{\r\n  &quot;200&quot;: 1,\r\n  &quot;301&quot;: 1,\r\n  &quot;403&quot;: 1\r\n}\r\n```",
                "title": "Counting instances of a value using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1701199736,
                "creation_date": 1701199736,
                "answer_id": 77566662,
                "question_id": 77566633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works:\r\n\r\n    reduce .[] as $row ({}; .[$row.status | tostring] += 1)\r\n\r\nThe trick is realizing that you never really wanted `select` in the first place, that&#39;s a relic of the &quot;bash is looping and deciding what status I&#39;m looking for&quot; way of working. `tostring` is because jq objects can&#39;t have numbers as keys, only strings.",
                "title": "Counting instances of a value using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701200635,
                "creation_date": 1701200635,
                "answer_id": 77566760,
                "question_id": 77566633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alternatively, you could just group the responses and check the length of the groupings. This approach works well if you&#39;re just dumping the counts and not formatting as json.\r\n\r\n```\r\n$ jq -r &#39;group_by(.status)[] | &quot;\\(.[0].status)\\t\\(length)&quot;&#39; test.json\r\n```\r\n\r\nBut you can still format as json if you wanted, there&#39;s plenty of ways to skin this cat.\r\n```\r\n$ jq &#39;[group_by(.status)[] | {key:&quot;\\(.[0].status)&quot;, value:length}] | from_entries&#39; test.json\r\n```\r\n",
                "title": "Counting instances of a value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1701238863,
        "creation_date": 1701199376,
        "last_edit_date": 1701238863,
        "question_id": 77566633,
        "body_markdown": "I&#39;m trying to use `jq` to parse the output of some tool. Specifically I&#39;m looking for a count of various HTTP status codes in the output json. I.e. something like\r\n\r\n```\r\njq -c &#39;. | &lt;filter&gt;&#39; test.json\r\n{200: 1, 301: 1, 403: 1}\r\n```\r\n\r\nfrom the following input json\r\n```\r\n#test.json\r\n[\r\n    {\r\n        &quot;content-length&quot;: 45,\r\n        &quot;path&quot;: &quot;/foo&quot;,\r\n        &quot;redirect&quot;: null,\r\n        &quot;status&quot;: 200\r\n    },\r\n    {\r\n        &quot;content-length&quot;: 40,\r\n        &quot;path&quot;: &quot;/bar&quot;,\r\n        &quot;redirect&quot;: null,\r\n        &quot;status&quot;: 301\r\n    },\r\n    {\r\n        &quot;content-length&quot;: 1150,\r\n        &quot;path&quot;: &quot;/baz&quot;,\r\n        &quot;redirect&quot;: null,\r\n        &quot;status&quot;: 403\r\n    }\r\n]\r\n```\r\nI could just loop through in bash with something like\r\n```\r\n$ for i in 200 301 403; do echo -n $i &quot;    &quot;; jq &#39;[.[] | select(.status | tostring ==&quot;&#39;$i&#39;&quot;)] | length&#39; test.json ; done\r\n200     1\r\n301     1\r\n403     1\r\n```\r\nbut that seems inefficient. Trying to loop in `jq` feels like the better way to go, but the actual syntax to do it is a bit beyond me. I haven&#39;t had any luck finding exapmples, and I haven&#39;t had any luck trying to interpret the  man pages\r\n```\r\n$ jq &#39;[200, 301, 403] as $s | {$s: [.[] | select(.status == $s)] | length}&#39; test.json \r\njq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[200, 301, 403] as $s | {$s: [.[] | select(.status == $s)] | length}                           \r\njq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 1:\r\n[200, 301, 403] as $s | {$s: [.[] | select(.status == $s)] | length}                         \r\njq: 2 compile errors\r\n```\r\n\r\nThe python equivalent to what I want to do, in case that&#39;s clearer, is \r\n```\r\nimport json\r\nfrom collections import Counter\r\ndat = json.load(open(&quot;test.json&quot;))\r\nprint(Counter(d[&quot;status&quot;] for d in dat))&#39;\r\n# Counter({200: 1, 301: 1, 403: 1})\r\n```",
        "link": "https://stackoverflow.com/questions/77566633/counting-instances-of-a-value-using-jq",
        "title": "Counting instances of a value using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "md5"
        ],
        "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": 1701252857,
                "post_id": 77570196,
                "comment_id": 136751664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1701257024,
                "last_edit_date": 1701257024,
                "creation_date": 1701255812,
                "answer_id": 77570579,
                "question_id": 77570196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A variation of peak&#39;s [answer][1] from the linked question. Two invocations of `jq`, first for calculating the md5 hashes and then re-construct the calculated result back into the original JSON using `reduce`\r\n\r\n\r\n```bash\r\njq -r &#39;.ips[].macAddress&#39; input.json |\r\nwhile read -r line ; do printf &#39;%s&#39; &quot;$line&quot; | md5 ; done |\r\njq -s -R --slurpfile json input.json &#39;split(&quot;\\n&quot;)\r\n  | map(select(length&gt;0))\r\n  | . as $in\r\n  | reduce range(0;length) as $i ($json; .[].ips[$i].macAddress = $in[$i])&#39;\r\n```\r\n\r\nThe second `jq` invocation should be read carefully. The initial arguments `-s -R` are for reading the multi-line non JSON output created by the for-loop into jq&#39;s context. While the `--slurpfile` argument is needed for updating back the calculated hash into the original JSON. The slurp action takes the whole file into memory. \r\n\r\nSo as such this command, might not be effective for really large JSON files.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/48552825/5291015",
                "title": "How to update a value within an object with its md5 using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1701295201,
                "creation_date": 1701295201,
                "answer_id": 77574711,
                "question_id": 77570196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach could be to use `jq` to decompose the JSON into lines of scalars, then filter for and process relevant lines outside of `jq`, and eventually reassemble that stream with a second call to `jq`.\r\n\r\nHere&#39;s one example using `jq`&#39;s stream representation for the broken-down interstage, i.e. `jq -c . --stream` for the decomposition, and `jq -n &#39;fromstream(inputs)&#39;` for the reassembly, and `awk` for the actual processing, as it can easily read and filter by lines, alter parts of it, and shell out to perform external tasks. To filter for lines like `[[&quot;ips&quot;,0,&quot;macAddress&quot;],&quot;ac:5f:3e:87:d7:1a&quot;]` while waving through others like `[[&quot;ips&quot;,0,&quot;ip&quot;],&quot;1.2.3.4&quot;]` or `[[&quot;ips&quot;,0,&quot;macAddress&quot;]]`, a simple approach could be to interpret each line as columns separated by double quotes `&quot;`, then filter for columns 2 and 4 matching a given content, and column 6 not being empty (which could obviously improved for robustness; this is just an example), then replace column 6 (using `getline`) with the output of `printf %s` on the 6th column&#39;s value, followed by your `md5sum` and `cut` processing. (Tested with [onetrueawk/awk](https://github.com/onetrueawk/awk) version 20231124, and [GNU Awk](https://www.gnu.org/software/gawk/) 5.3.0.)\r\n\r\n```sh\r\njq -c . --stream input.json | awk &#39;\r\n  BEGIN { FS = OFS = &quot;\\&quot;&quot; }\r\n  $2 == &quot;ips&quot; &amp;&amp; $4 == &quot;macAddress&quot; &amp;&amp; $6 {\r\n    &quot;printf %s &quot; $6 &quot; | md5sum | cut -d \\\\  -f1&quot; | getline $6\r\n  }\r\n  1\r\n&#39; | jq -n &#39;fromstream(inputs)&#39;\r\n```\r\n\r\nHere&#39;s another, more robust example that &quot;manually&quot; decomposes the input into value and path, while also appending a flag to mark the scalars that need to be further processed (queried by the `jq` path expression `.ips[].macAddress`), into lines like `&quot;1.2.3.4&quot; [&quot;ips&quot;,0,&quot;ip&quot;] false` or `&quot;ac:5f:3e:87:d7:1a&quot; [&quot;ips&quot;,0,&quot;macAddress&quot;] true`. The processing part of this example then only utilizes POSIX-compliant shell features like `read` to iterate through the lines, a `case` statement to deflect based on that flag, and `tr` and parameter expansion to extract the IP (which is assumed to not contain spaces or escapes). The final `jq` composer then collects the lines using `reduce`, and successively builds up the output using `setpath`.\r\n\r\n```sh\r\njq -r &#39;\r\n  [ path(.ips[].macAddress) ] as $q\r\n  | paths(type | IN(&quot;object&quot;,&quot;array&quot;) | not) as $p\r\n  | @json &quot;\\(getpath($p)) \\($p) \\(IN($p;$q[]))&quot;\r\n&#39; input.json |\r\n\r\nwhile read -r line; do case &quot;$line&quot; in\r\n  *false) printf &#39;%s\\n&#39; &quot;$line&quot; ;;\r\n  *true) printf &#39;&quot;%s&quot; %s\\n&#39; &quot;$(printf &#39;%s&#39; &quot;${line%% *}&quot; | tr -d &#39;&quot;&#39; |\r\n         md5sum | cut -d &#39; &#39; -f1)&quot; &quot;${line#* }&quot; ;;\r\nesac; done |\r\n\r\njq -s &#39;reduce _nwise(3) as [$v,$p] (null; setpath($p;$v))&#39;\r\n```\r\n\r\nFor the given input, both examples output\r\n```json\r\n{\r\n  &quot;key&quot;: &quot;value&quot;,\r\n  &quot;ips&quot;: [\r\n    {\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;macAddress&quot;: &quot;45ee585278a0717c642ff2cb25a8e441&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;5.6.7.8&quot;,\r\n      &quot;macAddress&quot;: &quot;ab47bf90cb9f385127977569e676ce70&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;9.10.11.12&quot;,\r\n      &quot;macAddress&quot;: &quot;a5e9785db428e3956a47776dbd00fc91&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;13.14.15.16&quot;,\r\n      &quot;macAddress&quot;: &quot;f75d61937f70252ff139adee241daab4&quot;\r\n    }\r\n  ]\r\n}\r\n",
                "title": "How to update a value within an object with its md5 using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1702728264,
        "creation_date": 1701252510,
        "last_edit_date": 1702728264,
        "question_id": 77570196,
        "body_markdown": "Suppose I have the following JSON document (inspired by [this post][1])\r\n\r\n**Initial document**\r\n```json\r\n{\r\n  &quot;key&quot;: &quot;value&quot;,\r\n  &quot;ips&quot;: [\r\n    {\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:1a&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;5.6.7.8&quot;,\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:2a&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;9.10.11.12&quot;,\r\n      &quot;macAddress&quot;: &quot;ac:5f:3e:87:d7:3a&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;13.14.15.16&quot;,\r\n      &quot;macAddress&quot;: &quot;42:12:20:2e:2b:ca&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nNow I would like to read every `macAddress` pass it to a hash function (e.g. `md5sum`) and write the result back to the JSON document.\r\n\r\n**Desired output**\r\n\r\n```json\r\n{\r\n  &quot;key&quot;: &quot;value&quot;,\r\n  &quot;ips&quot;: [\r\n    {\r\n      &quot;ip&quot;: &quot;1.2.3.4&quot;,\r\n      &quot;macAddress&quot;: &quot;45ee585278a0717c642ff2cb25a8e441&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;5.6.7.8&quot;,\r\n      &quot;macAddress&quot;: &quot;ab47bf90cb9f385127977569e676ce70&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;9.10.11.12&quot;,\r\n      &quot;macAddress&quot;: &quot;a5e9785db428e3956a47776dbd00fc91&quot;\r\n    },\r\n    {\r\n      &quot;ip&quot;: &quot;13.14.15.16&quot;,\r\n      &quot;macAddress&quot;: &quot;f75d61937f70252ff139adee241daab4&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nCurrently I&#39;ve the following shell script, but I think it can be done more elegantly...preferably in a one-liner.\r\n\r\n```bash\r\njson_doc=&quot;{\\&quot;key\\&quot;: \\&quot;value\\&quot;, \\&quot;ips\\&quot;: [{\\&quot;ip\\&quot;:\\&quot;1.2.3.4\\&quot;,\\&quot;macAddress\\&quot;:\\&quot;ac:5f:3e:87:d7:1a\\&quot;},{\\&quot;ip\\&quot;:\\&quot;5.6.7.8\\&quot;,\\&quot;macAddress\\&quot;:\\&quot;ac:5f:3e:87:d7:2a\\&quot;},{\\&quot;ip\\&quot;:\\&quot;9.10.11.12\\&quot;,\\&quot;macAddress\\&quot;:\\&quot;ac:5f:3e:87:d7:3a\\&quot;},{\\&quot;ip\\&quot;:\\&quot;13.14.15.16\\&quot;,\\&quot;macAddress\\&quot;:\\&quot;42:12:20:2e:2b:ca\\&quot;}]}&quot;\r\n\r\nip_list=$(jq -c &#39;.ips[]&#39; &lt;&lt;&lt; &quot;$json_doc&quot; |\r\nwhile read -r jsonline ; do\r\n  hashmac=&quot;$(jq -s -j &#39;.[] | .macAddress&#39; &lt;&lt;&lt;&quot;$jsonline&quot; | md5sum | cut -d &#39; &#39; -f1)&quot;\r\n  jq --arg hashmac &quot;$hashmac&quot; -s -r &#39;.[] | .macAddress |= &quot;\\($hashmac)&quot;&#39; &lt;&lt;&lt;&quot;$jsonline&quot;\r\ndone | jq -s)\r\n\r\n# Update json document with ip list containing hashed mac addresses\r\njq --argjson ips &quot;$ip_list&quot; &#39;.ips = $ips&#39; &lt;&lt;&lt;&quot;$json_doc&quot;\r\n\r\n\r\n```\r\n\r\n  [1]: https://stackoverflow.com/q/38739648/9002073",
        "link": "https://stackoverflow.com/questions/77570196/how-to-update-a-value-within-an-object-with-its-md5-using-jq",
        "title": "How to update a value within an object with its md5 using jq?"
    },
    {
        "tags": [
            "bash",
            "sed",
            "jq",
            "substitution"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1701256717,
                "post_id": 77570671,
                "comment_id": 136752399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701266854,
                "last_edit_date": 1701266854,
                "creation_date": 1701266465,
                "answer_id": 77571807,
                "question_id": 77570671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU paste and sed or parallel):\r\n\r\n    cat &lt;&lt;\\! &gt;command.txt\r\n    jq &#39;.backups[] | select(.resource_name == &quot;resource_name&quot;) | {BackupTime: .updated_at, DiskName: .resource_name}&#39; js.json\r\n    !\r\n\r\n    cat &lt;&lt;\\! &gt;list.txt\r\n    apple\r\n    mango\r\n    grape\r\n    !\r\n\r\n    sed -n &#39;r command.tx&#39; list.txt | paste - list.txt | sed -E &#39;s/&quot;.*&quot;(.*)\\t(.*)/&quot;**\\2**&quot;\\1/e&#39;\r\n\r\nPut the jq  command in a text file\r\n\r\nPut the list in a text file.\r\n\r\nApply the piped sed/paste/sed invocations.\r\n\r\nThe first sed invocation, creates a file of commands the length of the list.\r\n\r\nThe invocation of paste, appends the list separated by a tab.\r\n\r\nThe second invocation of sed, uses pattern matching to substitute then evalute the resulting line.\r\n\r\nAnother solution would to be to use GNU parallel:\r\n\r\n    parallel -k jq &#39;.backups[] | select(.resource_name == &quot;**{}**&quot;) | {BackupTime: .updated_at, DiskName: .resource_name}&#39; js.json :::: list.txt",
                "title": "Substitue values in jq from a txt file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1701268277,
                "creation_date": 1701268277,
                "answer_id": 77572060,
                "question_id": 77570671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You mean like this?\r\n\r\n```\r\nwhile read -r resource; do\r\n    jq --arg resource &quot;$resource&quot; &#39;.backups[] |\r\n        select(.resource_name == $rname) |\r\n        {BackupTime: .updated_at, DiskName: .resource_name}&#39; js.json |\r\n    head -4\r\ndone &lt;list.txt\r\n```",
                "title": "Substitue values in jq from a txt file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1701268277,
        "creation_date": 1701256612,
        "last_edit_date": 1701268024,
        "question_id": 77570671,
        "body_markdown": "I&#39;m executing `jq` like this:\r\n```\r\njq &#39;.backups[] | select(.resource_name == &quot;resource_name&quot;) | {BackupTime: .updated_at, DiskName: .resource_name}&#39; js.json | head -4\r\n```\r\n\r\nIs there a way to substitute the `.resource_name` field with the strings in a text file and execute a `jq` for each line of substitution from the text file?\r\n\r\nFor example, I have `list.txt` file with the below contents:\r\n```none\r\napple\r\nmango\r\ngrapes\r\n```\r\nI want the `jq` command to be substituted as below:\r\n```\r\njq &#39;.backups[] | select(.resource_name == &quot;**apple**&quot;) | {BackupTime: .updated_at, DiskName: .resource_name}&#39; js.json | head -4\r\n```",
        "link": "https://stackoverflow.com/questions/77570671/substitue-values-in-jq-from-a-txt-file",
        "title": "Substitue values in jq from a txt file"
    },
    {
        "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": 2,
                "creation_date": 1701273704,
                "post_id": 77572717,
                "comment_id": 136755977,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16203497,
                    "reputation": 68,
                    "user_id": 11699325,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5f176d606aed2c6f05b18c16be2d2113?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Chakra",
                    "link": "https://stackoverflow.com/users/11699325/chakra"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1701274257,
                "post_id": 77572717,
                "comment_id": 136756091,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701275782,
                "creation_date": 1701275782,
                "answer_id": 77572994,
                "question_id": 77572717,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The data presented are not well-formed JSON.  Based on the command you say works for you on your input, I guess you must have an array of objects, the objects directly containing the keys you want to display or use for filtering.  That is, something more like this:\r\n```\r\n[\r\n   {\r\n      &quot;agent_installed&quot; : true,\r\n      &quot;agent_version&quot; : &quot;&quot;,\r\n      &quot;asset_tag&quot; : &quot;&quot;,\r\n      &quot;blueprint_id&quot; : &quot;&quot;,\r\n      &quot;blueprint_name&quot; : &quot;&quot;,\r\n      &quot;device_id&quot; : &quot;d35feff4-7867-268a-zet1-82caa4bcf5a0&quot;,\r\n      &quot;device_name&quot; : &quot;Spare&#39;s MacBook Air&quot;,\r\n      &quot;model&quot; : &quot;MacBook Air&quot;,\r\n      &quot;os_version&quot; : &quot;13.3.1&quot;,\r\n      &quot;platform&quot; : &quot;Mac&quot;,\r\n      &quot;serial_number&quot; : &quot;FK1VXASVRFS2E&quot;\r\n   },\r\n\r\n   ... other objects ...\r\n]\r\n```\r\n\r\n&gt; Is it possible with using jq to have a more specific return, for example i&#39;d like to display only the device_id of the devices that have the 13.3.1 version.\r\n\r\nI take you to be asking about selecting a subset of the array elements to report upon.  Yes, the [`select()`][1] function provides this capability.  Inserting an appropriate `select()` will allow you to filter your array&#39;s elements to include only those satisfying a condition you specify.  For example, for input structured as shown above, this ...\r\n```\r\njq &#39;.[] | select(.os_version == &quot;13.3.1&quot;) | .device_id&#39; input_file\r\n```\r\n... will print a sequence of JSON strings containing the `device_id` values of the array elements having `os_version` of &quot;13.3.1&quot;.\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.6/#select",
                "title": "How to use jq to parse and display specific variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1701275782,
        "creation_date": 1701273466,
        "last_edit_date": 1701273692,
        "question_id": 77572717,
        "body_markdown": "I want to display specific variables of a data table. \r\n\r\n```\r\n` [\r\n   {\r\n     {\r\n      &quot;agent_installed&quot; : true,\r\n      &quot;agent_version&quot; : &quot;&quot;,\r\n      &quot;asset_tag&quot; : &quot;&quot;,\r\n      &quot;blueprint_id&quot; : &quot;&quot;,\r\n      &quot;blueprint_name&quot; : &quot;&quot;,\r\n      &quot;device_id&quot; : &quot;d35feff4-7867-268a-zet1-82caa4bcf5a0&quot;,\r\n      &quot;device_name&quot; : &quot;Spare&#39;s MacBook Air&quot;,\r\n      &quot;model&quot; : &quot;MacBook Air&quot;,\r\n      &quot;os_version&quot; : &quot;13.3.1&quot;,\r\n      &quot;platform&quot; : &quot;Mac&quot;,\r\n      &quot;serial_number&quot; : &quot;FK1VXASVRFS2E&quot;,\r\n      \r\n      }\r\n   }\r\n]`\r\n```\r\n\r\nusing this command `jq -r &#39;.[] | &quot;device_id=\\(.device_id) os_version=\\(.os_version)&quot;&#39;`\r\nI&#39;m able to display the device_id and the os version after, now what i&#39;d like to know is this :\r\n\r\nIs it possible with using jq to have a more specific return, for example i&#39;d like to display only the device_id of the devices that have the 13.3.1 version.",
        "link": "https://stackoverflow.com/questions/77572717/how-to-use-jq-to-parse-and-display-specific-variables",
        "title": "How to use jq to parse and display specific variables"
    },
    {
        "tags": [
            "linux",
            "syntax",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20405057,
                    "reputation": 11,
                    "user_id": 14969843,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhO0jzqOWf3AwplLjvyWzfa2h2KoV9IclLx39bW=k-s256",
                    "display_name": "EulerTao",
                    "link": "https://stackoverflow.com/users/14969843/eulertao"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701405741,
                "post_id": 77583037,
                "comment_id": 136774282,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701415052,
                "post_id": 77583037,
                "comment_id": 136775109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20405057,
                    "reputation": 11,
                    "user_id": 14969843,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhO0jzqOWf3AwplLjvyWzfa2h2KoV9IclLx39bW=k-s256",
                    "display_name": "EulerTao",
                    "link": "https://stackoverflow.com/users/14969843/eulertao"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701428465,
                "post_id": 77583037,
                "comment_id": 136777156,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1701417786,
                "creation_date": 1701417786,
                "answer_id": 77583777,
                "question_id": 77583037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; If you want to merge these results into a single array, you need to wrap the entire expression with brackets [].\r\n\r\nOne way to avoid having to do so would be to avoid using `[]` after the call to `group_by`, so your filter would end with:\r\n```\r\ngroup_by(.school) | map({k:.[0].school, len:length})\r\n```\r\n\r\nHowever, since the jq program is quite long anyway, you probably\r\nshould consider putting it into a file and use jq&#39;s -f option.\r\n\r\nFor the record, it might be worth mentioning that if you&#39;re working at the command prompt and find yourself in the situation described, you can always simply pipe the stream into `jq -s`.\r\n\r\n",
                "title": "How to merge multiple results in jq? The array construction provided by default is not very convenient"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1702368726,
                "creation_date": 1702368726,
                "answer_id": 77644541,
                "question_id": 77583037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are working in a POSIX shell, you can pipe the output to another jq invocation:\r\n\r\n```\r\njq &#39;..... your long jq program producing a stream of object .....&#39; | jq -s\r\n```\r\n\r\n`-s` is &quot;slurp&quot;, which will put all objects from the input stream into a single array. [An alternative is appending `jq -n &#39;[inputs]&#39;`](https://stackoverflow.com/questions/73843868/difference-between-slurp-null-input-and-inputs-filter)",
                "title": "How to merge multiple results in jq? The array construction provided by default is not very convenient"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1702368726,
        "creation_date": 1701405478,
        "last_edit_date": 1701642510,
        "question_id": 77583037,
        "body_markdown": "For example, there is a group_by_count script.\r\n\r\n```\r\njq &#39;map(select(.sno|startswith(&quot;20&quot;)))|group_by(.school)[]|{k:.[0].school,len:length}&#39;\r\n```\r\n\r\nThe output of this command has multiple results like:\r\n\r\n```\r\n{k:xxx,len:111}{k:aaa,len:22}...\r\n```\r\n\r\nIf you want to merge these results into a single array, you need to wrap the entire expression with brackets `[]`. For example, you would write:\r\n\r\n```\r\njq &#39;[map(select(.sno|startswith(&quot;20&quot;)))|group_by(.school)[]|{k:.[0].school,len:length}]&#39;\r\n```\r\n\r\nNotice the top level `[]`.\r\n\r\nThis can be a bit cumbersome, especially in a terminal environment where moving the cursor can be inconvenient. Is there a simpler method, such as using the command:\r\n\r\n```\r\njq &#39;map(select(.sno|startswith(&quot;20&quot;)))|group_by(.school)[]|{k:.[0].school,len:length} | merge&#39;\r\n```\r\n\r\nThis way, for the user, it would be a matter of &quot;appending&quot; without the need to move the cursor.\r\n\r\nExpected output： \r\n```json\r\n[\r\n  {\r\n    &quot;k&quot;: &quot;xxx&quot;,\r\n    &quot;len&quot;: 111\r\n  },\r\n  {\r\n    &quot;k&quot;: &quot;aaa&quot;,\r\n    &quot;len&quot;: 22\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/77583037/how-to-merge-multiple-results-in-jq-the-array-construction-provided-by-default",
        "title": "How to merge multiple results in jq? The array construction provided by default is not very convenient"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2119809,
                    "reputation": 55131,
                    "user_id": 1883316,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/9yAAh.jpg?s=256",
                    "display_name": "Tim Roberts",
                    "link": "https://stackoverflow.com/users/1883316/tim-roberts"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1701410117,
                "post_id": 77583221,
                "comment_id": 136774627,
                "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": 1701415189,
                "post_id": 77583221,
                "comment_id": 136775133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1701439707,
                "last_edit_date": 1701439707,
                "creation_date": 1701411394,
                "answer_id": 77583318,
                "question_id": 77583221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is my shell command line with `jq`:\r\n\r\n```bash\r\ncat input.json insert.json | jq -s &quot;.[0] * (.[0].ressummary * .[1] | {ressummary:.})&quot;\r\n```\r\n```bash\r\ncat input.json insert.json | jq -s &quot;.[0].ressummary += .[1]|.[0]&quot;\r\n```\r\n\r\n`input.json`:\r\n```json\r\n{\r\n    &quot;resstart&quot;: 1700839261,\r\n    &quot;resend&quot;: 1700839965,\r\n    &quot;resop&quot;: &quot;SUCCESS&quot;,\r\n    &quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n    &quot;ressummary&quot;: {\r\n        &quot;value&quot;: 1,\r\n        &quot;expect&quot;: 0,\r\n        &quot;tool&quot;: &quot;abc&quot;\r\n    }\r\n}\r\n```\r\n`insert.json`:\r\n```json\r\n{\r\n    &quot;Check&quot;: [\r\n        {\r\n            &quot;Check&quot;: [\r\n                &quot;A_DOG&quot;,\r\n                &quot;A_CAT&quot;,\r\n                &quot;A_HORSE&quot;\r\n            ],\r\n            &quot;code&quot;: &quot;C/C++&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThe result:\r\n\r\n```json\r\n{\r\n  &quot;resstart&quot;: 1700839261,\r\n  &quot;resend&quot;: 1700839965,\r\n  &quot;resop&quot;: &quot;SUCCESS&quot;,\r\n  &quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n  &quot;ressummary&quot;: {\r\n    &quot;value&quot;: 1,\r\n    &quot;expect&quot;: 0,\r\n    &quot;tool&quot;: &quot;abc&quot;,\r\n    &quot;Check&quot;: [\r\n      {\r\n        &quot;Check&quot;: [\r\n          &quot;A_DOG&quot;,\r\n          &quot;A_CAT&quot;,\r\n          &quot;A_HORSE&quot;\r\n        ],\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\n## Explanation ##\r\n\r\nI am only explaining the first statement.\r\nThe correct `ressummary` we need:\r\n```json\r\n{\r\n...\r\n&quot;ressummary&quot;: {\r\n    &quot;value&quot;: 1,\r\n    &quot;expect&quot;: 0,\r\n    &quot;tool&quot;: &quot;abc&quot;,\r\n    &quot;Check&quot;: [\r\n      {\r\n        &quot;Check&quot;: [\r\n          &quot;A_DOG&quot;,\r\n          &quot;A_CAT&quot;,\r\n          &quot;A_HORSE&quot;\r\n        ],\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\nSo basically we just merge `insert.json` to the `ressummary`.\r\n```\r\n.[0].ressummary * .[1]\r\n```\r\nUsing this statement will make a JSON file looking like this.\r\n```json\r\n{\r\n  &quot;value&quot;: 1,\r\n  &quot;expect&quot;: 0,\r\n  &quot;tool&quot;: &quot;abc&quot;,\r\n  &quot;Check&quot;: [\r\n    {\r\n      &quot;Check&quot;: [\r\n        &quot;A_DOG&quot;,\r\n        &quot;A_CAT&quot;,\r\n        &quot;A_HORSE&quot;\r\n      ],\r\n      &quot;code&quot;: &quot;C/C++&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd this should be place under the `ressummary`:\r\n```\r\n.[0].ressummary * .[1] | {ressummary:.}\r\n```\r\nUsing this statement will get a JSON looking like this:\r\n```json\r\n{\r\n  &quot;ressummary&quot;: {\r\n    &quot;value&quot;: 1,\r\n    &quot;expect&quot;: 0,\r\n    &quot;tool&quot;: &quot;abc&quot;,\r\n    &quot;Check&quot;: [\r\n      {\r\n        &quot;Check&quot;: [\r\n          &quot;A_DOG&quot;,\r\n          &quot;A_CAT&quot;,\r\n          &quot;A_HORSE&quot;\r\n        ],\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nThen we can merge it to the original input.\r\n```\r\n.[0] * (.[0].ressummary * .[1] | {ressummary:.})\r\n```\r\nUse parentheses for priority arithmetic `.[0].ressummary * .[1] | {ressummary:.}`\r\n\r\n\r\nPS: Using `-s` with `jq` will make it read multiple inputs as an array like this:\r\n```json\r\n[\r\n  {\r\n    &quot;resstart&quot;: 1700839261,\r\n    &quot;resend&quot;: 1700839965,\r\n    &quot;resop&quot;: &quot;SUCCESS&quot;,\r\n    &quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n    &quot;ressummary&quot;: {\r\n      &quot;value&quot;: 1,\r\n      &quot;expect&quot;: 0,\r\n      &quot;tool&quot;: &quot;abc&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Check&quot;: [\r\n      {\r\n        &quot;Check&quot;: [\r\n          &quot;A_DOG&quot;,\r\n          &quot;A_CAT&quot;,\r\n          &quot;A_HORSE&quot;\r\n        ],\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nBut I still recommend using Python to handle JSON.",
                "title": "How to add key pair value to an existing json file if there are quotes"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1701416489,
                "creation_date": 1701416489,
                "answer_id": 77583678,
                "question_id": 77583221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is how you import data using jq:\r\n\r\n- use `--arg varname &quot;value&quot;` to have access to a jq variable `$varname` set to the string `value`\r\n- use `--args &quot;value1&quot; &quot;value2&quot; …` (as last arguments) to set the builtin `$ARGS.positional` to the string array `[&quot;value1&quot;, &quot;value2&quot;, …]`\r\n- use `.ressummary.Check = […]` to set the `Check` field to an array as defined (or `.ressummary.Check += […]` to append to that array)\r\n\r\n```sh\r\n#!/bin/bash\r\n\r\nccheck=(&quot;A_DOG&quot; &quot;A_CAT&quot; &quot;A_MOUSE&quot; &quot;A_HORSE&quot;)\r\ncode=&quot;C/C++&quot;\r\njq --arg code &quot;$code&quot; &#39;.ressummary.Check = [{Check: $ARGS.positional, $code}]&#39; \\\r\n   key.json --args &quot;${ccheck[@]}&quot;\r\n```\r\n```json\r\n{\r\n  &quot;resstart&quot;: 1700839261,\r\n  &quot;resend&quot;: 1700839965,\r\n  &quot;resop&quot;: &quot;SUCCESS&quot;,\r\n  &quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n  &quot;ressummary&quot;: {\r\n    &quot;value&quot;: 1,\r\n    &quot;expect&quot;: 0,\r\n    &quot;tool&quot;: &quot;abc&quot;,\r\n    &quot;Check&quot;: [\r\n      {\r\n        &quot;Check&quot;: [\r\n          &quot;A_DOG&quot;,\r\n          &quot;A_CAT&quot;,\r\n          &quot;A_MOUSE&quot;,\r\n          &quot;A_HORSE&quot;\r\n        ],\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "How to add key pair value to an existing json file if there are quotes"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1701439707,
        "creation_date": 1701409563,
        "last_edit_date": 1701425850,
        "question_id": 77583221,
        "body_markdown": "I have an existing key.json file that looks like this:  \r\n     key.json  \r\n\r\n```\r\n{\r\n&quot;resstart&quot;: 1700839261,\r\n&quot;resend&quot;: 1700839965,\r\n&quot;resop&quot;: &quot;SUCCESS&quot;,\r\n&quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n&quot;ressummary&quot;: {\r\n  &quot;value&quot;: 1,\r\n  &quot;expect&quot;: 0,\r\n  &quot;tool&quot;: &quot;abc&quot;\r\n },\r\n}\r\n\r\n```\r\n\r\n      \r\nI need to add the below section in my json under ressummary\r\n\r\n```\r\n&quot;Check&quot;: [\r\n   {\r\n       &quot;Check&quot;: &quot;[&quot;A_DOG&quot;,&quot;A_CAT&quot;, &quot;A_HORSE&quot;]&quot;,\r\n       &quot;code&quot;: &quot;C/C++&quot;\r\n   }\r\n  ]\r\n```\r\n\r\nSo the final json file should look like:\r\n\r\n```\r\n{\r\n&quot;resstart&quot;: 1700839261,\r\n&quot;resend&quot;: 1700839965,\r\n&quot;resop&quot;: &quot;SUCCESS&quot;,\r\n&quot;resurl&quot;: &quot;http://xxxx/&quot;,\r\n&quot;ressummary&quot;: {\r\n   &quot;value&quot;: 1,\r\n   &quot;expect&quot;: 0,\r\n   &quot;tool&quot;: &quot;abc&quot;\r\n   &quot;Check&quot;: [\r\n     {\r\n        &quot;Check&quot;: &quot;[&quot;A_DOG&quot;,&quot;A_CAT&quot;, &quot;A_MOUSE&quot;, &quot;A_HORSE&quot;]&quot;,\r\n        &quot;code&quot;: &quot;C/C++&quot;\r\n     }\r\n   ]\r\n },\r\n}\r\n```\r\n\r\n\r\nI am using shell script to generate the above json. My code is:\r\n\r\n    name=&quot;key&quot;\r\n    ccheck=(&quot;A_DOG&quot; &quot;A_CAT&quot; &quot;A_MOUSE&quot; &quot;A_HORSE&quot;)\r\n    echo &quot;{&quot;Check&quot;: { &quot;Check&quot;: &quot;\\[&#39;$ccheck[@]&#39;\\]&quot;, &quot;code&quot;: &quot;C/C++&quot;}}&quot; &gt;&gt; $name.json\r\n    sed -i &quot;s/&#39;/&quot;/g&quot; $name.json\r\n    cat $name.json\r\n\r\nI am getting the below error:\r\nparse error: jq 1 compile error\r\n\r\nCan anyone tell me how I can get the desired json file ? I would like to do this with jq. Is there a better way to do this? I have tried define ccheck as a string and array, but i am not getting the  &quot;&quot; and , either.",
        "link": "https://stackoverflow.com/questions/77583221/how-to-add-key-pair-value-to-an-existing-json-file-if-there-are-quotes",
        "title": "How to add key pair value to an existing json file if there are quotes"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701530393,
                "post_id": 77590943,
                "comment_id": 136788406,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3459564,
                    "reputation": 12006,
                    "user_id": 2897115,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/1b1b6d91bd48f68d9a33b468d74d2b08?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Santhosh",
                    "link": "https://stackoverflow.com/users/2897115/santhosh"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701530468,
                "post_id": 77590943,
                "comment_id": 136788416,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1701530585,
                "creation_date": 1701530585,
                "answer_id": 77590968,
                "question_id": 77590943,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `strings` to filter for strings, and `test` to have regex test return a boolean. The regex itself has to be a JSON string, so use `\\\\` for escaping.\r\n```sh\r\njq -c &#39;paths(strings | test(&quot;^\\\\s*$&quot;))&#39; input.json\r\n```\r\n```json\r\n[&quot;key1&quot;]\r\n[&quot;key2&quot;]\r\n[&quot;key3&quot;,&quot;key4&quot;]\r\n```\r\n[Demo](https://jqplay.org/s/Hz_Nzuu77qA)",
                "title": "how to select all paths which have empty or only space type strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1701532124,
        "creation_date": 1701530288,
        "last_edit_date": 1701532124,
        "question_id": 77590943,
        "body_markdown": "I have the following JSON\r\n```json\r\n{\r\n   &quot;key0&quot; : null,\r\n   &quot;key&quot;  : 1010,\r\n   &quot;key1&quot; : &quot;&quot;,\r\n   &quot;key2&quot; : &quot;  &quot;,\r\n   &quot;key3&quot; : {\r\n    &quot;key4&quot; : &quot;   &quot;,\r\n    &quot;key5&quot; : &quot;test&quot;\r\n   }\r\n}\r\n```\r\n\r\nI want to get all the paths of keys whose values are either empty string or string with only spaces\r\n\r\nI am trying\r\n\r\n```\r\npath(..|select(. == &quot;&quot;))\r\n```\r\n\r\nBut how to extend the above to regex like &quot;^\\s*&quot;  which can check all values with empty string or string with only spaces.",
        "link": "https://stackoverflow.com/questions/77590943/how-to-select-all-paths-which-have-empty-or-only-space-type-strings",
        "title": "how to select all paths which have empty or only space type strings"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1701703942,
                "post_id": 77600597,
                "comment_id": 136805570,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1701716322,
                "post_id": 77600597,
                "comment_id": 136807932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1701715135,
                "last_edit_date": 1701715135,
                "creation_date": 1701714739,
                "answer_id": 77601819,
                "question_id": 77600597,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re sure that .partitions is a non-empty array, you could go with:\r\n\r\n    jq -r &#39;.partitions[0].topic&#39; topic-json\r\n\r\nOtherwise, consider alternatives such as:\r\n\r\n    jq -r &#39;first(.partitions[].topic)&#39; topic-json\r\n\r\n----\r\n\r\nYour use of `jq -s` suggests that perhaps you might ultimately want the distinct topics, in which case you could go with something like:\r\n\r\n    jq -r &#39;[.partitions[].topic] | unique[]&#39; topic-json\r\n\r\n",
                "title": "captures specific value from Kafka topics json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1701716282,
        "creation_date": 1701703341,
        "last_edit_date": 1701716282,
        "question_id": 77600597,
        "body_markdown": "I am trying to capture the topic name - `TEST2` from the following `topic-json` file\r\n\r\n    more topic-json\r\n    {\r\n     &quot;version&quot;:1,\r\n     &quot;partitions&quot;:[\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:0,&quot;replicas&quot;:[1003,1002,1001]},\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:1,&quot;replicas&quot;:[1001,1003,1002]},\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:2,&quot;replicas&quot;:[1002,1001,1003]},\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:3,&quot;replicas&quot;:[1003,1001,1002]},\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:4,&quot;replicas&quot;:[1001,1002,1003]},\r\n    {&quot;topic&quot;:&quot;TEST2&quot;,&quot;partition&quot;:5,&quot;replicas&quot;:[1002,1003,1001]},\r\n    .\r\n    .\r\n    .\r\n\r\n\r\n\r\nso far I wrote the following in order to get the first elements but not succeeded to print only the `TEST2` name \r\n\r\n    /tmp/jq -s &#39;{ partitions: map(.partitions[1]) }&#39;  topic-json\r\n    {\r\n      &quot;partitions&quot;: [\r\n        {\r\n          &quot;topic&quot;: &quot;TEST2&quot;,\r\n          &quot;partition&quot;: 1,\r\n          &quot;replicas&quot;: [\r\n            1001,\r\n            1003,\r\n            1002\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nExpected output\r\n\r\n    TEST2\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77600597/captures-specific-value-from-kafka-topics-json-file",
        "title": "captures specific value from Kafka topics json file"
    },
    {
        "tags": [
            "json",
            "comparison",
            "jq",
            "semantic-versioning"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1701800315,
                "post_id": 77607580,
                "comment_id": 136819435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1701918776,
                "last_edit_date": 1701918776,
                "creation_date": 1701801538,
                "answer_id": 77608539,
                "question_id": 77607580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You always have the option of parsing and implementing the comparisons.\r\n\r\n```\r\ndef _parse_semver($with_op):\r\n    if type == &quot;string&quot; then\r\n        capture(if $with_op then &quot;(?&lt;op&gt;[~])?&quot; else &quot;&quot; end\r\n        + &quot;(?&lt;major&gt;\\\\d+)\\\\.(?&lt;minor&gt;\\\\d+)(?:\\\\.(?&lt;patch&gt;\\\\d+))?&quot;\r\n        + &quot;(?:-(?&lt;prerelease&gt;[A-Z0-9]+(?:\\\\.[A-Z0-9]+)*))?&quot;\r\n        + &quot;(?:\\\\+(?&lt;build&gt;[A-Z0-9]+(?:\\\\.[A-Z0-9]+)*))?&quot;; &quot;i&quot;)\r\n        | (.major, .minor, .patch) |= (tonumber? // 0)\r\n    elif type == &quot;object&quot; and ([has((&quot;major,minor,patch,prerelease,build&quot;/&quot;,&quot;)[])]|all) then .\r\n    else empty end;\r\ndef parse_semver: _parse_semver(false);\r\ndef cmp_semver($other): parse_semver as $a | ($other|_parse_semver(true)) as $b |\r\n    def _cmp($other): if . == $other then 0 elif . &gt; $other then 1 else -1 end;\r\n    def _cmp_dotted($other):\r\n        if . == null then 1\r\n        elif $other == null then -1\r\n        else\r\n            reduce ([split(&quot;.&quot;), ($other|split(&quot;.&quot;))] | transpose[]) as [$a, $b] (0;\r\n                if . != 0 then .\r\n                elif $a == null then -1\r\n                elif $b == null then 1\r\n                else\r\n                    ($a|test(&quot;^\\\\d+$&quot;)) as $anum | ($b|test(&quot;^\\\\d+$&quot;)) as $bnum |\r\n                    if [$anum,$bnum] == [true,true] then $a | tonumber | _cmp($b | tonumber)\r\n                    elif $anum then -1\r\n                    elif $bnum then 1\r\n                    else $a | _cmp($b) end\r\n                end\r\n            )\r\n        end;\r\n    # slightly modified version of https://semver.org/#spec-item-11\r\n    if $a.major != $b.major then\r\n        if $a.major &gt; $b.major then 1 else -1 end\r\n    elif $a.minor != $b.minor then\r\n        if $a.minor &gt; $b.minor then 1 else -1 end\r\n    elif $a.patch != $b.patch then\r\n        if $a.patch &gt; $b.patch then 1 else -1 end\r\n    elif $b.op == &quot;~&quot; then\r\n        0\r\n    elif $a.prerelease != $b.prerelease then\r\n        ($a.prerelease | _cmp_dotted($b.prerelease))\r\n    elif $a.build != $b.build then\r\n        ($a.build | _cmp_dotted($b.build))\r\n    else\r\n        0\r\n    end;\r\ndef cmp_semver($first; $second): $first | cmp_semver($second);\r\n```\r\n\r\nThen utilize the new comparison functions:\r\n\r\n```\r\n$ jq &#39;map(select(.version | cmp_semver(&quot;1.2.0&quot;) &gt; 0))&#39; input.json\r\n[                                                                                                                                     \r\n  {                                                                                                                                   \r\n    &quot;id&quot;: 1,                                                                                                                          \r\n    &quot;version&quot;: &quot;2.3.4&quot;                                                                                                                \r\n  },                                                                                                                                  \r\n  {                                                                                                                                   \r\n    &quot;id&quot;: 2,                                                                                                                          \r\n    &quot;version&quot;: &quot;1.4.4&quot;                                                                                                                \r\n  },                                                                                                                                  \r\n  {                                                                                                                                   \r\n    &quot;id&quot;: 4,                                                                                                                          \r\n    &quot;version&quot;: &quot;1.3.4&quot;                                                                                                                \r\n  }                                                                                                                                   \r\n]\r\n\r\n$ jq -rn &#39;(&quot;1.0.0-alpha&lt;1.0.0-alpha.1&lt;1.0.0-alpha.beta&lt;1.0.0-beta&lt;1.0.0-beta.2&lt;1.0.0-beta.11&lt;1.0.0-rc.1&lt;1.0.0&quot;/&quot;&lt;&quot;) as $input |\r\n    range($input | length-1) |\r\n    &quot;cmp_semver(\\($input[.]|tojson);\\t\\($input[.+1]|tojson))\\t-&gt; &quot;\r\n    + &quot;\\(cmp_semver($input[.]; $input[.+1]))&quot;&#39;\r\ncmp_semver(&quot;1.0.0-alpha&quot;;       &quot;1.0.0-alpha.1&quot;)        -&gt; -1                                                                         \r\ncmp_semver(&quot;1.0.0-alpha.1&quot;;     &quot;1.0.0-alpha.beta&quot;)     -&gt; -1                                                                         \r\ncmp_semver(&quot;1.0.0-alpha.beta&quot;;  &quot;1.0.0-beta&quot;)   -&gt; -1                                                                                 \r\ncmp_semver(&quot;1.0.0-beta&quot;;        &quot;1.0.0-beta.2&quot;) -&gt; -1                                                                                 \r\ncmp_semver(&quot;1.0.0-beta.2&quot;;      &quot;1.0.0-beta.11&quot;)        -&gt; -1                                                                         \r\ncmp_semver(&quot;1.0.0-beta.11&quot;;     &quot;1.0.0-rc.1&quot;)   -&gt; -1                                                                                 \r\ncmp_semver(&quot;1.0.0-rc.1&quot;;        &quot;1.0.0&quot;)        -&gt; -1                                                                                 \r\n```\r\n\r\n----\r\n\r\nAt first I wasn&#39;t sure if it was possible to use arrays as the semver key, but it appears it is possible, but requires some additional data points to sort on.\r\n\r\n```\r\ndef semver_key: parse_semver | [\r\n    .major, .minor, .patch,\r\n    .prerelease==null, ((.prerelease//&quot;&quot;)/&quot;.&quot;|map(tonumber? //.)),\r\n    .build==null, ((.build//&quot;&quot;)/&quot;.&quot;|map(tonumber? //.))\r\n];\r\n```\r\n\r\nThis allows you to sort by the versions.\r\n\r\n```\r\n$ jq -rn &#39;\r\n(&quot;1.0.0-alpha&lt;1.0.0-alpha.1&lt;1.0.0-alpha.beta&lt;1.0.0-beta&lt;1.0.0-beta.2&lt;1.0.0-beta.11&lt;1.0.0-rc.1&lt;1.0.0&quot;/&quot;&lt;&quot;) as $input |\r\n[$input, ($input | sort_by(semver_key))] | transpose[] | &quot;\\(.[0])\\t\\(.[1])&quot;\r\n&#39;\r\n1.0.0-alpha     1.0.0-alpha                                                                                                           \r\n1.0.0-alpha.1   1.0.0-alpha.1                                                                                                         \r\n1.0.0-alpha.beta        1.0.0-alpha.beta                                                                                              \r\n1.0.0-beta      1.0.0-beta                                                                                                            \r\n1.0.0-beta.2    1.0.0-beta.2                                                                                                          \r\n1.0.0-beta.11   1.0.0-beta.11                                                                                                         \r\n1.0.0-rc.1      1.0.0-rc.1                                                                                                            \r\n1.0.0   1.0.0                                                                                                                         \r\n```\r\n\r\nAssuming this works, this could simplify the `cmp_semver/1` function greatly.\r\n\r\n```\r\ndef cmp_semver2($other): semver_key as $a | ($other|semver_key) as $b |\r\n    if $a == $b then 0\r\n    elif $a &gt; $b then 1\r\n    else -1 end;\r\n```",
                "title": "Semver comparison using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1701817598,
                "last_edit_date": 1701817598,
                "creation_date": 1701810257,
                "answer_id": 77609223,
                "question_id": 77607580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you need to get all the objects where the version is &quot;1.2.0&quot;, you can use string comparison :\r\n\r\n```\r\njq --arg target 1.2.0 &#39;\r\n    map(select(.version == $target))&#39; input.json\r\n```\r\n\r\nIf you want the objects with version greater than 1.2.7, then:\r\n\r\n```\r\njq --arg target 1.2.7 &#39;\r\n    def triple($i): $i | [splits(&quot;[.-]&quot;) | tonumber? // .];\r\n    map(select(triple(.version) &gt; triple($target)))&#39; input.json\r\n```",
                "title": "Semver comparison using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1702357850,
                "last_edit_date": 1702357850,
                "creation_date": 1701813165,
                "answer_id": 77609434,
                "question_id": 77607580,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I know I could do some ugly regex hack here\r\n\r\nYou could also use a simple regex hack if the semver strings do not need to be checked for correctness.  For example, consider the following:\r\n```\r\n# Ignore build metadata as it is irrelevant for comparisons:\r\n# this means we can use == on the semver results to \r\n# determine equality of precedence.\r\n# Note also that the following accords with the requirements\r\n# about pre-release versions, notably:\r\n# &quot;Identifiers consisting of only digits are compared numerically.&quot;\r\n# &quot;Numeric identifiers always have lower precedence than non-numeric identifiers.&quot;\r\ndef semver:\r\n  sub(&quot;\\\\+.*&quot;;&quot;&quot;) | [scan(&quot;[^-.]+&quot;) | tonumber? // .];\r\n```\r\nSince a valid semver string always begins with three components none of which can have superfluous leading zeros, and since jq&#39;s built-in ordering is so friendly (as per the comment by @A.H.), `semver` as defined above should make it quite easy to compare valid semver strings. However, since the spec requires that &quot;pre-release&quot; &lt; &quot;release&quot;, some care is required for non-trivial semantic version strings:\r\n```\r\n# Compare two semver arrays ensuring in particular that:\r\n# pre-release &lt; release\r\n# identifiers with letters or hyphens are compared lexically in ASCII sort order;\r\n# numeric identifiers always have lower precedence than non-numeric identifiers.\r\ndef semver_less_than($array):\r\n  if .[:3] == $array[:3] and length &gt; 3 and ($array|length) == 3 then true\r\n  else . &lt; $array\r\n  end;\r\n```\r\nThe above is sufficient to pass the following sequence of tests included in the Semver 2.0 specification document:\r\n```\r\n1.0.0-alpha &lt; 1.0.0-alpha.1 &lt; 1.0.0-alpha.beta &lt; 1.0.0-beta &lt; 1.0.0-beta.2 &lt; 1.0.0-beta.11 &lt; 1.0.0-rc.1 &lt; 1.0.0.\r\n```\r\n\r\nHowever, since your example only has trivial semver specs, you could get away with:\r\n```\r\n# Filter for finding .version greater than 1.2.7 \r\n(&quot;1.2.7&quot; | semver) as $v\r\n| map(select( (.version|semver) &gt; $v))\r\n```\r\n---\r\n\r\nCaveat: It&#39;s quite likely the above needs some improvement.  Tweaks or counterexamples would be welcome.\r\n\r\n   ",
                "title": "Semver comparison using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1702357850,
        "creation_date": 1701791906,
        "last_edit_date": 1701815853,
        "question_id": 77607580,
        "body_markdown": "I have a array that looks like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;version&quot;: &quot;2.3.4&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;version&quot;: &quot;1.4.4&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;version&quot;: &quot;0.0.4&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;version&quot;: &quot;1.3.4&quot;\r\n  },\r\n]\r\n```\r\n\r\nAnd I need to get all the objects where the version is &quot;1.2.0&quot;.\r\nI am interested in a built in way using JQ but I cannot find anything related. Maybe it does not exist?\r\n\r\nI know I could do some ugly regex hack here, but what would be the right way to solve this so I can easily swap my condition so if instead of 1.2.0 maybe in a short time in the future lets say I want the objects with version greater than 1.2.7 for instance?",
        "link": "https://stackoverflow.com/questions/77607580/semver-comparison-using-jq",
        "title": "Semver comparison using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1701832187,
                "last_edit_date": 1701832187,
                "creation_date": 1701831763,
                "answer_id": 77610328,
                "question_id": 77610317,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Each time you use `.details[]`, another iteration is performed (in the context of the previous one). Factor it out, and perform your operations in a subcontext. Here&#39;s an example using the [update operator](https://jqlang.github.io/jq/manual/#update-assignment) `|=`:\r\n```sh\r\n.details[] |= (.enginetype = .engine.type | del(.engine.type))\r\n```\r\n[Demo](https://jqplay.org/s/7pCYndyMlSH)\r\n\r\nNote: To remove the entire `.engine` field, replace `del(.engine.type)` with `del(.engine)`. Or use a positive approach by defining what (else) to keep (the `.type` field in this case): `.details[] |= {type, enginetype: .engine.type}`.",
                "title": "JQ - Flattening keys in array gives cartesian product"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1701874427,
        "creation_date": 1701831452,
        "last_edit_date": 1701874427,
        "question_id": 77610317,
        "body_markdown": "I have some json which i&#39;m trying to simplify:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;vehicles&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;passenger&quot;,\r\n      &quot;engine&quot;: {\r\n        &quot;type&quot;: &quot;electric&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;commercial&quot;,\r\n      &quot;engine&quot;: {\r\n        &quot;type&quot;: &quot;diesel&quot;\r\n      }\r\n    }\r\n```\r\n\r\nI want engine.type to become engineType.  So I&#39;m trying to add a new field, then delete the old one:\r\n\r\n`echo $json|jq &#39;(.details[].engineType = .details[].engine.type)|del(.details[].engine.type)&#39;`\r\n\r\nBut this is giving me a cartesian product:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;vehicles&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;passenger&quot;,\r\n      &quot;engine&quot;: {},\r\n      &quot;engineType&quot;: &quot;electric&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;commercial&quot;,\r\n      &quot;engine&quot;: {},\r\n      &quot;engineType&quot;: &quot;electric&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;vehicles&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;passenger&quot;,\r\n      &quot;engine&quot;: {},\r\n      &quot;engineType&quot;: &quot;diesel&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;commercial&quot;,\r\n      &quot;engine&quot;: {},\r\n      &quot;engineType&quot;: &quot;diesel&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m sure the fix is simple, but I can&#39;t work out the right way to do this.  \r\n\r\nAny ideas?\r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/77610317/jq-flattening-keys-in-array-gives-cartesian-product",
        "title": "JQ - Flattening keys in array gives cartesian product"
    },
    {
        "tags": [
            "json",
            "docker-compose",
            "yaml",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1702305832,
                "last_edit_date": 1702305832,
                "creation_date": 1702116401,
                "answer_id": 77630883,
                "question_id": 77629210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given `file`:\r\n\r\n```yaml\r\nname: movies-docker-test\r\nservices:\r\n  movies-rp:\r\n    volumes:\r\n      - type: volume\r\n        source: conf\r\n        target: /etc/nginx/conf.d\r\n      - type: volume\r\n        source: certs\r\n        target: /etc/nginx/certs\r\n        read_only: true\r\n      - type: bind\r\n        source: /home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/uploadsize.conf\r\n        target: /etc/nginx/conf.d/uploadsize.conf\r\n      - type: bind\r\n        source: /home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template\r\n        target: /etc/nginx/templates/wikibase.conf.template\r\n```\r\n\r\nthen, using `yq 4.40.3`:\r\n\r\n```bash\r\n$ yq e &#39;select(.services.*.volumes | select(tag == &quot;!!seq&quot;)|=sort_by(.type))&#39; file\r\n```\r\n```yaml\r\nname: movies-docker-test\r\nservices:\r\n  movies-rp:\r\n    volumes:\r\n      - type: bind\r\n        source: /home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/uploadsize.conf\r\n        target: /etc/nginx/conf.d/uploadsize.conf\r\n      - type: bind\r\n        source: /home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template\r\n        target: /etc/nginx/templates/wikibase.conf.template\r\n      - type: volume\r\n        source: conf\r\n        target: /etc/nginx/conf.d\r\n      - type: volume\r\n        source: certs\r\n        target: /etc/nginx/certs\r\n        read_only: true\r\n```\r\n",
                "title": "sort and update a docker-compose.yaml with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1702309102,
                "creation_date": 1702309102,
                "answer_id": 77640697,
                "question_id": 77629210,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here is what I successfully tested with &#39;&#39;yq&#39;&#39; and the wrapped &#39;&#39;jq&#39;&#39; syntax\r\n```bash\r\nyq &#39;.services|=with_entries(.value|=(select(has(&quot;volumes&quot;)).volumes |= sort_by((.type)) ))&#39; docker-compose.yml\r\n```\r\nor what I initially did with regular &#39;&#39;jq&#39;&#39;\r\n\r\n```bash\r\ncat movies.yml | yq eval -ojson |  jq &#39;.services|=with_entries(.value|=(select(has(&quot;volumes&quot;)).volumes |= sort_by((.type)) ))&#39; | yq -P\r\n```\r\n",
                "title": "sort and update a docker-compose.yaml with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1702309102,
        "creation_date": 1702070158,
        "last_edit_date": 1702308877,
        "question_id": 77629210,
        "body_markdown": "This is my docker-compose file:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;movies-docker-test&quot;,\r\n  &quot;services&quot;: {\r\n    &quot;movies-rp&quot;: {\r\n      &quot;volumes&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;volume&quot;,\r\n          &quot;source&quot;: &quot;certs&quot;,\r\n          &quot;target&quot;: &quot;/etc/nginx/certs&quot;,\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;bind&quot;,\r\n          &quot;source&quot;: &quot;/home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template&quot;,\r\n          &quot;target&quot;: &quot;/etc/nginx/templates/wikibase.conf.template&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nI&#39;d like to update this file so that each `volumes` of each `service` to be sorted by the &#39;.type&#39;:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;movies-docker-test&quot;,\r\n  &quot;services&quot;: {\r\n    &quot;movies-rp&quot;: {\r\n      &quot;volumes&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;bind&quot;,\r\n          &quot;source&quot;: &quot;/home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template&quot;,\r\n          &quot;target&quot;: &quot;/etc/nginx/templates/wikibase.conf.template&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;volume&quot;,\r\n          &quot;source&quot;: &quot;certs&quot;,\r\n          &quot;target&quot;: &quot;/etc/nginx/certs&quot;\r\n        }\r\n      ]\r\n    }\r\n  \r\n```\r\nI managed to do this, but the file is not updated:\r\n```bash\r\njq  &#39;[.services[].volumes[]?]|sort_by(.type)&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/77629210/sort-and-update-a-docker-compose-yaml-with-jq",
        "title": "sort and update a docker-compose.yaml with jq"
    },
    {
        "tags": [
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1702367935,
                "post_id": 77644442,
                "comment_id": 136884265,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22146663,
                    "reputation": 31,
                    "user_id": 16395786,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c1a4ec4debc159c879f7472cd87bcff8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "hola",
                    "link": "https://stackoverflow.com/users/16395786/hola"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1702368390,
                "post_id": 77644442,
                "comment_id": 136884324,
                "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": 1702371076,
                "post_id": 77644442,
                "comment_id": 136884773,
                "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": 1702373562,
                "post_id": 77644442,
                "comment_id": 136885217,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702386595,
                "last_edit_date": 1702386595,
                "creation_date": 1702373461,
                "answer_id": 77644957,
                "question_id": 77644442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The issue you are seeing is because of using `$ENV` or `env` inside double-quotes, which is [interpolated as a string][1] in `jq` and its value is emitted out literally. You need to use them inside single quotes or use the syntax for expression evaluation i.e. `\\(..)`\r\n\r\n```bash\r\njq &#39;.value[] | &quot;\\($ENV.name), \\(.id), \\(.startTime), \\(.finishTime)&quot;&#39;\r\n```\r\n\r\nor) store the value in a temporary variable and evaluate it inside the double-quotes.\r\n\r\n\r\n```bash\r\njq &#39;$ENV.name as $v | .value[] | &quot;\\($v), \\(.id), \\(.startTime), \\(.finishTime)&quot;&#39;\r\n```\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#string-interpolation",
                "title": "Accessing an environment variable with ENV inside a quoted string is not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1702588614,
        "creation_date": 1702367733,
        "last_edit_date": 1702588614,
        "question_id": 77644442,
        "body_markdown": "\r\n\r\n    cat /home/azure/fourkeys/deploy.json |jq  &#39;.value[]|  &quot;build, \\(.id), \\(.startTime), \\(.finishTime)&quot;&#39;\r\n    &quot;build, 7765709, 2023-12-05T09:19:44.8090261Z, 2023-12-05T09:23:11.4171119Z&quot;\r\n\r\n\r\nI wish to replace build with shell variables.\r\n\r\n\r\n     export name=&quot;build&quot;\r\n\r\n\r\nI tried to pass shell variable in cli, didn&#39;t work as below:\r\n\r\n \r\n\r\n    cat /home/azure/fourkeys/deploy.json |jq  &#39;.value[]|  &quot;$ENV.name, \\(.id), \\(.startTime), \\(.finishTime)&quot;&#39;\r\n    &quot;$ENV.name, 7765709, 2023-12-05T09:19:44.8090261Z, 2023-12-05T09:23:11.4171119Z&quot;\r\n\r\njson file:\r\n\r\n\r\n```json\r\n{\r\n  &quot;count&quot;: 1,\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: 7765709,\r\n      &quot;buildNumber&quot;: &quot;20231205.2&quot;,\r\n      &quot;status&quot;: &quot;completed&quot;,\r\n      &quot;result&quot;: &quot;succeeded&quot;,\r\n      &quot;queueTime&quot;: &quot;2023-12-05T09:19:39.1877578Z&quot;,\r\n      &quot;startTime&quot;: &quot;2023-12-05T09:19:44.8090261Z&quot;,\r\n      &quot;finishTime&quot;: &quot;2023-12-05T09:23:11.4171119Z&quot;,\r\n      &quot;url&quot;: &quot;https://dev.azure.com/slb1-swt/68bde508-a9d3-43ca-ae50-1ad38b747a65/_apis/build/Builds/7765709&quot;\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77644442/accessing-an-environment-variable-with-env-inside-a-quoted-string-is-not-working",
        "title": "Accessing an environment variable with ENV inside a quoted string is not working"
    },
    {
        "tags": [
            "json",
            "object",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1702486478,
                "last_edit_date": 1702486478,
                "creation_date": 1702459563,
                "answer_id": 77652363,
                "question_id": 77652021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can try:\r\n\r\n```bash\r\n$ jq &#39;group_by(.name) \r\n| map(first + {ip: map(.ip) | unique} \r\n            + {key: map(.kv_key) | unique}\r\n            + {value: map(.kv_value) | unique}) \r\n| map(. + {key_value: [.key,.value] | transpose | map({(.[0]):.[1]}) | add}) \r\n| map(del(.key,.value,.kv_key,.kv_value))&#39; file\r\n\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: [\r\n      &quot;192.168.0.1&quot;,\r\n      &quot;192.168.0.2&quot;\r\n    ],\r\n    &quot;location&quot;: &quot;here&quot;,\r\n    &quot;key_value&quot;: {\r\n      &quot;test1_key&quot;: &quot;test1_value&quot;,\r\n      &quot;test2_key&quot;: &quot;test2_value&quot;,\r\n      &quot;test3_key&quot;: &quot;test3_value&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "Merge json objects into one"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702461773,
                "last_edit_date": 1702461773,
                "creation_date": 1702459757,
                "answer_id": 77652386,
                "question_id": 77652021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If all items have the same keys, you can make this generic by using `to_entries` to split the objects into an array of key-value pairs, `transpose` them, and combine them again using `from_entries`. Duplicate values can be eliminated using `unique`, and singletons can be generated by checking for the presence of a second item using `select(has(1))`:\r\n```sh\r\ngroup_by(.name) | map(map(to_entries) | transpose | map(first + {value: (\r\n  map(.value) | unique | select(has(1)) // first\r\n)}) | from_entries)\r\n```\r\n\r\nTo account for merging `.kv_key` - `.kv_value` pairs into objects under a new `.key_value` key, you can make the conversion beforehand, and then collapse all object-only arrays found by `select(all(type == &quot;object&quot;))` into one object using `add`:\r\n```sh\r\nmap(del(.kv_key, .kv_value) + {key_value: {(.kv_key): .kv_value}})\r\n| group_by(.name) | map(map(to_entries) | transpose | map(first + {value: (\r\n    map(.value) | unique | select(all(type == &quot;object&quot;)) |= [add]\r\n    | select(has(1)) // first\r\n  )}) | from_entries)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: [\r\n      &quot;192.168.0.1&quot;,\r\n      &quot;192.168.0.2&quot;\r\n    ],\r\n    &quot;location&quot;: &quot;here&quot;,\r\n    &quot;key_value&quot;: {\r\n      &quot;test1_key&quot;: &quot;test1_value&quot;,\r\n      &quot;test2_key&quot;: &quot;test2_value&quot;,\r\n      &quot;test3_key&quot;: &quot;test3_value&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/IjYFRtSFoig)",
                "title": "Merge json objects into one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1702486270,
                "last_edit_date": 1702486270,
                "creation_date": 1702481738,
                "answer_id": 77654791,
                "question_id": 77652021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here’s a straightforward approach that makes no assumptions about the keys in any of the objects. It uses a generic function that might also be useful elsewhere:\r\n\r\n```\r\ndef meld($obj): \r\n   reduce ($obj|keys_unsorted[]) as $k(.; \r\n    if has($k)|not then .[$k] = $obj[$k] \r\n    elif .[$k] == $obj[$k] then . \r\n    else ( .[$k] | type) as $t \r\n    | if $t == &quot;array&quot; then .[$k] += [$obj[$k]] \r\n      else .[$k]=[ .[$k], $obj[$k]] \r\n      end \r\n    end); \r\n\r\n reduce .[] as $x ({}; meld($x))\r\n```\r\nThis is a quasi-lossless solution. You could easily modify it e.g. to use `unique` or otherwise handle duplicate values.\r\n\r\n",
                "title": "Merge json objects into one"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1702754676,
                "last_edit_date": 1702754676,
                "creation_date": 1702754360,
                "answer_id": 77672187,
                "question_id": 77652021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My take on this is:\r\n\r\n```\r\ngroup_by(.name)\r\n| map(\r\n    reduce .[] as $e(\r\n        first | del(.ip, .kv_key, .kv_value);\r\n        .ip += [ $e.ip ]\r\n        | .key_value[$e.kv_key] = $e.kv_value\r\n    )\r\n    | .ip |= unique\r\n)\r\n```\r\n\r\n- First `group_by(.name)` build the appropriate group.\r\n- After that each group is handled individually:\r\n- Take the first element of each group as a template but remove some things\r\n- Incrementally add stuff to the template using the iteration variable `$e`\r\n- Fixup `ip` by making it unique.\r\n",
                "title": "Merge json objects into one"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1702754676,
        "creation_date": 1702456105,
        "last_edit_date": 1702509654,
        "question_id": 77652021,
        "body_markdown": "I&#39;m trying to merge some json objects using jq.\r\n\r\nIt seems too complicated for me ^^\r\n\r\nI have a JSON which looks like this\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: &quot;192.168.0.1&quot;,\r\n    &quot;kv_key&quot;: &quot;test2_key&quot;,\r\n    &quot;kv_value&quot;: &quot;test2_value&quot;,\r\n    &quot;location&quot;: &quot;here&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: &quot;192.168.0.2&quot;,\r\n    &quot;kv_key&quot;: &quot;test1_key&quot;,\r\n    &quot;kv_value&quot;: &quot;test1_value&quot;,\r\n    &quot;location&quot;: &quot;here&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: &quot;192.168.0.1&quot;,\r\n    &quot;kv_key&quot;: &quot;test2_key&quot;,\r\n    &quot;kv_value&quot;: &quot;test2_value&quot;,\r\n    &quot;location&quot;: &quot;here&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: &quot;192.168.0.1&quot;,\r\n    &quot;kv_key&quot;: &quot;test3_key&quot;,\r\n    &quot;kv_value&quot;: &quot;test3_value&quot;,\r\n    &quot;location&quot;: &quot;here&quot;\r\n  }\r\n]\r\n```\r\n\r\nAnd I want something like this\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test_name&quot;,\r\n    &quot;cpu&quot;: &quot;1&quot;,\r\n    &quot;ip&quot;: [\r\n\t\t&quot;192.168.0.1&quot;,\r\n\t\t&quot;192.168.0.2&quot;\r\n\t],\r\n\t&quot;key_value&quot;: [\r\n\t\t{\r\n\t\t\t&quot;test1_key&quot;: &quot;test1_value&quot;,\r\n\t\t\t&quot;test2_key&quot;: &quot;test2_value&quot;,\r\n\t\t\t&quot;test3_key&quot;: &quot;test3_value&quot;\r\n\t\t}\r\n\t],\r\n    &quot;location&quot;: &quot;here&quot;\r\n  }\r\n]\r\n```\r\n\r\nI managed to make something work for the ip field only\r\n\r\n```\r\njq &#39;map(. |= (group_by(.name) | map(first + {ip: map(.ip)})))&#39; &lt;&lt;&lt; &quot;${json}&quot;\r\n```\r\n\r\nProbably not the best way to do this and I&#39;m clearly stuck on the key/value part.\r\n\r\nThx for you help !\r\n\r\namans\r\n",
        "link": "https://stackoverflow.com/questions/77652021/merge-json-objects-into-one",
        "title": "Merge json objects into one"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1702564625,
                "last_edit_date": 1702564625,
                "creation_date": 1702564231,
                "answer_id": 77660860,
                "question_id": 77660782,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use:\r\n\r\n```bash\r\n$ jq --arg dd &quot;$d&quot; &#39;.features[].properties += {date_added: $dd}&#39; file\r\n```",
                "title": "Using jq to add aditional key-value pairs to json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1702564625,
        "creation_date": 1702563325,
        "last_edit_date": 1702564486,
        "question_id": 77660782,
        "body_markdown": "I have this json.\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              [\r\n                4.991669,\r\n                52.324436,\r\n                0\r\n              ]\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;neighbourhood&quot;: &quot;Bijlmer-Oost&quot;,\r\n        &quot;neighbourhood_group&quot;: null\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              [\r\n                5.079162,\r\n                52.388654,\r\n                0\r\n              ]\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;neighbourhood&quot;: null,\r\n        &quot;neighbourhood_group&quot;: null\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I want is to add to the properties part a new key-value pair.\r\nSomeone could help me to figure it out what is the best way to do this?\r\n\r\nI tried with this:\r\n```jq --arg dd &quot;$d&quot; &#39;.features[] |= . + {properties: download_date: $dd}&#39; /tmp/file-$d.geojson```\r\n\r\n\r\nBut this is updates the whole properites like this:\r\n&quot;properties&quot;: {\r\n        &quot;download_date&quot;: &quot;2023-03-09&quot;\r\n      }\r\n\r\n\r\nExpected result should look like this:\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              [\r\n                4.991669,\r\n                52.324436,\r\n                0\r\n              ]\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;neighbourhood&quot;: &quot;Bijlmer-Oost&quot;,\r\n        &quot;neighbourhood_group&quot;: null,\r\n        &quot;date_added&quot;: &quot;2022-01-01&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;MultiPolygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              [\r\n                5.079162,\r\n                52.388654,\r\n                0\r\n              ]\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;neighbourhood&quot;: null,\r\n        &quot;neighbourhood_group&quot;: null,\r\n        &quot;date_added&quot;: &quot;2022-01-01&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77660782/using-jq-to-add-aditional-key-value-pairs-to-json",
        "title": "Using jq to add aditional key-value pairs to json"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1702758611,
                "last_edit_date": 1702758611,
                "creation_date": 1702757761,
                "answer_id": 77672357,
                "question_id": 77672251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is how I would create the desired output:\r\n- `tostream` produces a stream of path-only items and path-value pairs; filter for those having a value (using `select(has(1))`) to get the scalars (alternatively, use `paths(scalars)` and `getpath`)\r\n- in the path array, strings represent object fields, numbers represent array indices; convert them separately using `strings` and `numbers`, respectively, then prepend the dot (since jq 1.7, a dot preceding array indices in brackets is valid syntax even in concatenated expressions)\r\n```sh\r\ntostream | select(has(1))  # or: paths(scalars) as $p | [$p, getpath($p)]\r\n| &quot;\\(first | map(&quot;.\\(&quot;[\\(numbers)]&quot; // strings|=@json)&quot;) | add) = \\(last|@json)&quot;\r\n```\r\n[Demo](https://jqplay.org/s/TbE97EehbOg)",
                "title": "Using jq to shows all possible jq paths and their values and handle cases where numbers are object keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1702825319,
        "creation_date": 1702755583,
        "question_id": 77672251,
        "body_markdown": "Working off of https://github.com/jqlang/jq/issues/243, I&#39;ve got an almost complete solution to be able to generate the jq paths to access all elements within a json object. But unfortunately it isnt producing a valid jq path if there is an object key is a number.\r\n\r\nThe path to the object key needs to be quoted to be correctly handled, but I cant seem to get the syntax correct.\r\n\r\nThe query looks like:\r\n\r\n\r\n```\r\n# source: https://github.com/jqlang/jq/issues/243\r\n\r\ndef path2text($value):\r\n  def tos: if type == &quot;number&quot; then . else (tojson) end;\r\n  reduce .[] as $segment (&quot;&quot;;  .\r\n    + ($segment\r\n       | if type == &quot;string&quot; then &quot;.&quot; + . else &quot;[\\(.)]&quot; end))\r\n  + &quot; = \\($value | tos)&quot;;\r\n  \r\n\r\npaths(scalars) as $p\r\n  | getpath($p) as $v\r\n  | $p | path2text($v)\r\n```\r\n\r\nA sample json object showing the problem is:\r\n\r\n```\r\n{ &quot;00&quot; : &quot;a&quot; }\r\n```\r\n\r\n[The query will produce](https://www.devtoolsdaily.com/jq_playground/?#v2=N4IglgdgDgrgLgFQKYA84gFwmAAgDogAMhBOG+IAhqQL4gA0IAZmADZxIBOAoilJ5hAATJExxRKcABYAmDmgAUAEgBulVjCQBKDHgg4cIsXAD2AZ3JhjATyhIcAXgcUIMALYAjLqWlJ9AOhwkVjN7BVMAKzMTCC0giCEAbj0DTiQhGABje38AbQBdHEozHCVQgHM3PzgcBQICRIN-FIMcAGpasqRK6pbWgwAfHCscOFt7JwozOE5Icp8pPwpmkHacQODQily8PAV-LXzSPyEtLRaO0mdd5TUNeyHTM3OQZP18CD0JaTMFM0z1JROM8iiUlFAWkNykg4N8pMooHFiqUVJDSlAcEM4XJUHBbloGCBOJQAO4AeXgsHQGCY6lCNCAA):\r\n```\r\n&quot;.00 = \\&quot;a\\&quot;\r\n```\r\n\r\nBut using that filter on the same object will produce the following error:\r\n```\r\n1 compile error\r\njq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n[0].0   \r\njq: 1 compile error\r\n```\r\n\r\nThe correct filter should be:\r\n```\r\n.&quot;00&quot;\r\n```\r\n\r\nI&#39;ve made a couple attempts trying to use the test function and a regex, but I can&#39;t quite get it right. My closest version is:\r\n\r\n```\r\ndef quote_string_numbers($data):\r\n   if (test(&quot;\\\\.\\\\d+&quot;) or test(&quot;\\\\d+&quot;)) then &quot;\\&quot;&quot; + . + &quot;\\&quot;&quot; else . end;\r\n\r\ndef path2text($value):\r\n  def tos: if type == &quot;number&quot; then . else tojson end;\r\n  reduce .[] as $segment (&quot;&quot;;  .\r\n    + ($segment\r\n       | if type == &quot;string&quot; then \r\n            quote_string_numbers(&quot;.&quot; + .) else &quot;[\\(.)]&quot; end))\r\n  + &quot; = \\($value | tos)&quot;;\r\n\r\npaths(scalars) as $p\r\n  | getpath($p) as $v\r\n  | $p | path2text($v)\r\n```\r\n\r\nBut that still isnt quite right and while it produces [correct results for my example](https://www.devtoolsdaily.com/jq_playground/?#v2=N4IglgdgDgrgLgFQKYA84gFwmAAgDogAMhBOG+IAhqQL4gA0IAZmADZxIBOAoilJ5hAATJExwBHGAHsOAfQDOcTpADmsiDAC2AIy7yAFABIhlOJQCUGPBBy2wY-R0X6CeN3gB07vEIDUBcxwpThwnOBcQbz8AwLgACyQbVzdIkBxfHA90indUnCRWeSRM-IghAG5raxExKFM4gCYONCMAN0pWGCRLa1sa0Kl5cntQgE8oYoBeSYoNHS5SeMSSgqKBgCt5KRtEit6cTiQhGABjYo8AbQBdHEp5HEMilU1EuBwIgnLbLxtbbKMni8IHB9n9bAAfHAjODjKYzAiKZQQFSLBJJX5gzESaRyRGqdRaXScAwELxpDIeQKrYoEC5ufSUq6kXbmcz7DKkeF4NodLo4SFwQZskCVCDWOrxAzyE4dSjEwJ3B5QfaQlRIOASuJGKAK+6GVoqpX8nCapqocL68wMECcSgAdwA8vBYOgMEwOkUaEA).\r\n```\r\n&quot;\\&quot;00\\&quot; = \\&quot;a\\&quot;&quot;\r\n```\r\n\r\nBut it doesnt for a more complex case:\r\n```\r\n{ &quot;00&quot; : {&quot;02&quot; : &quot;a&quot;, &quot;banana&quot; : &quot;foo&quot; }}\r\n```\r\n\r\n[instead it produces](https://www.devtoolsdaily.com/jq_playground/?#v2=N4IglgdgDgrgLgFQKYA84gFwmAAgDogAMhBOGOwBhATKeQQIYEA0+IARgxF0yGWwDMA9kNIBfMSGYgBYADZwkAJwCiKKEswgAJkgE4AjjCGKA+gGc4SyAHNTEGAFt2y8wAoAJNoZwGASgw8CBwQsH03RUs3AjxYvAA6OLxtAGoCPxwhJRxIuGiQJNT0jLgACyRgmNiCvhSceJw6qpi+JDlzJHqcCu0AbiCg3X0oH1LqRTRPADcGORgkAKCQoZyhc3IwnIBPKE6AXj22B2dlUjKKrraO1YArcyFgnv7gnCUkbRgAY074gG0AXRwDHMOA8HRsjgqcBw+QIvRCiReITqnnBkIgcCWIWxOAAPjhNnAdvtDgRLNYIDYzuVKkicfSjCYkBYrLZ7E4XEp3ARErV6hkrp0CL9Ym54n5-qQen4-FimnxSXhprN5njVuZZSBnkERmV3OZPrMGFyMsDQVAsfibEg4LrSp4oKaQR4ppbzWq7eNUHkXX4pCAlAwAO4AeXgsHQGAEsw6YiAA):\r\n```\r\n&quot;\\&quot;00\\&quot;\\&quot;02\\&quot; = \\&quot;a\\&quot;&quot;\r\n&quot;\\&quot;00\\&quot;banana = \\&quot;foo\\&quot;&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/77672251/using-jq-to-shows-all-possible-jq-paths-and-their-values-and-handle-cases-where",
        "title": "Using jq to shows all possible jq paths and their values and handle cases where numbers are object keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1702759953,
                "creation_date": 1702759953,
                "answer_id": 77672461,
                "question_id": 77672423,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will evaluate to `false` given your first two inputs, and `true` given the third one. use it as condition in a `if` or `select` expression if your &quot;command&quot; lives inside jq. Otherwise, you could use jq&#39;s `--exit-status` (or `-e`) flag to set its exit status to `1` or `0`, which you can capture and process in the invoking shell either by assigning `$?` to a variable, or by directly using the invocation in an `if` statement.\r\n\r\n```\r\nany(arrays[]; .name | . == &quot;README.md&quot; or startswith(&quot;.&quot;) | not)\r\n```\r\n[Demo](https://jqplay.org/s/vku_4KL9kTO)",
                "title": "How to check if the response array exists and there&#39;s some content other than...?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1702759953,
        "creation_date": 1702759138,
        "question_id": 77672423,
        "body_markdown": "I&#39;ve got a bash script and I&#39;m trying to perform a command based on a JSON response.\r\n\r\nI can have back 3 types of response which I store in the `content` variable:\r\n\r\n1st type (repo doesn&#39;t exist):\r\n```json\r\n{\r\n    &quot;message&quot;: &quot;The repo doesn&#39;t exist&quot;\r\n}\r\n```\r\n\r\n2nd type (repo exists but there&#39;s no content):\r\n```json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;.dotfile&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;.anotherdotfile&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;README.md&quot;\r\n    },\r\n]\r\n```\r\n\r\n3rd type (repo exists and there&#39;s a content):\r\n```json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;.dotfile&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;.anotherdotfile&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;README.md&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;myscript.sh&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;anotherscript.sh&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;anotherfile.sh&quot;\r\n    },\r\n]\r\n```\r\n\r\nIn my script I have loop like this:\r\n\r\n```bash\r\n#/bin/bash\r\n\r\nfor repo_name in &quot;${repos_name[@]}&quot;; do\r\n    content=$(curl -s http://example.com/$repo_name)\r\n\t\r\n    # Here I would like to check if the response is of the 3rd type.\r\n    # So, if it&#39;s an array with at least 1 object with value&#39;s name\r\n    # which not start from &quot;.&quot; or equal to &quot;README.md&quot;.\r\n    # In that case I would perform a command\r\n\r\ndone\r\n\r\n```\r\n\r\nBasically, I would like to check if a repo exist and it has some content apart from the dot files and the README.\r\n\r\nI tried to use `jq` tool but I don&#39;t know how to correctly filter the content to perform the check.\r\n\r\nHow can I achieve that result?",
        "link": "https://stackoverflow.com/questions/77672423/how-to-check-if-the-response-array-exists-and-theres-some-content-other-than",
        "title": "How to check if the response array exists and there&#39;s some content other than...?"
    },
    {
        "tags": [
            "json",
            "jq",
            "github-api",
            "github-cli"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1702903505,
                "creation_date": 1702903505,
                "answer_id": 77679173,
                "question_id": 77679117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can even collect all into one object using `reduce` instead of a mapping:\r\n```sh\r\ngh … | jq &#39;reduce .items[] as $i ({}; .[$i.repository.full_name] += [$i.path])&#39;\r\n```\r\n```json\r\n{\r\n  &quot;org-name/helm-charts&quot;: [\r\n    &quot;README.md&quot;\r\n  ],\r\n  &quot;org-name/repo-name&quot;: [\r\n    &quot;file-name-1.py&quot;,\r\n    &quot;file-name-2.py&quot;\r\n  ]\r\n}\r\n```\r\n\r\nIf you want to have an array of separate, single-field objects, append `to_entries | map([.] | from_entries)` to sort them out.",
                "title": "Use jq to get list of files that need editing from GitHub API for each repo returned"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1703157657,
        "creation_date": 1702902854,
        "last_edit_date": 1703157657,
        "question_id": 77679117,
        "body_markdown": "I am trying to query the GitHub API using `gh` and use the returned JSON to give me a list of repos that have matches for my search, and against each repo, I want a list of the filenames that need editing.\r\n\r\nI can get a list of the repos back from the API like so:\r\n\r\n```bash\r\ngh api --method=GET &quot;search/code?q=some-specific-string&quot; | jq -r &#39;[.items[] | { ( .repository.full_name ) :  .path}]&#39;\r\n```\r\n\r\nThis gives me results like:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;org-name/helm-charts&quot;: [\r\n      &quot;README.md&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;org-name/repo-name&quot;: [\r\n      &quot;file-name-1.py&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;org-name/repo-name&quot;: [\r\n      &quot;file-name-2.py&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI am trying to find the right way to take the results and merge them so that there are no duplicate repo names, and their lists are concatenated. So I get a result like:\r\n\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;org-name/helm-charts&quot;: [\r\n      &quot;README.md&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;org-name/repo-name&quot;: [\r\n      &quot;file-name-1.py&quot;,\r\n      &quot;file-name-2.py&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nHow would I do that with `jq`? I am trying to search for the solution but the way to word what I am trying to do eludes me",
        "link": "https://stackoverflow.com/questions/77679117/use-jq-to-get-list-of-files-that-need-editing-from-github-api-for-each-repo-retu",
        "title": "Use jq to get list of files that need editing from GitHub API for each repo returned"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1702917058,
                "last_edit_date": 1702917058,
                "creation_date": 1702916839,
                "answer_id": 77680436,
                "question_id": 77680411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could select the first 2 items in the array (`.[0:2]`) and then [`join()`][1] that with a `-`.\r\n\r\nIf you need the `2` items dynamic, you could use `.[:-1]` to just _remove_ the last index. More about the `.[x:y]` slice can be found in the [Array string slice documentation](https://jqlang.github.io/jq/manual/#array-string-slice).\r\n\r\n\r\n----------\r\n\r\n\r\n```\r\n.data[] | .[0:2] | join(&quot;-&quot;)\r\n```\r\n\r\n```\r\n.data[] | .[:-1] | join(&quot;-&quot;)\r\n```\r\n\r\nBoth give:\r\n```none\r\n2.16.1.0-2.16.1.255\r\n2.16.3.0-2.16.3.255\r\n2.16.6.0-2.16.7.255\r\n```\r\n----------\r\n\r\n##### [Online JQ Play Demo](https://jqplay.org/s/0LaVqPz4--l)\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#join",
                "title": "Two first elements from array and join them"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1702917424,
                "creation_date": 1702917424,
                "answer_id": 77680503,
                "question_id": 77680411,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "String interpolation can work here too:\r\n\r\n```\r\njq -r &#39;.data[] | &quot;\\(.[0])-\\(.[1])&quot;&#39;\r\n```\r\n\r\nOr string concatenation:\r\n\r\n```\r\njq -r &#39;.data[] | .[0] + &quot;-&quot; + .[1]&#39;\r\n```",
                "title": "Two first elements from array and join them"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1703047935,
        "creation_date": 1702916440,
        "last_edit_date": 1703047935,
        "question_id": 77680411,
        "body_markdown": "I have a following array\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    [\r\n      &quot;2.16.1.0&quot;,\r\n      &quot;2.16.1.255&quot;,\r\n      &quot;256&quot;\r\n    ],\r\n    [\r\n      &quot;2.16.3.0&quot;,\r\n      &quot;2.16.3.255&quot;,\r\n      &quot;256&quot;\r\n    ],\r\n    [\r\n      &quot;2.16.6.0&quot;,\r\n      &quot;2.16.7.255&quot;,\r\n      &quot;512&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\nI am trying to get the following output of it:\r\n```\r\n2.16.1.0-2.16.1.255\r\n2.16.3.0-2.16.3.255\r\n2.16.6.0-2.16.7.255\r\n```\r\nso far I have succeeded in outputting the first two required values\r\n\r\n```\r\ncat ./data.txt | jq -r &#39;.[][]|nth(0,1)&#39;\r\n\r\n2.16.1.0\r\n2.16.1.255\r\n2.16.3.0\r\n2.16.3.255\r\n2.16.6.0\r\n2.16.7.255\r\n```\r\nbut how do I merge/join them? Not sure I&#39;m going in the right direction.\r\n",
        "link": "https://stackoverflow.com/questions/77680411/two-first-elements-from-array-and-join-them",
        "title": "Two first elements from array and join them"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "deployment",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 17782992,
                    "reputation": 99,
                    "user_id": 12913765,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mAKbKmgKST0P6TEIw4phzFbPuPygrjU2UFDefprOA=k-s256",
                    "display_name": "Nathana&#235;l Blanchet",
                    "link": "https://stackoverflow.com/users/12913765/nathana%c3%abl-blanchet"
                },
                "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": 1703118842,
                "post_id": 77695140,
                "comment_id": 136974118,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17782992,
                    "reputation": 99,
                    "user_id": 12913765,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mAKbKmgKST0P6TEIw4phzFbPuPygrjU2UFDefprOA=k-s256",
                    "display_name": "Nathana&#235;l Blanchet",
                    "link": "https://stackoverflow.com/users/12913765/nathana%c3%abl-blanchet"
                },
                "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": 1703118996,
                "post_id": 77695140,
                "comment_id": 136974133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1703243526,
                "post_id": 77695140,
                "comment_id": 136988299,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9328817,
                    "reputation": 4538,
                    "user_id": 6925185,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bf7f59a5eeef601ed72a59d993045563?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jottbe",
                    "link": "https://stackoverflow.com/users/6925185/jottbe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1703502834,
                "post_id": 77695140,
                "comment_id": 137006784,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1710113948,
                "creation_date": 1710113948,
                "answer_id": 78137844,
                "question_id": 77695140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you want to modify array items in two distinct places and in two distinct ways, but all based on the same values that come from transforming the same source, I&#39;d recommend setting up a lookup table (e.g. using `INDEX`), and then querying it in both cases (instead of recurring to the same source and repeating the same transformations over and over):\r\n\r\n```sh\r\n.spec.template.spec |= (\r\n\r\n  INDEX(.containers[].volumeMounts[]\r\n    | {id: .name, subPath: (.mountPath / &quot;/&quot;)[-1]}\r\n    | .name = (.id | .[:index(&quot;claim&quot;)])\r\n            + (.subPath | gsub(&quot;[_.]&quot;;&quot;-&quot;) | ascii_downcase);\r\n    select(.subPath | test(&quot;[.][^.]+$&quot;)).id\r\n  ) as $lookup\r\n  \r\n  # With the sample input, $lookup would contain:\r\n  # \r\n  # {\r\n  #   &quot;movies-wikibase-claim1&quot;: {\r\n  #     &quot;id&quot;: &quot;movies-wikibase-claim1&quot;,\r\n  #     &quot;subPath&quot;: &quot;LocalSettings.override.php&quot;,\r\n  #     &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;\r\n  #   },\r\n  #   &quot;movies-wikibase-claim2&quot;: {\r\n  #     &quot;id&quot;: &quot;movies-wikibase-claim2&quot;,\r\n  #     &quot;subPath&quot;: &quot;wikibase_logo.png&quot;,\r\n  #     &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;\r\n  #   }\r\n  # }\r\n\r\n  | .containers[].volumeMounts[] |= last(., {mountPath} + (\r\n      $lookup[.name] | values | {name, subPath}\r\n    ))\r\n\r\n  | .volumes[] |= last(., (\r\n      $lookup[.name] | values | {configMap: {defaultMode: 420, name}, name}\r\n    ))\r\n\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n  &quot;kind&quot;: &quot;Deployment&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;template&quot;: {\r\n      &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n          {\r\n            &quot;volumeMounts&quot;: [\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html&quot;,\r\n                &quot;name&quot;: &quot;shared&quot;\r\n              },\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html/LocalSettings.d/LocalSettings.override.php&quot;,\r\n                &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;,\r\n                &quot;subPath&quot;: &quot;LocalSettings.override.php&quot;\r\n              },\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html/img/wikibase_logo.png&quot;,\r\n                &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;,\r\n                &quot;subPath&quot;: &quot;wikibase_logo.png&quot;\r\n              }\r\n            ]\r\n          }\r\n        ],\r\n        &quot;volumes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;shared&quot;,\r\n            &quot;persistentVolumeClaim&quot;: {\r\n              &quot;claimName&quot;: &quot;shared&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;configMap&quot;: {\r\n              &quot;defaultMode&quot;: 420,\r\n              &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;\r\n            },\r\n            &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;\r\n          },\r\n          {\r\n            &quot;configMap&quot;: {\r\n              &quot;defaultMode&quot;: 420,\r\n              &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;\r\n            },\r\n            &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/0kbYfmmJsbm)",
                "title": "transforming pvclaims into configmaps using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1710113948,
        "creation_date": 1703118230,
        "last_edit_date": 1703243504,
        "question_id": 77695140,
        "body_markdown": "Here is my input:\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n  &quot;kind&quot;: &quot;Deployment&quot;,\r\n  &quot;spec&quot;: {\r\n    &quot;template&quot;: {\r\n      &quot;spec&quot;: {\r\n        &quot;containers&quot;: [\r\n          {\r\n            &quot;volumeMounts&quot;: [\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html&quot;,\r\n                &quot;name&quot;: &quot;shared&quot;\r\n              },\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html/LocalSettings.d/LocalSettings.override.php&quot;,\r\n                &quot;name&quot;: &quot;movies-wikibase-claim1&quot;\r\n              },\r\n              {\r\n                &quot;mountPath&quot;: &quot;/var/www/html/img/wikibase_logo.png&quot;,\r\n                &quot;name&quot;: &quot;movies-wikibase-claim2&quot;\r\n              }\r\n            ]\r\n          }\r\n        ],\r\n        &quot;volumes&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;shared&quot;,\r\n            &quot;persistentVolumeClaim&quot;: {\r\n              &quot;claimName&quot;: &quot;shared&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;movies-wikibase-claim1&quot;,\r\n            &quot;persistentVolumeClaim&quot;: {\r\n              &quot;claimName&quot;: &quot;movies-wikibase-claim1&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;movies-wikibase-claim2&quot;,\r\n            &quot;persistentVolumeClaim&quot;: {\r\n              &quot;claimName&quot;: &quot;movies-wikibase-claim2&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nI&#39;d like to transform any mountpath ending with an extension into a mountPath pointing to a  corresponding &#39;configMaps&#39; object that itself replaces the pre-existing associated &#39;persistentVolumeClaim&#39;.\r\n\r\nWith this result:\r\n```json\r\n\r\n    {\r\n    ...\r\n                &quot;volumeMounts&quot;: [\r\n                  {\r\n                    &quot;mountPath&quot;: &quot;/var/www/html&quot;,\r\n                    &quot;name&quot;: &quot;shared&quot;\r\n                  },\r\n                  {\r\n                    &quot;mountPath&quot;: &quot;/var/www/html/LocalSettings.d/LocalSettings.override.php&quot;,\r\n                    &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;,\r\n                    &quot;subPath&quot;: &quot;LocalSettings.override.php&quot;\r\n                  },\r\n                  {\r\n                    &quot;mountPath&quot;: &quot;/var/www/html/img/wikibase_logo.png&quot;,\r\n                    &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;,\r\n                    &quot;subPath&quot;: &quot;wikibase_logo.png&quot;\r\n                  }\r\n                ]\r\n              }\r\n            ],\r\n            &quot;volumes&quot;: [\r\n              {\r\n                &quot;name&quot;: &quot;shared&quot;,\r\n                &quot;persistentVolumeClaim&quot;: {\r\n                  &quot;claimName&quot;: &quot;shared&quot;\r\n                }\r\n              },\r\n              {\r\n                &quot;configMap&quot;: {\r\n                  &quot;defaultMode&quot;: 420,\r\n                  &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;\r\n                },\r\n                &quot;name&quot;: &quot;movies-wikibase-localsettings-override-php&quot;\r\n              }\r\n              {\r\n                &quot;configMap&quot;: {\r\n                  &quot;defaultMode&quot;: 420,\r\n                  &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;\r\n                },\r\n                &quot;name&quot;: &quot;movies-wikibase-wikibase-logo-png&quot;\r\n              }\r\n    \r\n```\r\nI&#39;ve begun some stuff, but I didn&#39;t manage to achieve it:\r\n\r\n```    \r\ncat movies-wikibase-deployment.json| \r\n   jq -r &#39;((.spec.template.spec.containers[].volumeMounts[]?|select(.mountPath|test(&quot;(\\\\.[^.]+)$&quot;)))|={mountPath: .mountPath, name: ((.name|split(&quot;-claim&quot;)|.[0]) + &quot;-&quot; + (.mountPath|split(&quot;/&quot;)|last|gsub(&quot;_&quot;;&quot;-&quot;)|gsub(&quot;\\\\.&quot;;&quot;-&quot;)|ascii_downcase)), subPath: (.mountPath|split(&quot;/&quot;)|last)})|(((.spec.template.spec.containers[].volumeMounts[]?|select(.mountPath|test(&quot;(\\\\.[^.]+)$&quot;)).name) ) as $toto|.spec.template.spec.volumes+=[{configMap: {defaultMode: 420, name: $toto}, name: $toto}])&#39;\r\n```\r\n\r\nEDIT: In stead of one long line of code, you could have written a slightly more readable version like: \r\n\r\n```\r\njq -r &#39;(\r\n         (.spec.template.spec.containers[].volumeMounts[]?|\r\n          select(.mountPath|test(&quot;(\\\\.[^.]+)$&quot;)))|=\r\n          {mountPath: .mountPath, name: ((.name|split(&quot;-claim&quot;)|.[0]) + &quot;-&quot; + (.mountPath|split(&quot;/&quot;)|last|gsub(&quot;_&quot;;&quot;-&quot;)|gsub(&quot;\\\\.&quot;;&quot;-&quot;)|ascii_downcase)), subPath: (.mountPath|split(&quot;/&quot;)|last)}\r\n\t   )|\r\n        (\r\n\t\t ((.spec.template.spec.containers[].volumeMounts[]?|select(.mountPath|test(&quot;(\\\\.[^.]+)$&quot;)).name) ) as $toto|\r\n         .spec.template.spec.volumes+=[{configMap: {defaultMode: 420, name: $toto}, name: $toto}])&#39;  movies-wikibase-deployment.json\r\n```",
        "link": "https://stackoverflow.com/questions/77695140/transforming-pvclaims-into-configmaps-using-jq",
        "title": "transforming pvclaims into configmaps using jq"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1703180805,
                "post_id": 77699072,
                "comment_id": 136981860,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1703173940,
                "creation_date": 1703173940,
                "answer_id": 77699085,
                "question_id": 77699072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.data |= map(select(.age &gt;= 10))\r\n```\r\n\r\nWill produce the same output in a more cleaner way as you can test in [this online demo](https://jqplay.org/s/IsFLD8c8sH2).\r\n\r\n\r\n----------\r\n\r\nUsing the [`|=` update assignment][1] to update the value of `.data`.\r\n\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#update-assignment",
                "title": "Can the following jq recipe be simplified"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1703174017,
                "creation_date": 1703174017,
                "answer_id": 77699090,
                "question_id": 77699072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You already have an array, so you don&#39;t need to convert to entries first. Simply `map` the array and `select` the required elements:\r\n\r\n```\r\n.data |= map(select(.age &gt;= 10))\r\n```\r\n\r\nAlternatively\r\n\r\n```\r\n.data | { data: map(select(.age &gt;= 10)) }\r\n```\r\n\r\nor\r\n\r\n```\r\n{ data: (.data | map(select(.age &gt;= 10))) }\r\n```\r\n\r\nCalling `to_entries` on an array will give you a new array with a key-value object, the key being the index:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: 0,\r\n    &quot;value&quot;: {\r\n      &quot;name&quot;: &quot;Rich&quot;,\r\n      &quot;age&quot;: 10\r\n    }\r\n  },\r\n  ...\r\n]\r\n```\r\n\r\nSo unless your condition needs to perform calculations on the index (say, selecting every 3rd element, or only those indices which are multiples of 5), you don&#39;t need `to_entries` here.",
                "title": "Can the following jq recipe be simplified"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1703174017,
        "creation_date": 1703173758,
        "question_id": 77699072,
        "body_markdown": "Using jq version 1.5, I need to conditionally output some json objects (in an array) based on a value within the nested object.  I&#39;ve looked here on StackOverflow and managed to get what I want working, but I wonder if it can be simplified.  Here&#39;s my data\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Rich&quot;,\r\n      &quot;age&quot;: 10\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Michael&quot;,\r\n      &quot;age&quot;: 11\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Victoria&quot;,\r\n      &quot;age&quot;: 8\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Philip&quot;,\r\n      &quot;age&quot;: 9\r\n    }\r\n  ]\r\n}\r\n```\r\nand I need to reproduce the same structure, but only for pupils 10 or older, so the output should look like this:\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Rich&quot;,\r\n      &quot;age&quot;: 10\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Michael&quot;,\r\n      &quot;age&quot;: 11\r\n    }\r\n  ]\r\n}\r\n```\r\nI have the following code which achieves what I want:\r\n```\r\n.data | to_entries | map(select(.value.age&gt;9)) | [.[].value] | {data: .}\r\n```\r\nbut I read in the jq manual that `with_entries` can be used to replace `to_entries` -&gt; `map` -&gt; `from_entries`, now I&#39;m not using `from_entries`, but it made me question whether I should be, and if it would mean I don&#39;t need to manually recreate my array and object in the last two pipes.\r\n\r\nIs this the best way to solve this type of problem?\r\n\r\nI tried using using `from_entries` after my map, to see if that did what I need, but I got an error:\r\n```\r\njq: error (at &lt;stdin&gt;:19): Cannot use number (0) as object key\r\n```\r\nSo my understanding of how that works isn&#39;t correct.",
        "link": "https://stackoverflow.com/questions/77699072/can-the-following-jq-recipe-be-simplified",
        "title": "Can the following jq recipe be simplified"
    },
    {
        "tags": [
            "json",
            "pipe",
            "jq",
            "syntax-highlighting"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1703559350,
        "creation_date": 1703531213,
        "last_edit_date": 1703559350,
        "question_id": 77714718,
        "body_markdown": "Piping to jq, I get output like so:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\nIs there a way to change the color of null/boolean/number?\r\n\r\nSomething like:\r\n\r\n\r\n    export jq_int_color=yellow\r\n    export jq_bool_color=red\r\n    export jq_null_color=black\r\n\r\n\r\n\r\n  [1]: https://i.sstatic.net/aW5my.png",
        "link": "https://stackoverflow.com/questions/77714718/how-to-change-colors-of-null-boolean-number-with-jq",
        "title": "How to change colors of null / boolean / number with jq?"
    },
    {
        "tags": [
            "bash",
            "docker",
            "ubuntu",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1703765275,
                "creation_date": 1703765275,
                "answer_id": 77726797,
                "question_id": 77726749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;.[0].RepoTags[0]&#39; manifest.json\r\n\r\nThis command breaks down as follows:\r\n\r\n - **.[0]** accesses the first element of the JSON array (assuming there&#39;s only one element in the array as shown in your example).\r\n - **.RepoTags[0]** accesses the first element within the &quot;RepoTags&quot; array, which contains the image name and version in the format hello/world:latest.",
                "title": "How to get the image name and version from manifest.json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1703848324,
                "creation_date": 1703848324,
                "answer_id": 77731641,
                "question_id": 77726749,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possibility that might be worth considering:\r\n\r\n    ..|.RepoTags?[]\r\n\r\nOr more robustly:\r\n\r\n    ..|.RepoTags? // empty | .[]",
                "title": "How to get the image name and version from manifest.json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1703848324,
        "creation_date": 1703764802,
        "last_edit_date": 1703766020,
        "question_id": 77726749,
        "body_markdown": "This is a `manifest.json` generated by &quot;`docker save`&quot; on Ubuntu:\r\n\r\n    \r\n```json \r\n[\r\n  {\r\n    &quot;Config&quot;:&quot;a5a29aeb4d6a28cb5a0b759572ae5696f0a99a4be39aa4de08d8a897e6d12b95.json&quot;,\r\n    &quot;RepoTags&quot;:[&quot;hello/world:latest&quot;],\r\n    &quot;Layers&quot;:[&quot;b0e93b0b2e63771ea0cd34f350681b4397c804e5ed5ba01aec23cfaf6c49bc51/layer.tar&quot;,&quot;f9b7caaf240b159e636f77a9571073f6e4d5a0541d864ec64e4e2808b282e302/layer.tar&quot;,&quot;1355029c32eee25981e17b0e89e946d9346cffdff29ff53858104ebfe6728d80/layer.tar&quot;,&quot;362092bb6a9ed18c0e88a9b1635e7c16914661935ce64f1b581d19fd5226463a/layer.tar&quot;,&quot;fe2bde379de2f44bb47d5d75a25294485f70d8b4c7a99a08b0fcef8f4076914d/layer.tar&quot;,&quot;4acfd2b9473bf5c17f50ad2ff04c148b1be79d1174509e0fb10d27ba8cff9294/layer.tar&quot;,&quot;e5131e82e66e45e002a88618254c1cde43a497d8a94fcb5d9b20171f19b15b96/layer.tar&quot;]\r\n  }\r\n]\r\n```\r\n\r\nI want to use &quot;`jq`&quot; to get the `docker image name` and `version` from &quot;`RepoTags`&quot;:\r\n\r\n    jq -e -r &quot;.RepoTags&quot; manifest.json\r\n\r\n**Here is the error:**\r\n\r\n    jq: error (at manifest.json:1): Cannot index array with string &quot;RepoTags&quot;\r\n\r\nHow to get it with `jq`?\r\n",
        "link": "https://stackoverflow.com/questions/77726749/how-to-get-the-image-name-and-version-from-manifest-json",
        "title": "How to get the image name and version from manifest.json"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1703776254,
                "post_id": 77727557,
                "comment_id": 137030267,
                "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": 1704314630,
                "post_id": 77727557,
                "comment_id": 137078184,
                "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": 1704317717,
                "post_id": 77727557,
                "comment_id": 137078636,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1703778625,
                "creation_date": 1703778625,
                "answer_id": 77727862,
                "question_id": 77727557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.&quot;solr.jetty&quot;.&quot;org.eclipse.jetty.server.handler.DefaultHandler.requests&quot;.count&#39;\r\n```",
                "title": "JQ filter for a single JSON file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1703821125,
                "creation_date": 1703821125,
                "answer_id": 77730128,
                "question_id": 77727557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to minimize typing, consider:\r\n\r\n    ..|.count? // empty",
                "title": "JQ filter for a single JSON file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1703821125,
        "creation_date": 1703774882,
        "question_id": 77727557,
        "body_markdown": "I have a file containing\r\n\r\n    {\r\n      &quot;solr.jetty&quot;: {\r\n        &quot;org.eclipse.jetty.server.handler.DefaultHandler.requests&quot;: {\r\n          &quot;count&quot;: 432742,\r\n          &quot;meanRate&quot;: 0.1393530774422645,\r\n          &quot;1minRate&quot;: 0.1582358234691172,\r\n          &quot;5minRate&quot;: 0.24472281886082692,\r\n          &quot;15minRate&quot;: 0.32856666658514566,\r\n          &quot;min_ms&quot;: 0,\r\n          &quot;max_ms&quot;: 124,\r\n          &quot;mean_ms&quot;: 19.05039312538189,\r\n          &quot;median_ms&quot;: 1,\r\n          &quot;stddev_ms&quot;: 27.68447649619781,\r\n          &quot;p75_ms&quot;: 61,\r\n          &quot;p95_ms&quot;: 63,\r\n          &quot;p99_ms&quot;: 64,\r\n          &quot;p999_ms&quot;: 67\r\n        }\r\n      }\r\n    }\r\n\r\nI want ``jq`` command to print the &quot;count&quot; field.\r\n\r\nI read many web pages with a lot of dumb examples and I didn&#39;t get yet my filter to use because I find it all very counterintuitive.\r\n\r\n\r\nP.D: do you know any **good** jq tutorial or guide?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77727557/jq-filter-for-a-single-json-file",
        "title": "JQ filter for a single JSON file"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12046,
                    "reputation": 191436,
                    "user_id": 23528,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1595024881f1df4af9e2280926fb6272?s=256&d=identicon&r=PG",
                    "display_name": "Daniel A. White",
                    "link": "https://stackoverflow.com/users/23528/daniel-a-white"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1704462497,
                "post_id": 77764999,
                "comment_id": 137097089,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 81175,
                    "reputation": 2702,
                    "user_id": 229058,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1556e6ebdef89457b4a34b9a1b426a2a?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Rasku",
                    "link": "https://stackoverflow.com/users/229058/stephen-rasku"
                },
                "reply_to_user": {
                    "account_id": 12046,
                    "reputation": 191436,
                    "user_id": 23528,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1595024881f1df4af9e2280926fb6272?s=256&d=identicon&r=PG",
                    "display_name": "Daniel A. White",
                    "link": "https://stackoverflow.com/users/23528/daniel-a-white"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1704462851,
                "post_id": 77764999,
                "comment_id": 137097145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12046,
                    "reputation": 191436,
                    "user_id": 23528,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1595024881f1df4af9e2280926fb6272?s=256&d=identicon&r=PG",
                    "display_name": "Daniel A. White",
                    "link": "https://stackoverflow.com/users/23528/daniel-a-white"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1704463378,
                "post_id": 77764999,
                "comment_id": 137097230,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 81175,
                    "reputation": 2702,
                    "user_id": 229058,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/1556e6ebdef89457b4a34b9a1b426a2a?s=256&d=identicon&r=PG",
                    "display_name": "Stephen Rasku",
                    "link": "https://stackoverflow.com/users/229058/stephen-rasku"
                },
                "reply_to_user": {
                    "account_id": 12046,
                    "reputation": 191436,
                    "user_id": 23528,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1595024881f1df4af9e2280926fb6272?s=256&d=identicon&r=PG",
                    "display_name": "Daniel A. White",
                    "link": "https://stackoverflow.com/users/23528/daniel-a-white"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1704463715,
                "post_id": 77764999,
                "comment_id": 137097290,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1704463648,
                "creation_date": 1704463648,
                "answer_id": 77765142,
                "question_id": 77764999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You would convert the object into an array with [to_entries](https://jqlang.github.io/jq/manual/v1.7/#to_entries-from_entries-with_entries) and [map](https://jqlang.github.io/jq/manual/v1.7/#map-map_values)\r\n```\r\necho &quot;$your_object&quot; | jq &#39;to_entries | map(.value)&#39;\r\n```\r\nSorting can then follow.",
                "title": "Use jq to convert object to sorted array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1704467236,
                "creation_date": 1704467236,
                "answer_id": 77765520,
                "question_id": 77764999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just iterate over the (outer) object&#39;s items using `.[]`, and collect them into a new array by surrounding with `[…]`; or use `map(.)` with the same effect. The sorting can then be achieved using `sort_by(.Tag)`.\r\n```sh\r\njq &#39;[.[]] | sort_by(.Tag)&#39; input.json\r\n# or\r\njq &#39;map(.) | sort_by(.Tag)&#39; input.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;ID&quot;: &quot;ddeeb3d41a4c&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.177&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;f92356a49d78&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.178&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;2f5a63db6634&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.179&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a4e57f2db7eb&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.181&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a1caaccdba45&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.183&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;9aa95de44891&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.189&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;91a86fec59b1&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.202&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;1eba648810a9&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.237&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;2df272728204&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.243&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;d0254d6406e0&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.253&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a35ad9d93e62&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.42&quot;\r\n  }\r\n]\r\n```",
                "title": "Use jq to convert object to sorted array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1704475980,
        "creation_date": 1704462273,
        "last_edit_date": 1704475980,
        "question_id": 77764999,
        "body_markdown": "I have the following JSON object.\r\n```JSON\r\n{\r\n  &quot;1eba648810a9&quot;: {\r\n    &quot;ID&quot;: &quot;1eba648810a9&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.237&quot;\r\n  },\r\n  &quot;2df272728204&quot;: {\r\n    &quot;ID&quot;: &quot;2df272728204&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.243&quot;\r\n  },\r\n  &quot;2f5a63db6634&quot;: {\r\n    &quot;ID&quot;: &quot;2f5a63db6634&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.179&quot;\r\n  },\r\n  &quot;91a86fec59b1&quot;: {\r\n    &quot;ID&quot;: &quot;91a86fec59b1&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.202&quot;\r\n  },\r\n  &quot;9aa95de44891&quot;: {\r\n    &quot;ID&quot;: &quot;9aa95de44891&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.189&quot;\r\n  },\r\n  &quot;a1caaccdba45&quot;: {\r\n    &quot;ID&quot;: &quot;a1caaccdba45&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.183&quot;\r\n  },\r\n  &quot;a35ad9d93e62&quot;: {\r\n    &quot;ID&quot;: &quot;a35ad9d93e62&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.42&quot;\r\n  },\r\n  &quot;a4e57f2db7eb&quot;: {\r\n    &quot;ID&quot;: &quot;a4e57f2db7eb&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.181&quot;\r\n  },\r\n  &quot;d0254d6406e0&quot;: {\r\n    &quot;ID&quot;: &quot;d0254d6406e0&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.253&quot;\r\n  },\r\n  &quot;ddeeb3d41a4c&quot;: {\r\n    &quot;ID&quot;: &quot;ddeeb3d41a4c&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.177&quot;\r\n  },\r\n  &quot;f92356a49d78&quot;: {\r\n    &quot;ID&quot;: &quot;f92356a49d78&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.178&quot;\r\n  }\r\n}\r\n```\r\n\r\nHow do I convert this into an array and sort it by `Tag`.  In the end I want something like this.\r\n```JSON\r\n[\r\n  {\r\n    &quot;ID&quot;: &quot;ddeeb3d41a4c&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.177&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;f92356a49d78&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.178&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;2f5a63db6634&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.179&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a4e57f2db7eb&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.181&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a1caaccdba45&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.183&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;9aa95de44891&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.189&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;91a86fec59b1&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.202&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;1eba648810a9&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.237&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;2df272728204&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.243&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;d0254d6406e0&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.253&quot;\r\n  },\r\n  {\r\n    &quot;ID&quot;: &quot;a35ad9d93e62&quot;,\r\n    &quot;Tag&quot;: &quot;1.0.42&quot;\r\n  }\r\n]\r\n```\r\nNote that the sorting by version is not entirely correct but that&#39;s a separate issue.  Ideally, I would like a solution using only `jq` instead of other external tools.\r\n\r\nThe [following question](https://stackoverflow.com/questions/70492898/using-jq-how-to-sort-array-of-object) has been suggested as a duplicate but it&#39;s not relevant because that is sorting an array, not an object.",
        "link": "https://stackoverflow.com/questions/77764999/use-jq-to-convert-object-to-sorted-array",
        "title": "Use jq to convert object to sorted array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1704798620,
                "creation_date": 1704798620,
                "answer_id": 77786313,
                "question_id": 77786240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should check if the context `has` that key. Also, to prevent the string from failing when trying to apply `has` on it, either filter for `objects`, or suppress the error with `?`. In either case, use this condition to filter the results using `select`.\r\n\r\n```sh\r\nkeys[] as $k | .[$k] | objects | select(has(&quot;linux-image-amd64&quot;))\r\n# or\r\nkeys[] as $k | .[$k] | select(has(&quot;linux-image-amd64&quot;)?)\r\n```\r\n```json\r\n{\r\n  &quot;linux-image-6.1.0-0.deb11.13-amd64&quot;: {\r\n    &quot;old&quot;: &quot;&quot;,\r\n    &quot;new&quot;: &quot;6.1.55-1~bpo11+1&quot;\r\n  },\r\n  &quot;linux-image-amd64&quot;: {\r\n    &quot;old&quot;: &quot;6.1.38-4~bpo11+1&quot;,\r\n    &quot;new&quot;: &quot;6.1.55-1~bpo11+1&quot;\r\n  }\r\n}\r\n{\r\n  &quot;linux-image-amd64&quot;: {\r\n    &quot;old&quot;: &quot;5.10.197-1&quot;,\r\n    &quot;new&quot;: &quot;5.10.205-2&quot;\r\n  },\r\n  &quot;linux-image-5.10.0-27-amd64&quot;: {\r\n    &quot;old&quot;: &quot;&quot;,\r\n    &quot;new&quot;: &quot;5.10.205-2&quot;\r\n  }\r\n}\r\n```\r\n\r\nYou can then construct your output using `$k`, e.g.:\r\n```sh\r\nkeys[] as $k | .[$k] | select(has(&quot;linux-image-amd64&quot;)?) | $k\r\n```\r\n```\r\nlmrelaunch.example.de\r\nweb-prode-04.example.de\r\n```\r\n",
                "title": "jq how to get all parents of a specific child"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1704799424,
        "creation_date": 1704797983,
        "last_edit_date": 1704799424,
        "question_id": 77786240,
        "body_markdown": "Hello I&#39;ve the following json and try to get all parents who have the &quot;linux-image-amd64&quot;\r\n\r\n```\r\n{\r\n    &quot;web-prode-01.example.de&quot;: &quot;ERROR: Problem encountered installing package(s). Additional info follows:\\n\\nchanges:\\n    ----------\\n    linux-image-amd64:\\n        ----------\\n        new:\\n        old:\\n            6.1.55-1\\nerrors:\\n    - Running scope as unit: run-rad31bddd35ec452b9d67fef004ce3daf.scope\\n      E: Sub-process /usr/bin/dpkg returned an error code (1)&quot;,\r\n    &quot;web-prode-04.example.de&quot;: {\r\n        &quot;linux-image-amd64&quot;: {\r\n            &quot;old&quot;: &quot;5.10.197-1&quot;,\r\n            &quot;new&quot;: &quot;5.10.205-2&quot;\r\n        },\r\n        &quot;linux-image-5.10.0-27-amd64&quot;: {\r\n            &quot;old&quot;: &quot;&quot;,\r\n            &quot;new&quot;: &quot;5.10.205-2&quot;\r\n        }\r\n    },\r\n    &quot;lmrelaunch.example.de&quot;: {\r\n        &quot;linux-image-6.1.0-0.deb11.13-amd64&quot;: {\r\n            &quot;old&quot;: &quot;&quot;,\r\n            &quot;new&quot;: &quot;6.1.55-1~bpo11+1&quot;\r\n        },\r\n        &quot;linux-image-amd64&quot;: {\r\n            &quot;old&quot;: &quot;6.1.38-4~bpo11+1&quot;,\r\n            &quot;new&quot;: &quot;6.1.55-1~bpo11+1&quot;\r\n        }\r\n    }   \r\n}\r\n```\r\nI tried ```jq -r &#39;keys[] as $k | &quot;\\($k) \\(.[$k].&quot;linux-image-amd64&quot;)&quot;&#39;``` but I just got one entry instead of two",
        "link": "https://stackoverflow.com/questions/77786240/jq-how-to-get-all-parents-of-a-specific-child",
        "title": "jq how to get all parents of a specific child"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1704833169,
                "post_id": 77789650,
                "comment_id": 137136182,
                "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": 1704838017,
                "post_id": 77789650,
                "comment_id": 137136755,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1714764011,
                "creation_date": 1714764011,
                "answer_id": 78426599,
                "question_id": 77789650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes -- you can separate multiple field assignments with commas in a single expression \r\n\r\n`echo {} | jq &#39;.a = 1, .b = 2&#39;`\r\n\r\nTakes empty JSON, sets both `a` and `b`. no matter the input, jq will overwrite these values if present. \r\n\r\n 1. Start with Empty\r\n```\r\necho {} | jq &#39;.a = 1, .b = 2&#39;\r\n# Output: {&quot;a&quot;:1,&quot;b&quot;:2}\r\n```\r\n\r\n2. Starting with `{&quot;a&quot;:42}`:\r\n\r\n```\r\necho &#39;{&quot;a&quot;:42}&#39; | jq &#39;.a = 1, .b = 2&#39;\r\n# Output: {&quot;a&quot;:1,&quot;b&quot;:2}\r\n```\r\n \r\n3. Starting with `{&quot;a&quot;:&quot;hello&quot;}`\r\n\r\n```\r\necho &#39;{&quot;a&quot;:&quot;hello&quot;}&#39; | jq &#39;.a = 1, .b = 2&#39;\r\n# Output: {&quot;a&quot;:1,&quot;b&quot;:2}\r\n```\r\n\r\n 4. Starting with `{&quot;b&quot;:&quot;qwerty&quot;}`:\r\n```\r\necho &#39;{&quot;b&quot;:&quot;qwerty&quot;}&#39; | jq &#39;.a = 1, .b = 2&#39;\r\n# Output: {&quot;a&quot;:1,&quot;b&quot;:2}\r\n```",
                "title": "jq to set several explicit properties at once"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1714764011,
        "creation_date": 1704833059,
        "question_id": 77789650,
        "body_markdown": "In a very simplified senes, I would like to take an existing JSON object and use `jq` to add/update two additional values to it. For example\r\n\r\n| Start | Result |\r\n| -------- | -------------- |\r\n| `{}`    | `{&quot;a&quot;: 1, &quot;b&quot;:2}` |\r\n| `{&quot;a&quot;:42}`   | `{&quot;a&quot;: 1, &quot;b&quot;:2}`             |\r\n| `{&quot;a&quot;:&quot;hello&quot;}`   | `{&quot;a&quot;: 1, &quot;b&quot;:2}`             |\r\n| `{&quot;b&quot;:&quot;qwerty&quot;}`   | `{&quot;a&quot;: 1, &quot;b&quot;:2}`             |\r\n\r\nI can set either `a` or `b` with two back to back commands like so `echo {} | jq &#39;.a=1&#39; | jq &#39;.b=2&#39;`. But I was wondering if there is a way to make only a single `jq` call to do both operations?",
        "link": "https://stackoverflow.com/questions/77789650/jq-to-set-several-explicit-properties-at-once",
        "title": "jq to set several explicit properties at once"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1704901494,
                "creation_date": 1704901494,
                "answer_id": 77794607,
                "question_id": 77794243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Something like this?\r\n\r\n```\r\n$ echo &#39;{&quot;Results&quot;: [{&quot;Input&quot;: [{&quot;foo&quot;:&quot; bar&quot;, &quot;this&quot;: &quot;that&quot;}, {&quot;foo&quot;: &quot;bing&quot;}]}]}&#39; | \\\r\n  jq &#39;{sections: ([{first: &quot;element&quot;, that: &quot;is needed at pos 0 in this array&quot;}] + [.Results[].Input[] | { markdown: true, facts: [ { name: &quot;MyFoo&quot;, value: .foo }]}])}&#39;\r\n{\r\n  &quot;sections&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;element&quot;,\r\n      &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;\r\n    },\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot; bar&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot;bing&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIn particular, note the use of `+` to concatenate two arrays.",
                "title": "Add generated elements to template in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1704904712,
                "creation_date": 1704904712,
                "answer_id": 77794972,
                "question_id": 77794243,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are almost there.\r\nLet&#39;s format your attempt a bit, to understand what it does:\r\n\r\n```jq\r\n{\r\n  &quot;sections&quot;: [\r\n    {&quot;first&quot;: &quot;element&quot;, &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;},\r\n    .Results[] | .Input[]? | {&quot;markdown&quot;: true, &quot;facts&quot;: [{name: &quot;MyFoo&quot;, value: .foo}]}\r\n  ]\r\n}\r\n```\r\n\r\nI formatted it according to your intent: you want an object whose `sections` property is an array that has the object `{ &quot;first&quot;: &quot;element&quot; ... }` as its first item and the other items are computed from the properties `.Results.Input` of the input object.\r\n\r\nUnfortunately, the [documentation of `jq`](https://jqlang.github.io/jq/manual/) does not specify the precedence of its operators. While everybody (including me) assumes that the [pipe operator (`|`)](https://jqlang.github.io/jq/manual/#pipe) has higher precedence than the [comma operator (`,`)](https://jqlang.github.io/jq/manual/#comma) (an assumption probably based on how these operators work in the languages inspired from C), in `jq` is the other way around: `,` has higher precedence than `|`.\r\n\r\nThis makes your code work equivalent to this:\r\n```jq\r\n{\r\n  &quot;sections&quot;: [\r\n    ({&quot;first&quot;: &quot;element&quot;, &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;}, .Results[])\r\n    | .Input[]? | {&quot;markdown&quot;: true, &quot;facts&quot;: [{name: &quot;MyFoo&quot;, value: .foo}]}\r\n  ]\r\n}\r\n```\r\n\r\nThe first filter (`{&quot;first&quot;: ... }, .Results[]`) produces:\r\n```json\r\n{\r\n  &quot;sections&quot;:[\r\n    {&quot;first&quot;: &quot;element&quot;,&quot;that&quot;:&quot;is needed at pos 0 in this array&quot;},\r\n    {&quot;Input&quot;: [{&quot;foo&quot;: &quot; bar&quot;,&quot;this&quot;: &quot;that&quot;}, {&quot;foo&quot;: &quot;bing&quot;}]}\r\n  ]\r\n}\r\n```\r\nThe next filter, `.Input[]` discards the object `{first: &quot;element&quot; ...}` and its output is `[{&quot;foo&quot;: &quot; bar&quot;,&quot;this&quot;: &quot;that&quot;}, {&quot;foo&quot;: &quot;bing&quot;}]` and now it is clear why the output of the entire program is not the one that you expect.\r\n\r\nThe solution is simple: wrap the pipeline that processes the input in parentheses and it will work.\r\n\r\n---\r\n\r\nGiven that `jq` language is not JSON (but it includes JSON), you don&#39;t have to wrap the keys in quotes. Getting rid of the quotes around keys and wrapping the program on multiple lines makes it easier to read:\r\n\r\n```jq\r\n{\r\n  sections: [\r\n    { first: &quot;element&quot;, that: &quot;is needed at pos 0 in this array&quot; },\r\n    (.Results[] | .Input[]? | { markdown: true, facts: [{ name: &quot;MyFoo&quot;, value: .foo }]})\r\n  ]\r\n}\r\n```\r\n\r\nCheck it online on the [`jq` playground](https://jqplay.org/s/Ff1GLQHnF0c).",
                "title": "Add generated elements to template in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1704904712,
        "creation_date": 1704898038,
        "question_id": 77794243,
        "body_markdown": "I&#39;m trying to generate a new json from an existing one. In the new json is an array with one entry, which needs to remain the first entry in the array. With jq generate additional entries to this arrays. But my code replaces the existing entry. I&#39;ve created a smaller representation of my Problem. \r\n\r\nThis following code is what I have so far.\r\n\r\n```bash\r\necho &#39;{&quot;Results&quot;: [{&quot;Input&quot;: [{&quot;foo&quot;:&quot; bar&quot;, &quot;this&quot;: &quot;that&quot;}, {&quot;foo&quot;: &quot;bing&quot;}]}]}&#39; | \\\r\n  jq &#39;{&quot;sections&quot;: [{&quot;first&quot;: &quot;element&quot;, &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;},  .Results[] | .Input[]? | {&quot;markdown&quot;: true, &quot;facts&quot;:[{name: &quot;MyFoo&quot;, value: .foo}]}]}&#39;\r\n```\r\n\r\nThis is the result i, which is missing the first element of the sections list.\r\n\r\n```json\r\n{\r\n  &quot;sections&quot;: [\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot; bar&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot;bing&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nMy desired result would be the following:\r\n\r\n```json\r\n{\r\n  &quot;sections&quot;: [\r\n    {\r\n      &quot;first&quot;: &quot;element&quot;,\r\n      &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;\r\n    },\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot; bar&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;markdown&quot;: true,\r\n      &quot;facts&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;MyFoo&quot;,\r\n          &quot;value&quot;: &quot;bing&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;v tried to use two linked jq command but his destroys the order in the sections list.\r\n\r\n```\r\necho &#39;{&quot;Results&quot;: [{&quot;Input&quot;: [{&quot;foo&quot;:&quot; bar&quot;, &quot;this&quot;: &quot;that&quot;}, {&quot;foo&quot;: &quot;bing&quot;}]}]}&#39; | \\\r\n  jq &#39;{&quot;sections&quot;: [ .Results[] | .Input[]? | {&quot;markdown&quot;: true, &quot;facts&quot;:[{name: &quot;MyFoo&quot;, value: .foo}]}]}&#39; |\\\r\n  jq &#39;.sections += [{&quot;first&quot;: &quot;element&quot;, &quot;that&quot;: &quot;is needed at pos 0 in this array&quot;}]&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/77794243/add-generated-elements-to-template-in-jq",
        "title": "Add generated elements to template in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1704969657,
                "creation_date": 1704969657,
                "answer_id": 77799393,
                "question_id": 77799300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After `.parent.innerList[] |` your context isn&#39;t the root anymore. Access `rootElement` outside the iteration:\r\n```\r\n.parent | .innerList[] += {rootElement}\r\n```\r\n```\r\n{\r\n  &quot;rootElement&quot;: &quot;root&quot;,\r\n  &quot;innerList&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;value&quot;: &quot;A&quot;,\r\n      &quot;rootElement&quot;: &quot;root&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 2,\r\n      &quot;value&quot;: &quot;B&quot;,\r\n      &quot;rootElement&quot;: &quot;root&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 3,\r\n      &quot;value&quot;: &quot;C&quot;,\r\n      &quot;rootElement&quot;: &quot;root&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/rEHwf3WPbNj)",
                "title": "jq command for getting root element inside an inner list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1705013344,
                "last_edit_date": 1705013344,
                "creation_date": 1705008587,
                "answer_id": 77803137,
                "question_id": 77799300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using a jq variable in this and similar cases makes for an easy-to-read solution:\r\n```\r\n.parent\r\n| .rootElement as $rootElement\r\n| .innerList[] += {$rootElement}\r\n```\r\n\r\nOr, if you want the .rootElement key to appear first in the outermost object, change the last line above to:\r\n\r\n\r\n```\r\n| .innerList[] |= {$rootElement} + .\r\n```",
                "title": "jq command for getting root element inside an inner list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1705381622,
        "creation_date": 1704968667,
        "last_edit_date": 1705381622,
        "question_id": 77799300,
        "body_markdown": "This is my sample json\r\n\r\n```\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;rootElement&quot;: &quot;root&quot;,\r\n    &quot;innerList&quot;: [\r\n      {&quot;id&quot;: 1, &quot;value&quot;: &quot;A&quot;},\r\n      {&quot;id&quot;: 2, &quot;value&quot;: &quot;B&quot;},\r\n      {&quot;id&quot;: 3, &quot;value&quot;: &quot;C&quot;}\r\n    ]\r\n  }\r\n}\r\n```\r\nI want a transformed json like this using jq commands\r\n\r\n```\r\n{&quot;innerList&quot;: [\r\n        {&quot;id&quot;: 1, &quot;rootElement&quot;: &quot;root&quot;, &quot;value&quot;: &quot;A&quot;\r\n        },\r\n        {&quot;id&quot;: 2, &quot;rootElement&quot;: &quot;root&quot;, &quot;value&quot;: &quot;B&quot;\r\n        },\r\n        {&quot;id&quot;: 3, &quot;rootElement&quot;: &quot;root&quot;, &quot;value&quot;: &quot;C&quot;\r\n        }\r\n    ],\r\n &quot;rootElement&quot;: &quot;root&quot;\r\n}\r\n```\r\n\r\n\r\nI tried this command but I dont get the desried output as I am not able to access the root element once I inside parsing the inner list.\r\n\r\n\r\n`jq &#39;{rootElement: .parent.rootElement, innerList: [.parent.innerList[] | {id, value: .value, rootElement: .parent.rootElement}]}&#39;`\r\n\r\nI get \r\n\r\n```\r\n{&quot;innerList&quot;: [\r\n        {&quot;id&quot;: 1, &quot;rootElement&quot;: null, &quot;value&quot;: &quot;A&quot;\r\n        },\r\n        {&quot;id&quot;: 2, &quot;rootElement&quot;: null, &quot;value&quot;: &quot;B&quot;\r\n        },\r\n        {&quot;id&quot;: 3, &quot;rootElement&quot;: null, &quot;value&quot;: &quot;C&quot;\r\n        }\r\n    ],\r\n &quot;rootElement&quot;: &quot;root&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77799300/jq-command-for-getting-root-element-inside-an-inner-list",
        "title": "jq command for getting root element inside an inner list"
    },
    {
        "tags": [
            "json",
            "amazon-web-services",
            "null",
            "devops",
            "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": 1704977320,
                "post_id": 77799635,
                "comment_id": 137154999,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1705007414,
                "creation_date": 1705007414,
                "answer_id": 77803051,
                "question_id": 77799635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could sprinkle postfix &quot;?&quot;s in your query, though exactly how will of course depend on your requirements.  Here&#39;s an example:\r\n\r\n    jq &#39;.Reservations[]?.functions[]?.UserId&#39; \r\n\r\nTo understand this, note that if E is some jq expression, then `(E)?` is like `try E catch empty`.\r\n",
                "title": "Can not iterate over null error at stdin 18"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1705007435,
        "creation_date": 1704971965,
        "last_edit_date": 1705007435,
        "question_id": 77799635,
        "body_markdown": "\r\nScanning linux images...\r\n\r\nRunning kernel seems to be up-to-date.\r\n\r\nNo services need to be restarted.\r\n\r\nNo containers need to be restarted.\r\n\r\nNo user sessions are running outdated binaries.\r\n\r\nNo VM guests are running outdated hypervisor (qemu) binaries on this host.\r\n\r\n    ubuntu@ip-172-31-19-196:-$ aws iam list-users | jq.Reservations[].functions[].UserId&quot;\r\n    \r\n    jq: error (at &lt;stdin&gt;:18): Cannot iterate over null (null)\r\n    \r\n    ubuntu@ip-172-31-19-196:-$ aws iam list-users | jq&quot;.Reservations[].functions[].UserId&#39;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77799635/can-not-iterate-over-null-error-at-stdin-18",
        "title": "Can not iterate over null error at stdin 18"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "amazon-kinesis",
            "amazon-kinesis-firehose",
            "jql"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1705117694,
                "creation_date": 1705117694,
                "answer_id": 77810244,
                "question_id": 77809442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe that the part you need is explained in the manual&#39;s section on [object construction][1].\r\n\r\nThis will put the objects in an array, which is close to your desired output.\r\n\r\n    jq -n &#39;[ inputs | { id, &quot;users&quot;: .users[] } ]&#39;\r\n\r\nBut perhaps this is what you want.\r\n\r\n    jq &#39;{ id, &quot;users&quot;: .users[] }&#39;\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.7/#object-construction",
                "title": "How to use jq for firehose metadata extraction in aggregated events"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1705117694,
        "creation_date": 1705096207,
        "question_id": 77809442,
        "body_markdown": "I have this aggregated single event in firehose. When  using jq to create keys:values for I get the below error. My jq is like this\r\n\r\n    id:.id\r\n    users:users[].uuid\r\n\r\n    \r\n\r\n&gt; Error: metadata extraction failed because JQ query failed. invalid jq query\r\n&gt; causing a single record to split into 2 or more.\r\n\r\n    {   &quot;id&quot;:20\r\n        &quot;users&quot;: [\r\n            {   &quot;uuid&quot;:2330\r\n                &quot;first&quot;: &quot;Stevie&quot;,\r\n                &quot;last&quot;: &quot;Wonder&quot;\r\n            },\r\n            {   &quot;uuid&quot;:9033131\r\n                &quot;first&quot;: &quot;Michael&quot;,\r\n                &quot;last&quot;: &quot;Jackson&quot;\r\n            }\r\n        ]\r\n    }\r\n    {   &quot;id&quot;:30\r\n        &quot;users&quot;: [\r\n            {   &quot;uuid&quot;:984209302\r\n                &quot;first&quot;: &quot;lower&quot;,\r\n                &quot;last&quot;: &quot;harvest&quot;\r\n            },\r\n            {   &quot;uuid&quot;:8980323932\r\n                &quot;first&quot;: &quot;Duncan&quot;,\r\n                &quot;last&quot;: &quot;mighty&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n**I want to be able to create dynamicc partitioning using uuid.**\r\n\r\n    {   &quot;id&quot;:20\r\n            &quot;users&quot;: [\r\n                {   &quot;uuid&quot;:2330\r\n                    &quot;first&quot;: &quot;Stevie&quot;,\r\n                    &quot;last&quot;: &quot;Wonder&quot;\r\n                }\r\n    ]\r\n    },\r\n    {   &quot;id&quot;:20\r\n            &quot;users&quot;: [\r\n                {   &quot;uuid&quot;:9033131\r\n                    &quot;first&quot;: &quot;Michael&quot;,\r\n                    &quot;last&quot;: &quot;Jackson&quot;\r\n                }\r\n            ]\r\n        }\r\n    },\r\n        {   &quot;id&quot;:30\r\n            &quot;users&quot;: [\r\n                {   &quot;uuid&quot;:984209302\r\n                    &quot;first&quot;: &quot;lower&quot;,\r\n                    &quot;last&quot;: &quot;harvest&quot;\r\n                }\r\n            ]\r\n        }",
        "link": "https://stackoverflow.com/questions/77809442/how-to-use-jq-for-firehose-metadata-extraction-in-aggregated-events",
        "title": "How to use jq for firehose metadata extraction in aggregated events"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705174878,
                "last_edit_date": 1705174878,
                "creation_date": 1705171236,
                "answer_id": 77812667,
                "question_id": 77812664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ended up solving this using the `IN` sql like operator.\r\n\r\n`.[] | select(.field as $field | [&quot;value-1&quot;, &quot;value-3&quot;] | all(IN($field[])))`\r\n\r\nHere&#39;s a jq play demo - https://jqplay.org/s/spEokLaWUHL\r\n\r\nLooking forward to hearing if there are any other ways to do this filtering",
                "title": "How to select objects with jq which have a string array field that is a superset of an input array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1705180031,
                "last_edit_date": 1705180031,
                "creation_date": 1705173005,
                "answer_id": 77812766,
                "question_id": 77812664,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the updated question, going by `all` and `IN` is the best approach. Here is a reformatted version of it:\r\n```sh\r\n.[] | select(. as {$field} | all(&quot;value-1&quot;, &quot;value-3&quot;; IN($field[])))\r\n```\r\n\r\nHowever, with arrays of rather manageable lengths, you could also go by a less efficient array subtraction. If all items were present, the resulting array is expected to be empty:\r\n```sh\r\n.[] | select([&quot;value-1&quot;, &quot;value-3&quot;] - .field == [])\r\n```\r\n```json\r\n{\r\n  &quot;field&quot;: [\r\n    &quot;value-1&quot;,\r\n    &quot;value-2&quot;,\r\n    &quot;value-3&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;field&quot;: [\r\n    &quot;value-3&quot;,\r\n    &quot;value-1&quot;,\r\n    &quot;value-4&quot;,\r\n    &quot;value-5&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/Svv8Y6T0Lgf)",
                "title": "How to select objects with jq which have a string array field that is a superset of an input array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1705180031,
        "creation_date": 1705171143,
        "last_edit_date": 1705174802,
        "question_id": 77812664,
        "body_markdown": "An example is to return objects that have both &quot;value-1&quot; and &quot;value-2&quot; in the &quot;field&quot; property, using jq.\r\n\r\nObjects:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;field&quot;: [&quot;value-1&quot;, &quot;value-2&quot;, &quot;value-3&quot;]\r\n  },\r\n  {\r\n    &quot;field&quot;: [&quot;value-1&quot;, &quot;value-2&quot;, &quot;value-34&quot;]\r\n  },\r\n  {\r\n    &quot;field&quot;: [&quot;value-3&quot;, &quot;value-1&quot;, &quot;value-4&quot;, &quot;value-5&quot;]\r\n  }\r\n]\r\n```\r\n\r\nReturn:\r\n```\r\n{\r\n  &quot;field&quot;: [&quot;value-1&quot;, &quot;value-2&quot;, &quot;value-3&quot;]\r\n},\r\n{\r\n  &quot;field&quot;: [&quot;value-3&quot;, &quot;value-1&quot;, &quot;value-4&quot;, &quot;value-5&quot;]\r\n}\r\n```\r\n\r\nI&#39;ve found many examples for selecting objects that include at least one value from an array (e.g. return objects where the &quot;field&quot; property includes &quot;value-1&quot; or &quot;value-2&quot;), but I didn&#39;t find any examples to match all values. At first glance, some of the functions in jq, such as `contains` looked like they might be useful here, but actually match on substrings instead and I need exact match only.",
        "link": "https://stackoverflow.com/questions/77812664/how-to-select-objects-with-jq-which-have-a-string-array-field-that-is-a-superset",
        "title": "How to select objects with jq which have a string array field that is a superset of an input array"
    },
    {
        "tags": [
            "jq",
            "oracle-cloud-infrastructure"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705341888,
                "last_edit_date": 1705341888,
                "creation_date": 1705341321,
                "answer_id": 77821549,
                "question_id": 77821502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create the structure you want them collected in using that structure&#39;s constructor, and assign the values to the desired places within the structure using the references you have used already.\r\n\r\nInto an array, for example, using the [array constructor](https://jqlang.github.io/jq/manual/#array-construction) `[]`:\r\n```sh\r\n.data[] | [\r\n  .&quot;display-name&quot;,\r\n  .&quot;id&quot;,\r\n  .&quot;shape-config&quot;.&quot;memory-in-gbs&quot;\r\n]\r\n```\r\n```json\r\n[\r\n  &quot;TEST-VM&quot;,\r\n  &quot;ocid1.instance.&quot;,\r\n  16.0\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/6M4IhB7HIDW)\r\n\r\nOr into an object, using the [object constructor](https://jqlang.github.io/jq/manual/#object-construction) `{}`:\r\n```sh\r\n.data[]| {\r\n  &quot;display-name&quot;: .&quot;display-name&quot;,\r\n  &quot;id&quot;: .&quot;id&quot;,\r\n  &quot;memory&quot;: .&quot;shape-config&quot;.&quot;memory-in-gbs&quot;\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;display-name&quot;: &quot;TEST-VM&quot;,\r\n  &quot;id&quot;: &quot;ocid1.instance.&quot;,\r\n  &quot;memory&quot;: 16.0\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/OZX_7cJQAWv)\r\n\r\nBoth produce the structure in a sequence for each item within the `.data` array. If you want to collect them into an array, either wrap this in an outer array just as we did before:\r\n```sh\r\n[ .data[] | [ … ] ]\r\n# or\r\n[ .data[] | { … } ]\r\n```\r\nOr use the equivalent [`map`](https://jqlang.github.io/jq/manual/#map-map_values) shortcut, which performs the iteration automatically (so you can strip `[]` from `.data`):\r\n```sh\r\n.data | map( [ … ] )\r\n# or\r\n.data | map( { … } )\r\n```\r\n",
                "title": "Parse data from nested oci output with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705341544,
                "creation_date": 1705341544,
                "answer_id": 77821573,
                "question_id": 77821502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can merge the necessary keys/names separated by a comma:\r\n\r\nie.:\r\n\r\n    jq -r &#39;{name: .data[].&quot;display-name&quot;, ocid: .data[].&quot;id&quot; }&#39;",
                "title": "Parse data from nested oci output with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705627809,
                "creation_date": 1705627809,
                "answer_id": 77843258,
                "question_id": 77821502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re using jq 1.7 and don&#39;t care too much about the final structure of the result, you can use the `pick/1` function to pick the properties out from the items.\r\n\r\n```\r\n$ jq &#39;.data[] | pick(.&quot;display-name&quot;, .id, .&quot;shape-config&quot;.&quot;memory-in-gbs&quot;)&#39; input.json\r\n{\r\n  &quot;display-name&quot;: &quot;TEST-VM&quot;,\r\n  &quot;id&quot;: &quot;ocid1.instance.&quot;,\r\n  &quot;shape-config&quot;: {\r\n    &quot;memory-in-gbs&quot;: 16.0\r\n  }\r\n}\r\n```",
                "title": "Parse data from nested oci output with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1705627809,
        "creation_date": 1705340803,
        "question_id": 77821502,
        "body_markdown": "How does one parse data from nested arrays using jq?  The path to the objects within the array I&#39;ve not managed to decipher.  I&#39;m a novice in this space and YouTube examples and the myriad of questions I&#39;ve read and attempted to retool for my situation remains elusive.  Help appreciated. \r\n\r\nThe sanitized output from an oci command follows:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;agent-config&quot;: null,\r\n    &quot;availability-config&quot;: {\r\n      &quot;is-live-migration-preferred&quot;: null,\r\n      &quot;recovery-action&quot;: &quot;RESTORE_INSTANCE&quot;\r\n    },\r\n    &quot;availability-domain&quot;: &quot;AD&quot;,\r\n    &quot;capacity-reservation-id&quot;: null,\r\n    &quot;compartment-id&quot;: &quot;ocid1.compartment.&quot;,\r\n    &quot;dedicated-vm-host-id&quot;: null,\r\n    &quot;defined-tags&quot;: {},\r\n    &quot;display-name&quot;: &quot;TEST-VM&quot;,\r\n    &quot;extended-metadata&quot;: null,\r\n    &quot;fault-domain&quot;: &quot;FAULT-DOMAIN&quot;,\r\n    &quot;freeform-tags&quot;: {},\r\n    &quot;id&quot;: &quot;ocid1.instance.&quot;,\r\n    &quot;image-id&quot;: &quot;ocid1.image.&quot;,\r\n    &quot;instance-options&quot;: {\r\n      &quot;are-legacy-imds-endpoints-disabled&quot;: false\r\n    },\r\n    &quot;ipxe-script&quot;: null,\r\n    &quot;launch-mode&quot;: &quot;PARAVIRTUALIZED&quot;,\r\n    &quot;launch-options&quot;: {\r\n      &quot;boot-volume-type&quot;: &quot;PARAVIRTUALIZED&quot;,\r\n      &quot;firmware&quot;: &quot;BIOS&quot;,\r\n      &quot;is-consistent-volume-naming-enabled&quot;: false,\r\n      &quot;is-pv-encryption-in-transit-enabled&quot;: false,\r\n      &quot;network-type&quot;: &quot;PARAVIRTUALIZED&quot;,\r\n      &quot;remote-data-volume-type&quot;: &quot;PARAVIRTUALIZED&quot;\r\n    },\r\n    &quot;lifecycle-state&quot;: &quot;STOPPED&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;ssh_authorized_keys&quot;: &quot;lots_of_random&quot;\r\n    },\r\n    &quot;platform-config&quot;: null,\r\n    &quot;preemptible-instance-config&quot;: null,\r\n    &quot;region&quot;: &quot;2nd-reg&quot;,\r\n    &quot;shape&quot;: &quot;Standard1.1&quot;,\r\n    &quot;shape-config&quot;: {\r\n      &quot;baseline-ocpu-utilization&quot;: null,\r\n      &quot;gpu-description&quot;: null,\r\n      &quot;gpus&quot;: null,\r\n      &quot;local-disk-description&quot;: null,\r\n      &quot;local-disks&quot;: null,\r\n      &quot;local-disks-total-size-in-gbs&quot;: null,\r\n      &quot;max-vnic-attachments&quot;: 2,\r\n      &quot;memory-in-gbs&quot;: 16.0,\r\n      &quot;networking-bandwidth-in-gbps&quot;: 24.6,\r\n      &quot;ocpus&quot;: 1.0,\r\n      &quot;processor-description&quot;: null\r\n    },\r\n    &quot;source-details&quot;: {\r\n      &quot;boot-volume-size-in-gbs&quot;: null,\r\n      &quot;boot-volume-vpus-per-gb&quot;: null,\r\n      &quot;image-id&quot;: &quot;ocid1.image.&quot;,\r\n      &quot;kms-key-id&quot;: null,\r\n      &quot;source-type&quot;: &quot;image&quot;\r\n    },\r\n    &quot;system-tags&quot;: null,\r\n    &quot;time-created&quot;: &quot;2022-10-27T19:43:33.651460+00:00&quot;,\r\n    &quot;time-maintenance-reboot-due&quot;: null\r\n  },\r\n\r\n```\r\n\r\nI&#39;m looking for the display-name, id, memory-in-gbs.  \r\n\r\n\r\n\r\n\r\nI can gain the display-name and id with relative ease. \r\n` jq -r &#39;.data[] |.&quot;display-name&quot;, .&quot;id&quot;&#39;`\r\n\r\nI can collect the memory-in-gbs as well with the following.  \r\n`jq -r &#39;.data[] .&quot;shape-config&quot;.&quot;memory-in-gbs&quot;&#39;`\r\n\r\nI&#39;m unable to get them together. The output from above will contain multiple iterations of the above data for each vm.  I&#39;ll use the data to build other queries, but I cant clear the first hurdle. \r\n\r\nThe end goal should look like this:\r\ndisplay-name\r\nid\r\nmemory\r\n\r\nHelp appreciated. ",
        "link": "https://stackoverflow.com/questions/77821502/parse-data-from-nested-oci-output-with-jq",
        "title": "Parse data from nested oci output with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1705692041,
                "creation_date": 1705692041,
                "answer_id": 77848362,
                "question_id": 77848300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `.level2[]` within another array constructor (the outer `[…]`) just collects all items iterated over into that constructed array. Separate them to iterate outside another array, make both parts create (sub)arrays themselves, then add them together:\r\n```sh\r\n[.level1.id] + (.level2[] | [.id]) | @tsv\r\n```\r\n[Demo](https://jqplay.org/s/ZzFnD6iWhPb)\r\n\r\nAlternatively, use variables which you can reference from inside the array constructor:\r\n```sh\r\n.level2[] as {$id} | [.level1.id, $id] | @tsv\r\n```\r\n[Demo](https://jqplay.org/s/9VAENdDCvpm)\r\n\r\nOutput:\r\n```\r\na\t1\r\na\t2\r\nb\t3\r\nb\t4\r\n```\r\n",
                "title": "jq: repeat value from one object when iterating over array elements in another object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1705692491,
                "creation_date": 1705692491,
                "answer_id": 77848401,
                "question_id": 77848300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Wrap the first-level id into an array, then append each id from the second level:\r\n\r\n```\r\n[.level1.id] + (.level2[]|[.id]) | @tsv\r\n```",
                "title": "jq: repeat value from one object when iterating over array elements in another object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1705702095,
        "creation_date": 1705691198,
        "last_edit_date": 1705702095,
        "question_id": 77848300,
        "body_markdown": "Input:\r\n\r\n    {\r\n      &quot;level1&quot;: {\r\n        &quot;id&quot;: &quot;a&quot;\r\n      },\r\n      &quot;level2&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;2&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;level1&quot;: {\r\n        &quot;id&quot;: &quot;b&quot;\r\n      },\r\n      &quot;level2&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;3&quot;\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;4&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nExpected output:\r\n\r\n    a  1 \r\n    a  2 \r\n    b  3 \r\n    b  4 \r\n\r\nWhat I basically want to accomplish is:\r\n\r\n    jq -r &#39;[ .level1.id, (.level2[] |.id ) ]|@tsv&#39;\r\n\r\nwhere .level1.id repeats for every object in the .level2 array but I don&#39;t seem to be able to think about the problem the right way\r\n",
        "link": "https://stackoverflow.com/questions/77848300/jq-repeat-value-from-one-object-when-iterating-over-array-elements-in-another-o",
        "title": "jq: repeat value from one object when iterating over array elements in another object"
    },
    {
        "tags": [
            "json",
            "duplicates",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1705696262,
                "creation_date": 1705696262,
                "answer_id": 77848664,
                "question_id": 77848480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one approach using `tostream` and `fromstream` to deconstruct and reconstruct the input via stream representation, which is a stream of arrays containing a path and its corresponding value. A `foreach` loop iterates over this streams, replicating each item for later reconstruction. Additionally, it keeps track of each path-value pair reduced by the path&#39;s first item (matches occur irrelevant of their position in the original input array), and registers each appearance using a counter. If that is higher than one, also output another item (distinguished by adding `_dup` to the last path item) with the current count as value.\r\n```sh\r\nfromstream(\r\n  foreach (tostream | [., (.[0] |= .[1:] | @json)]) as [$s,$j] (\r\n    {};\r\n    if $s | has(1) then .[$j] += 1 end;\r\n    if .[$j] &gt; 1 then [($s[0] | last += &quot;_dup&quot;), .[$j]] else empty end,\r\n    $s\r\n  )\r\n)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;baz&quot;\r\n  },\r\n  {\r\n    &quot;thud&quot;: &quot;grunt&quot;,\r\n    &quot;id&quot;: &quot;fum&quot;\r\n  },\r\n  {\r\n    &quot;foo_dup&quot;: 2,\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;noot&quot;\r\n  },\r\n  {\r\n    &quot;zot&quot;: &quot;toto&quot;,\r\n    &quot;id&quot;: &quot;pluto&quot;\r\n  },\r\n  {\r\n    &quot;foo_dup&quot;: 3,\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;toto&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/mdEYdYZXHYp)",
                "title": "How do I add a new key to a jq array whenever a a key/value repeats itself"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1705743969,
                "creation_date": 1705743969,
                "answer_id": 77850504,
                "question_id": 77848480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an easy-to-understand solution, or at least it&#39;s a solution to one interpretation of the problem.  It has the advantage that it can easily be modified in accordance with other interpretations of the problem.\r\n```\r\nreduce .[] as $kv ({ ans: [], count: {}};\r\n  ($kv|del(.id)|tostring) as $pair\r\n  | .count[$pair] += 1\r\n  | .count[$pair] as $count\r\n  | if $count == 1 then .ans += [$kv]\r\n    else .ans += [$kv + {desc: &quot;duplicate #\\($count) of \\($pair)&quot;} ]\r\n    end)\r\n  | .ans\r\n      \r\n```\r\n\r\nSample output:\r\n```\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;baz&quot;\r\n  },\r\n  {\r\n    &quot;thud&quot;: &quot;grunt&quot;,\r\n    &quot;id&quot;: &quot;fum&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;noot&quot;,\r\n    &quot;desc&quot;: &quot;duplicate #2 of {\\&quot;foo\\&quot;:\\&quot;bar\\&quot;}&quot;\r\n  },\r\n  {\r\n    &quot;zot&quot;: &quot;toto&quot;,\r\n    &quot;id&quot;: &quot;pluto&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;toto&quot;,\r\n    &quot;desc&quot;: &quot;duplicate #3 of {\\&quot;foo\\&quot;:\\&quot;bar\\&quot;}&quot;\r\n  }\r\n]\r\n```",
                "title": "How do I add a new key to a jq array whenever a a key/value repeats itself"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1705743969,
        "creation_date": 1705693516,
        "question_id": 77848480,
        "body_markdown": "This is the input json. In this example json the key/value... &quot;foo:bar&quot; keeps repeating randomly. Order is not important eventhough it looks to be repeating alternately. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;baz&quot;\r\n  },\r\n  {\r\n    &quot;thud&quot;: &quot;grunt&quot;,\r\n    &quot;id&quot;: &quot;fum&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;noot&quot;\r\n  },\r\n  {\r\n    &quot;zot&quot;: &quot;toto&quot;,\r\n    &quot;id&quot;: &quot;pluto&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;toto&quot;\r\n  }  \r\n]\r\n```\r\n\r\nWhenever a key/value gets repeated, rather than removing it, would want to add an additional key/value into that particular element as shown below\r\nThe desired output would be:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;baz&quot;\r\n  },\r\n  {\r\n    &quot;thud&quot;: &quot;grunt&quot;,\r\n    &quot;id&quot;: &quot;fum&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;noot&quot;,\r\n    &quot;desc&quot;: &quot;1st duplicate found\r\n  },\r\n  {\r\n    &quot;zot&quot;: &quot;toto&quot;,\r\n    &quot;id&quot;: &quot;pluto&quot;\r\n  },\r\n  {\r\n    &quot;foo&quot;: &quot;bar&quot;,\r\n    &quot;id&quot;: &quot;toto&quot;,\r\n    &quot;desc&quot;: &quot;2nd duplicate found&quot;\r\n  } \r\n]\r\n```\r\n\r\nAgain order and numbering is not relevant/required. Added it for articulation purposes only\r\n\r\nFound several solution to remove duplicates but unable to make any headway to resolve this\r\n\r\nAppreciate any proposed resolution for above\r\n\r\nThanks much for you time\r\n\r\n\r\n\r\n\r\nTried complex solution to split the json into two and merge with -n and argjson without much break through\r\n",
        "link": "https://stackoverflow.com/questions/77848480/how-do-i-add-a-new-key-to-a-jq-array-whenever-a-a-key-value-repeats-itself",
        "title": "How do I add a new key to a jq array whenever a a key/value repeats itself"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "jmespath"
        ],
        "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": 1705713100,
                "post_id": 77848822,
                "comment_id": 137244252,
                "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": 3,
                "creation_date": 1705744040,
                "post_id": 77848822,
                "comment_id": 137245847,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1706108707,
                "creation_date": 1706108707,
                "answer_id": 77874092,
                "question_id": 77848822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you are really looking for the argument to pass to jq that will provide you the InstanceName, LaunchTime and the Tags, your first aws command provides everything you need, you just need to adjust your jq command to extract those values. The following works for me:\r\n\r\n```\r\n$ aws ec2 describe-instances --query &quot;Reservations[].Instances[?LaunchTime&lt;=&#39;$(date --date=&#39;-90 days&#39; &#39;+%Y-%m-%d&#39;)&#39;]&quot; | jq -r &#39;.[] | .[] | (.InstanceId + &quot;,&quot; + .LaunchTime) + &quot;,&quot; + (.Tags[] | .Key + &quot;=&quot; + .Value)&#39;\r\ni-08e56acf,2020-04-12T11:37:18+00:00,RemoveNote=DoNotDelete\r\ni-08e56acf,2020-04-12T11:37:18+00:00,AlwaysOn=True\r\ni-08e56acf,2020-04-12T11:37:18+00:00,Name=AD-US\r\n```\r\nNote that I put a comma (&quot;,&quot;) between the fields, and an equal (&quot;=&quot;) between the key and its value.",
                "title": "aws ec2 describe-instances and get that&#39;s older than 90 days ago outputing Instance ID, LaunchTime and Tag Name value"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1706108707,
        "creation_date": 1705698467,
        "last_edit_date": 1705704195,
        "question_id": 77848822,
        "body_markdown": "\r\nI am trying to write a JMSEpath query to return a list of Instances that&#39;s 90days old returning instances ID number, Launch Tine and the Instance Tag name if not null. \r\n\r\nI can get the instance ID and the launch time, however when I add the Tags key and values, it only returns the tags name value. See below.\r\n\r\n\r\n    aws ec2 describe-instances \\\r\n        --query &quot;Reservations[].Instances[?LaunchTime&lt;=&#39;$(date --date=&#39;-90 days&#39; &#39;+%Y-%m-%d&#39;)&#39;]&quot; | \\\r\n        jq .[][] | jq -r &#39;. | .InstanceId + &quot; &quot; + .Name + &quot; &quot; + .LaunchTime&#39;\r\n\r\n    i-0d1b4afee437442a4  2023-02-25T03:17:00+00:00\r\n    i-0e2464a16b9e6b1af  2023-10-19T18:44:34+00:00\t\r\n\r\n    aws ec2 describe-instances \\\r\n        --instance-ids i-0d1b4afee437442a4 \\\r\n        --query &quot;Reservations[*].Instances[?LaunchTime&lt;=&#39;$(date --date=&#39;-90 days&#39; &#39;+%Y-%m-%d&#39;)&#39;].[ Tags[?Key==&#39;Name&#39;].Value][0][0]&quot;\r\n\r\n    [\r\n        [\r\n            &quot;MDM-server-01&quot;\r\n        ]\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77848822/aws-ec2-describe-instances-and-get-thats-older-than-90-days-ago-outputing-insta",
        "title": "aws ec2 describe-instances and get that&#39;s older than 90 days ago outputing Instance ID, LaunchTime and Tag Name value"
    },
    {
        "tags": [
            "bash",
            "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": 1,
                "creation_date": 1705781731,
                "post_id": 77852580,
                "comment_id": 137249135,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1705781780,
                "post_id": 77852580,
                "comment_id": 137249139,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1705781869,
                "post_id": 77852580,
                "comment_id": 137249144,
                "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": 1705782054,
                "post_id": 77852580,
                "comment_id": 137249163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1705782226,
                "post_id": 77852580,
                "comment_id": 137249186,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 197511,
                    "reputation": 4034,
                    "user_id": 441634,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/2ccf0eeb146b0baa43b49ef614430ba2?s=256&d=identicon&r=PG",
                    "display_name": "JHarnach",
                    "link": "https://stackoverflow.com/users/441634/jharnach"
                },
                "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": 1705789150,
                "post_id": 77852580,
                "comment_id": 137249797,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1705781686,
        "creation_date": 1705781686,
        "question_id": 77852580,
        "body_markdown": "In a Bash script I&#39;m trying to parse a parameterized json string assigned to a variable. \r\n\r\n*(I&#39;m providing a trivialized version here of a much larger script to demostrate the issue.)*\r\n\r\nBoth examples are valid json, why does only one work ? \r\n\r\nGiven:\r\n\r\n    VALUE=&quot;1234&quot;\r\n\r\nThe following produces the expected output\r\n\r\n    GOOD_JSON=&#39;{&quot;key&quot;:$VALUE}&#39;;\r\n    echo $(jq -n --arg VALUE &quot;$VALUE&quot; $GOOD_JSON)\r\n    ##Output:\r\n    #{ &quot;key&quot;: &quot;1234&quot; }\r\n\r\nHowever introducing a single whitespace character causes an error\r\n\r\n    BAD_JSON=&#39;{&quot;key&quot;: $VALUE}&#39;;\r\n    echo $(jq -n --arg VALUE &quot;$VALUE&quot; $BAD_JSON)\r\n    ##Output:\r\n    #jq: error: syntax error, unexpected end of file (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    #{&quot;key&quot;:\r\n    #jq: 1 compile error\r\n\r\n\r\nThis is on MacOS using Bash and Zsh, with versions. 1.5 and 1.7.1 of JQ.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77852580/jq-cant-parse-json-containing-whitespace",
        "title": "JQ Can&#39;t Parse JSON Containing Whitespace"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1705956688,
                "last_edit_date": 1705956688,
                "creation_date": 1705953728,
                "answer_id": 77862466,
                "question_id": 77862400,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I would like to write a JSON object in (ascending) order of `componentIndex`.\r\n\r\n&gt; What is the correct `jq` statement to provide the nested objects in the desired sort order?\r\n\r\nYou can&#39;t (reliably) sort object fields (while retaining them as an object) because an object&#39;s order of fields is not part of the information conveyed by the JSON encoding. There is, of course, an implicit order in the actual representation of the document as a character stream, but this just happens to be the one you see. Any other ordering of object fields is still considered the same document, and any JSON processor may just disregard or even re-arrange that order without giving notice.\r\n\r\nThat said, you can, however, trick jq into generating exactly that ordering for the object by first turning it into an array representation using `to_entries` (which preserves the keys), then sorting that array (using `.value` to access its values), and then re-assembling the object using the inverse filter `from_entries` (which, as of the current version of jq at least, happens to reflect the input array&#39;s order). But keep in mind that this ordering is not guaranteed to be preserved or even interpreted as such by the next processor (including future versions of jq).\r\n\r\n```sh\r\njq &#39;to_entries | sort_by(.value.componentIndex) | from_entries&#39;\r\n```\r\n```json\r\n{\r\n  &quot;naturalKillerCells&quot;: {\r\n    &quot;componentIndex&quot;: 1,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Natural killer cells&quot;,\r\n    &quot;filenameKey&quot;: &quot;naturalKillerCells&quot;,\r\n    &quot;color&quot;: &quot;#BB2DD4&quot;\r\n  },\r\n  &quot;bCells&quot;: {\r\n    &quot;componentIndex&quot;: 2,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;B cells&quot;,\r\n    &quot;filenameKey&quot;: &quot;bCells&quot;,\r\n    &quot;color&quot;: &quot;#E6009B&quot;\r\n  },\r\n  &quot;cd34PlusProgenitor&quot;: {\r\n    &quot;componentIndex&quot;: 8,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;CD34+ progenitor&quot;,\r\n    &quot;filenameKey&quot;: &quot;cd34PlusProgenitor&quot;,\r\n    &quot;color&quot;: &quot;#ED2024&quot;\r\n  },\r\n  &quot;lungCancerCellLines&quot;: {\r\n    &quot;componentIndex&quot;: 11,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Lung cancer cell lines&quot;,\r\n    &quot;filenameKey&quot;: &quot;lungCancerCellLines&quot;,\r\n    &quot;color&quot;: &quot;#8CC63F&quot;\r\n  },\r\n  &quot;respiratoryMuscular&quot;: {\r\n    &quot;componentIndex&quot;: 12,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Respiratory / muscular&quot;,\r\n    &quot;filenameKey&quot;: &quot;respiratoryMuscular&quot;,\r\n    &quot;color&quot;: &quot;#DDE223&quot;\r\n  },\r\n  &quot;cerebellarHemisphere&quot;: {\r\n    &quot;componentIndex&quot;: 14,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Cerebellar hemisphere&quot;,\r\n    &quot;filenameKey&quot;: &quot;cerebellarHemisphere&quot;,\r\n    &quot;color&quot;: &quot;#2E97BC&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/sSwY0ZgjnaW)\r\n\r\n---\r\n\r\n&gt; The real question I am asking is how to extract the value of `color` keys in the order provided by the integers in `componentIndex`.\r\n\r\nFor that, you really just need to convert the object into a regular (you don&#39;t need the keys) array of objects using `map(.)` or `[.[]]`, then sort it using `sort_by(.componentIndex)` (note that `.componentIndex` is already a number, so `.componentIndex|tonumber` won&#39;t make a difference here), and extract from its items the fields you&#39;re interested in:\r\n```sh\r\njq -r &#39;map(.) | sort_by(.componentIndex)[].color&#39;\r\n```\r\n```\r\n#BB2DD4\r\n#E6009B\r\n#ED2024\r\n#8CC63F\r\n#DDE223\r\n#2E97BC\r\n```\r\n[Demo](https://jqplay.org/s/OIPjMurbs2F)",
                "title": "Sorting by nested integer value with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1705981958,
        "creation_date": 1705952924,
        "last_edit_date": 1705981958,
        "question_id": 77862400,
        "body_markdown": "I have a JSON object of objects:\r\n\r\n```\r\n{\r\n  &quot;lungCancerCellLines&quot;: {\r\n    &quot;componentIndex&quot;: 11,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Lung cancer cell lines&quot;,\r\n    &quot;filenameKey&quot;: &quot;lungCancerCellLines&quot;,\r\n    &quot;color&quot;: &quot;#8CC63F&quot;\r\n  },\r\n  &quot;naturalKillerCells&quot;: {\r\n    &quot;componentIndex&quot;: 1,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Natural killer cells&quot;,\r\n    &quot;filenameKey&quot;: &quot;naturalKillerCells&quot;,\r\n    &quot;color&quot;: &quot;#BB2DD4&quot;\r\n  },\r\n  &quot;respiratoryMuscular&quot;: {\r\n    &quot;componentIndex&quot;: 12,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Respiratory / muscular&quot;,\r\n    &quot;filenameKey&quot;: &quot;respiratoryMuscular&quot;,\r\n    &quot;color&quot;: &quot;#DDE223&quot;\r\n  },\r\n  &quot;cerebellarHemisphere&quot;: {\r\n    &quot;componentIndex&quot;: 14,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;Cerebellar hemisphere&quot;,\r\n    &quot;filenameKey&quot;: &quot;cerebellarHemisphere&quot;,\r\n    &quot;color&quot;: &quot;#2E97BC&quot;\r\n  },\r\n  &quot;bCells&quot;: {\r\n    &quot;componentIndex&quot;: 2,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;B cells&quot;,\r\n    &quot;filenameKey&quot;: &quot;bCells&quot;,\r\n    &quot;color&quot;: &quot;#E6009B&quot;\r\n  },\r\n  ...,\r\n  &quot;cd34PlusProgenitor&quot;: {\r\n    &quot;componentIndex&quot;: 8,\r\n    &quot;active&quot;: true,\r\n    &quot;longName&quot;: &quot;CD34+ progenitor&quot;,\r\n    &quot;filenameKey&quot;: &quot;cd34PlusProgenitor&quot;,\r\n    &quot;color&quot;: &quot;#ED2024&quot;\r\n  }\r\n}\r\n```\r\n\r\nI would like to write a JSON object in (ascending) order of `componentIndex`.\r\n\r\nBased on previous Stack Overflow questions and answers, I have tried the following statements:\r\n\r\n```\r\njq -s &#39;sort_by(.[].componentIndex)&#39; in.json &gt; out.v1.json\r\n```\r\n\r\nAnd:\r\n\r\n```\r\njq -s &#39;sort_by(.[].componentIndex|tonumber)&#39; in.json &gt; out.v2.json\r\n```\r\n\r\nThe files `out.v1.json` and `out.v2.json` are identical to `in.json` in presented order.\r\n\r\nWhat is the correct `jq` statement to provide the nested objects in the desired sort order?\r\n\r\nThe real question I am asking is how to extract the value of `color` keys in the order provided by the integers in `componentIndex`. But as a first step, it looks like I need to solve how to sort on integer values with `jq`. Thanks for your advice.",
        "link": "https://stackoverflow.com/questions/77862400/sorting-by-nested-integer-value-with-jq",
        "title": "Sorting by nested integer value with jq"
    },
    {
        "tags": [
            "bash",
            "macos",
            "jq",
            "file-permissions",
            "automator"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13921089,
                    "reputation": 153,
                    "user_id": 10085782,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/457f3b1c4b3381c0a552f6cbdadfbf09?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rr0ss0rr",
                    "link": "https://stackoverflow.com/users/10085782/rr0ss0rr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706030987,
                "post_id": 77864613,
                "comment_id": 137276784,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1706045280,
                "creation_date": 1706045280,
                "answer_id": 77869373,
                "question_id": 77864613,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you have selinux enabled? Find out by running `getenforce`. If it returns &quot;Enforcing&quot; then it could be what is blocking access to the file.\r\n\r\nYou can disable the enforcement with `sudo setenforce 0`. To confirm it isn&#39;t being enforced, just run `getenforce` again. It should return &quot;Passive&quot;.\r\n\r\nYou can use `sudo setenforce 1` to re-enable. Note these that changes are temporary in that upon next reboot it will go back to the default that is set in the /etc/sysconfig/selinux file.\r\n\r\nIf you find that selinux is enabled, Google search &quot;how to diagnose selinux issues&quot; for instructions on how to resolve issues.",
                "title": "&quot;Operation Not Permitted&quot; - Cannot get read access from App created with Automator Bash Script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1711605595,
        "creation_date": 1705994880,
        "question_id": 77864613,
        "body_markdown": "I am stuck trying to access this specific file from an App I have created with Automator. When the exact same Bash script is run from Terminal, all is dandy. I have checked permissions on the file and they are `-rw-r--r--@` (which I recognize is quarantined) and then I remove the xattr so it becomes `-rw-r--r--`, however it does seem that the attribute does get reapplied at some point (not instantaneous).\r\n\r\nThe file path is the following:\r\n\r\n`~/Library/Caches/com.apple.findmy.fmipcore/Items.data: Operation not permitted`\r\n\r\nand the application I am creating is documented here on github\r\nhttps://github.com/jbobrow/DogWalker\r\n\r\n\r\nAs a quick recap of what I&#39;ve tried:\r\nI tried changing the file permissions. I tried restarting after permission changes. I granted the application full access in System Settings. I tried removing the quarantine attribute from the file...\r\n\r\nWhen the application is run in Automator or with the app, the file isn&#39;t accessed so the CSV simply gets a blank line with the date. When I run the same bash script in Terminal, the CSV populates as desired.\r\n\r\nI look forward to a possible solution and will be thrilled to give credit in my README.md &#128517;",
        "link": "https://stackoverflow.com/questions/77864613/operation-not-permitted-cannot-get-read-access-from-app-created-with-automat",
        "title": "&quot;Operation Not Permitted&quot; - Cannot get read access from App created with Automator Bash Script"
    },
    {
        "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": 1706097273,
                "post_id": 77872831,
                "comment_id": 137284727,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 30317890,
                    "reputation": 3,
                    "user_id": 23234269,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/95bccdc18e188dae2d00e3909416e146?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "QA_Chief",
                    "link": "https://stackoverflow.com/users/23234269/qa-chief"
                },
                "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": 1706102029,
                "post_id": 77872831,
                "comment_id": 137285573,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1706098341,
                "creation_date": 1706098341,
                "answer_id": 77872947,
                "question_id": 77872831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please fix the input data first. It contains two instances of `&quot;className&quot; : &quot;className&quot; : …` which breaks JSON validity.\r\n\r\nIterate over the array items and construct a corresponding array, then use `@csv` and the `-r` flag to create a CSV output:\r\n```sh\r\njq -r &#39;\r\n  [.passCount, .failCount] + (\r\n    .suites[].cases[] | select(.status == &quot;FAILED&quot;)\r\n    | [.className, .name, .errorDetails, .status]\r\n  ) | @csv\r\n&#39;\r\n```\r\n```csv\r\n147,4,&quot;Main testsuite 2&quot;,&quot;testcase 2.2&quot;,&quot;short error message&quot;,&quot;FAILED&quot;\r\n```\r\n[Demo](https://jqplay.org/s/bc86b7QvI61)",
                "title": "JQ format jenkins testreport json to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1706101916,
        "creation_date": 1706097144,
        "last_edit_date": 1706101916,
        "question_id": 77872831,
        "body_markdown": "I have the following base file (tried to make it as minimal as possible)\r\nfrom Jenkins nightly testreport\r\n\r\n\r\n```\r\n{\r\n  &quot;_class&quot; : &quot;hudson.tasks.junit.TestResult&quot;,\r\n  &quot;testActions&quot; : [\r\n    \r\n  ],\r\n  &quot;duration&quot; : 9408.876,\r\n  &quot;empty&quot; : false,\r\n  &quot;failCount&quot; : 4,\r\n  &quot;passCount&quot; : 147,\r\n  &quot;skipCount&quot; : 1040,\r\n  &quot;suites&quot; : [\r\n    {\r\n      &quot;cases&quot; : [\r\n        {\r\n          &quot;testActions&quot; : [\r\n            \r\n          ],\r\n          &quot;age&quot; : 0,\r\n          &quot;className&quot; : &quot;Main testsuite 1&quot;,\r\n          &quot;duration&quot; : 17.281,\r\n          &quot;errorDetails&quot; : null,\r\n          &quot;errorStackTrace&quot; : null,\r\n          &quot;failedSince&quot; : 0,\r\n          &quot;name&quot; : &quot;testcase 1.1&quot;,\r\n          &quot;properties&quot; : {\r\n            \r\n          },\r\n          &quot;skipped&quot; : false,\r\n          &quot;skippedMessage&quot; : null,\r\n          &quot;status&quot; : &quot;PASSED&quot;,\r\n          &quot;stderr&quot; : null,\r\n          &quot;stdout&quot; : null\r\n        },\r\n        {\r\n          &quot;testActions&quot; : [\r\n            \r\n          ],\r\n          &quot;age&quot; : 0,\r\n          &quot;className&quot; : &quot;Main testsuite 1&quot;,\r\n          &quot;duration&quot; : 40.538,\r\n          &quot;errorDetails&quot; : null,\r\n          &quot;errorStackTrace&quot; : null,\r\n          &quot;failedSince&quot; : 0,\r\n          &quot;name&quot; : &quot;testcase 1.2&quot;,\r\n          &quot;properties&quot; : {\r\n            \r\n          },\r\n          &quot;skipped&quot; : false,\r\n          &quot;skippedMessage&quot; : null,\r\n          &quot;status&quot; : &quot;PASSED&quot;,\r\n          &quot;stderr&quot; : null,\r\n          &quot;stdout&quot; : null\r\n        }\r\n      ],\r\n      &quot;duration&quot; : 170.714,\r\n      &quot;enclosingBlockNames&quot; : [\r\n        &quot;Blockname 1&quot;,\r\n        &quot;Blockname 2&quot;\r\n      ],\r\n      &quot;enclosingBlocks&quot; : [\r\n        &quot;52&quot;,\r\n        &quot;25&quot;\r\n      ],\r\n      &quot;id&quot; : null,\r\n      &quot;name&quot; : &quot;Main testsuite 1&quot;,\r\n      &quot;nodeId&quot; : &quot;67&quot;,\r\n      &quot;properties&quot; : {\r\n        \r\n      },\r\n      &quot;stderr&quot; : null,\r\n      &quot;stdout&quot; : null,\r\n      &quot;timestamp&quot; : null\r\n    },\r\n\t  {\r\n      &quot;cases&quot; : [\r\n        {\r\n          &quot;testActions&quot; : [\r\n            \r\n          ],\r\n          &quot;age&quot; : 0,\r\n          &quot;className&quot; : &quot;Main testsuite 2&quot;,\r\n          &quot;duration&quot; : 17.781,\r\n          &quot;errorDetails&quot; : null,\r\n          &quot;errorStackTrace&quot; : null,\r\n          &quot;failedSince&quot; : 0,\r\n          &quot;name&quot; : &quot;testcase 2.1&quot;,\r\n          &quot;properties&quot; : {\r\n            \r\n          },\r\n          &quot;skipped&quot; : false,\r\n          &quot;skippedMessage&quot; : null,\r\n          &quot;status&quot; : &quot;FIXED&quot;,\r\n          &quot;stderr&quot; : null,\r\n          &quot;stdout&quot; : null\r\n        },\r\n        {\r\n          &quot;testActions&quot; : [\r\n            \r\n          ],\r\n          &quot;age&quot; : 1,\r\n          &quot;className&quot; : &quot;Main testsuite 2&quot;,\r\n          &quot;duration&quot; : 184.508,\r\n          &quot;errorDetails&quot; : &quot;short error message&quot;,\r\n          &quot;errorStackTrace&quot; : &quot;longer error message&quot;,\r\n          &quot;failedSince&quot; : 2410,\r\n          &quot;name&quot; : &quot;testcase 2.2&quot;,\r\n          &quot;properties&quot; : {\r\n            \r\n          },\r\n          &quot;skipped&quot; : false,\r\n          &quot;skippedMessage&quot; : null,\r\n          &quot;status&quot; : &quot;FAILED&quot;,\r\n          &quot;stderr&quot; : null,\r\n          &quot;stdout&quot; : &quot;Random pretty long error message&quot;\r\n        }\r\n      ],\r\n      &quot;duration&quot; : 215.862,\r\n      &quot;enclosingBlockNames&quot; : [\r\n        &quot;Others&quot;,\r\n        &quot;Blockname 2&quot;\r\n      ],\r\n      &quot;enclosingBlocks&quot; : [\r\n        &quot;98&quot;,\r\n        &quot;25&quot;\r\n      ],\r\n      &quot;id&quot; : null,\r\n      &quot;name&quot; : &quot;Main testsuite 2&quot;,\r\n      &quot;nodeId&quot; : &quot;113&quot;,\r\n      &quot;properties&quot; : {\r\n        \r\n      },\r\n      &quot;stderr&quot; : null,\r\n      &quot;stdout&quot; : null,\r\n      &quot;timestamp&quot; : null\r\n    }\r\n]\r\n \r\n}\r\n```\r\n\r\n1) from this json I need to create a csv file\r\n2) `passCount` and `failCount` in the top of the file including the values (only displayed once)\r\n3) only testcases &quot;cases&quot; that have `&quot;status&quot;: &quot;FAILED&quot;`\r\n4) generally only the key/value pairs of: `className, name, errorDetail, status`\r\n\r\n\r\nI managed to fabricate parts of my requirements but not all in one go and especially not in a csv file\r\n\r\nThat was my best attempt (I am in windows cmdline thats why the lame quotation):\r\n\r\n    jq &quot;{Passed: .passCount, Failed: .failCount, Cases: .suites[].cases[]  | select((.status==\\&quot;FAILED\\&quot;) or (.status==\\&quot;REGRESSION\\&quot;)) | pick((.className, .errorDetails, .name, .status))}&quot; build.json &gt; output.json",
        "link": "https://stackoverflow.com/questions/77872831/jq-format-jenkins-testreport-json-to-csv",
        "title": "JQ format jenkins testreport json to csv"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1706099119,
                "last_edit_date": 1706099119,
                "creation_date": 1706098896,
                "answer_id": 77873020,
                "question_id": 77872962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can split the array into chunks with `_nwise`, then `join()` those with a char of your liking:\r\n```\r\n.facet_counts.facet_fields.title | _nwise(2) | join(&quot;: &quot;)\r\n```\r\n```\r\nprimary: 5981\r\ndatabase: 5965\r\nsource: 5963\r\neecm: 5949\r\nthe: 5066\r\nresearch: 4888\r\n```\r\n\r\n\r\n----------\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/4fI4NpFnnxp)",
                "title": "json jq formatting unnamed objects onto single line"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1706099058,
                "creation_date": 1706099058,
                "answer_id": 77873040,
                "question_id": 77872962,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just pipe the output of `jq` to format it:\r\n\r\n    jq ... | paste -d, - - \r\n\r\n",
                "title": "json jq formatting unnamed objects onto single line"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1706099119,
        "creation_date": 1706098454,
        "last_edit_date": 1706098628,
        "question_id": 77872962,
        "body_markdown": "Another question re &#39;jq&#39; formatting onto a single line.   Here is my json file: \r\n\r\n```{\r\n  &quot;facet_counts&quot;:{\r\n    &quot;facet_queries&quot;:{},\r\n    &quot;facet_fields&quot;:{\r\n      &quot;title&quot;:[\r\n        &quot;primary&quot;,5981,\r\n        &quot;database&quot;,5965,\r\n        &quot;source&quot;,5963,\r\n        &quot;eecm&quot;,5949,\r\n        &quot;the&quot;,5066,\r\n        &quot;research&quot;,4888]},\r\n    &quot;facet_ranges&quot;:{}\r\n  }\r\n}\r\n```\r\nAs you see there is no label assigned for the tuplets within the title array.  I want to print the output like: -\r\n```\r\n        &quot;primary&quot;,5981,\r\n        &quot;database&quot;,5965,\r\n        &quot;source&quot;,5963,\r\n        &quot;eecm&quot;,5949,\r\n        &quot;the&quot;,5066,\r\n        &quot;research&quot;,4888\r\n```\r\n\r\nSo far, I&#39;ve been trying **jq -c &#39;.facet_counts.facet_fields.title[]&#39;**, but members of the tuplet are being output on different lines (i.e. effectively decoupled): -\r\n```\r\n&quot;primary&quot;\r\n5981\r\n&quot;database&quot;\r\n5965\r\n&quot;source&quot;\r\n5963\r\n&quot;eecm&quot;\r\n5949\r\n&quot;the&quot;\r\n5066\r\n&quot;research&quot;\r\n4888\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77872962/json-jq-formatting-unnamed-objects-onto-single-line",
        "title": "json jq formatting unnamed objects onto single line"
    },
    {
        "tags": [
            "arrays",
            "filter",
            "jq",
            "membership"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1706116862,
                "last_edit_date": 1706116862,
                "creation_date": 1706114828,
                "answer_id": 77874803,
                "question_id": 77874726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could split the list at commas into an array, then use `all` with `IN` to test the containedness for all items.\r\n```sh\r\nstr=&quot;val1,val2,val3&quot;\r\njq --arg str &quot;$str&quot; &#39;($str / &quot;,&quot;) as $arr\r\n  | map(select(. as $dot | $arr | all(IN(($dot.key1 / &quot;,&quot;)[]))).name)\r\n&#39;\r\n```\r\n```json\r\n[\r\n  &quot;foo&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/m7C3S5YRZEJ)",
                "title": "JQ query to filter entries using a membership condition over an external array passed into parameter (with --arg)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1706172097,
                "last_edit_date": 1706172097,
                "creation_date": 1706136317,
                "answer_id": 77876639,
                "question_id": 77874726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For clarity, I&#39;d use `all/2`:\r\n```\r\njq -r --arg v &quot;val1,val2,val3&quot; &#39;\r\n   ($v / &quot;,&quot;) as $values\r\n   | .[]\r\n   | select( (.key1 / &quot;,&quot;) as $kv\r\n             | all( $values[]; IN($kv[]) ))\r\n   | .name\r\n```",
                "title": "JQ query to filter entries using a membership condition over an external array passed into parameter (with --arg)"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1706172097,
        "creation_date": 1706114130,
        "last_edit_date": 1706114206,
        "question_id": 77874726,
        "body_markdown": "Given a test file test.json:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo&quot;,\r\n    &quot;key1&quot;: &quot;val3,val2,val1&quot;,\r\n    &quot;category&quot;: &quot;thefoocategory&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar&quot;,\r\n    &quot;key1&quot;: &quot;val2&quot;,\r\n    &quot;category&quot;: &quot;thebarcategory&quot;\r\n  }\r\n]\r\n```\r\n\r\nand given:\r\n\r\n```\r\nstr=&quot;val1,val2,val3&quot;\r\n```\r\n\r\nI want to filter from the file the &quot;name&quot; attributes for which the associated &quot;key1&quot; attribute, seen as an array, hold all the values (order of elements doesn&#39;t matter) of &quot;str&quot; seen as an array \\[foo\\]\r\n\r\nI try with easier use cases (replacing &quot;valX&quot; by &quot;X&quot; in the test file)  but I am stuck at specifying the condition of membership.  \r\n  \r\nSomething like:\r\n\r\n```\r\ncat test1 | jq -r --arg v &quot;1,2,3&quot; &#39;[.[] | select($v | split(&quot;,&quot;) | all((.key1 | split(&quot;,&quot;)) | index(.) != null))]&#39;\r\n```\r\n\r\nIt fails (Cannot index string with string &quot;key1&quot;) but I can&#39;t really figure out why replacing `(.key1|split(&quot;,&quot;))` with \\[1,2,3\\] produces a result.",
        "link": "https://stackoverflow.com/questions/77874726/jq-query-to-filter-entries-using-a-membership-condition-over-an-external-array-p",
        "title": "JQ query to filter entries using a membership condition over an external array passed into parameter (with --arg)"
    },
    {
        "tags": [
            "random",
            "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": 1706182219,
                "post_id": 77879588,
                "comment_id": 137296653,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19118721,
                    "reputation": 12134,
                    "user_id": 13963086,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9df2c3c4c87d8050b8fd6a59c88c7133?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "k314159",
                    "link": "https://stackoverflow.com/users/13963086/k314159"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1706186599,
                "post_id": 77879588,
                "comment_id": 137297404,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1727170688,
                "last_edit_date": 1727170688,
                "creation_date": 1706200742,
                "answer_id": 77881575,
                "question_id": 77879588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ doesn&#39;t have built-ins for generating random data but it&#39;s easy to roll your own. For example, if you had an array of objects like this:\r\n```none\r\n[\r\n  {\r\n    &quot;foo&quot;: 42\r\n  },\r\n  {\r\n    &quot;foo&quot;: 5\r\n  }\r\n]\r\n```\r\nand wanted to add a pseudo-random five-character-long `id` field to each object, you could do:\r\n```\r\ndef random_words:\r\n  def LCG($seed):\r\n    (105*$seed + 1) % pow(26; 5) | ., LCG(.);\r\n  LCG(now) | [97 + (. / pow(26; range(5)))%26] | implode;\r\n\r\n[[limit(length; random_words)], .]\r\n| transpose | map({id: .[0]} + .[1])\r\n```\r\nAnd the result would look like:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;flxai&quot;,\r\n    &quot;foo&quot;: 42\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;gfqql&quot;,\r\n    &quot;foo&quot;: 5\r\n  }\r\n]\r\n```",
                "title": "How to use JQ command to generate random string of length 5, consisting of lowercase letters(a to z)"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1706339641,
                "last_edit_date": 1706339641,
                "creation_date": 1706240579,
                "answer_id": 77884092,
                "question_id": 77879588,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want a high-entropy source of randomness and can use /dev/random\r\nin a bash or bash-like environment, \r\nthen the following illustrates a general technique for doing so while\r\nsolving the instance of the problem presented by @oguz_ismail on this page.\r\nWe suppose the JSON file containing an array of objects is in input.json\r\n\r\n```\r\n&lt; /dev/random tr -cd &#39;0-9&#39; | fold -w 1 |\r\n  jq -Mcnr --slurpfile input.json &#39;\r\n\r\n# Output: a PRN in range(0;$n) where $n is .\r\ndef prn:\r\n  if . == 1 then 0\r\n  else . as $n\r\n  | (($n-1)|tostring|length) as $w\r\n  | [limit($w; inputs)] | join(&quot;&quot;) | tonumber\r\n  | if . &lt; $n then . else ($n | prn) end\r\n  end;\r\n\r\n# pseudo-random lower-case word of the given width\r\ndef random_word($width):\r\n  [limit($width; repeat(26|prn)) + 97] | implode;\r\n\r\n# Add key id \r\nreduce $input[][] as $in ([]; . +  [$in | .id = random_word(5)] )\r\n&#39;\r\n```\r\n\r\nOf course, for the specific problem at hand, one\r\ncould simplify this to:\r\n```\r\n&lt; /dev/random tr -cd &#39;A-Za-z&#39; | tr A-Z a-z | fold -w 5 |\r\n  jq -cnRr --slurpfile input input.json &#39;\r\n# Add key id \r\nreduce $input[][] as $in ([]; . +  [$in | .id = input] )\r\n&#39;\r\n```\r\nIllustrative output:\r\n```\r\n[{&quot;foo&quot;:42,&quot;id&quot;:&quot;rduaf&quot;},{&quot;foo&quot;:5,&quot;id&quot;:&quot;qcxmw&quot;}]\r\n```",
                "title": "How to use JQ command to generate random string of length 5, consisting of lowercase letters(a to z)"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1727170688,
        "creation_date": 1706182077,
        "last_edit_date": 1706241402,
        "question_id": 77879588,
        "body_markdown": "I am not getting any function to generate random string using JQ filter\r\n\r\nI tried to use random and rand function to generate random strings, but JQ is giving error saying random or rand is not defined. I am using 1.7 version of JQ but these functions are not supported in this version.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77879588/how-to-use-jq-command-to-generate-random-string-of-length-5-consisting-of-lower",
        "title": "How to use JQ command to generate random string of length 5, consisting of lowercase letters(a to z)"
    },
    {
        "tags": [
            "io",
            "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": 1706204506,
                "post_id": 77881699,
                "comment_id": 137301039,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1706211535,
                "last_edit_date": 1706211535,
                "creation_date": 1706202479,
                "answer_id": 77881749,
                "question_id": 77881699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The filter following `seq 3 | jq -R …` actually receives not one but three inputs because the `-R` flag makes jq provide one string for each line of input. In fact, the manual says:\r\n```\r\n--raw-input / -R:\r\n\r\n    Don&#180;t parse the input as JSON. Instead, each line of text is passed\r\n    to the filter as a string. […]\r\n```\r\n\r\nBut then, when applied to each line individually, `splits(&quot;\\n&quot;)` has no effect anymore (with final newlines stripped from each input, only one partition, namely the full input string, is produced), and `seq 3 | jq -R &#39;splits(&quot;\\n&quot;)|tonumber&#39;` becomes no different from just `seq 3 | jq -R &#39;tonumber&#39;`, which just coincidentally matches your expected outcome.\r\n\r\nHowever, as the manual continues with the definition of the `-R` flag:\r\n```\r\n--raw-input / -R:\r\n\r\n    […] If combined with `--slurp`, then the entire input is passed to\r\n    the filter as a single long string.\r\n```\r\n\r\nThat&#39;s what you intended to compare the `inputs` variant against, I suppose. And running `seq 3 | jq -Rs &#39;splits(&quot;\\n&quot;)|tonumber&#39;` instead indeed receives only one input string (namely `&quot;1\\n2\\n3\\n&quot;`), which is split at newlines into a stream of substrings, then each of them is converted into a number. This produces the expected output -- and also throws an error! That&#39;s because the split actually produced four substrings, as the input contained three newline characters, with the fourth output being the empty string, which `tonumber` cannot handle. To catch up, add the error suppression operator `?`, and `seq 3 | jq -Rs &#39;splits(&quot;\\n&quot;)|tonumber?&#39;` will work as intended, producing the expecetd output without errors.\r\n\r\nAs for computing the sum of these values using `reduce`, this explains why `seq 3 | jq -R &#39;reduce …&#39;` actually runs the reduction three times, independently from each other and with one iteration each, resulting in the simple reproduction of the individual corresponding inputs (each number is separately added to the initial `0` value). Using `-Rs`, on the other hand, does the job, but the &quot;fourth&quot; value still needs more treatment. Only suppressing the conversion error would produce `empty` in that case, spoiling the numeric sum, and rendering the overall output `null`. Instead, switch to the neutral summand `0` to retain the sum, provided by the alternative operator `//`, and now you can also `reduce` the output of `seq 3` into the expected output of `6` using the `-R` (and `-s`) flags:\r\n\r\n```sh\r\nseq 3 | jq -Rs &#39;reduce splits(&quot;\\n&quot;) as $_ (0; . + ($_|tonumber? // 0))&#39;\r\n```\r\n```json\r\n6\r\n```\r\n[Demo](https://jqplay.org/s/tiT-G0_lSC5)\r\n",
                "title": "What is the difference between `jq -nR inputs` and `jq -R split(&quot;\\n&quot;)`?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1706256936,
                "last_edit_date": 1706256936,
                "creation_date": 1706215723,
                "answer_id": 77882854,
                "question_id": 77881699,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To see the difference between `jq -nR inputs` and `jq -R splits(&quot;\\n&quot;)` :\r\n\r\n```\r\n$ seq 3 | jq -nR &#39;[inputs]&#39;\r\n[\r\n  &quot;1&quot;,\r\n  &quot;2&quot;,\r\n  &quot;3&quot;\r\n]\r\n\r\n$ seq 3 | jq -R &#39;[splits(&quot;\\n&quot;)]&#39;\r\n[\r\n  &quot;1&quot;\r\n]\r\n[\r\n  &quot;2&quot;\r\n]\r\n[\r\n  &quot;3&quot;\r\n]\r\n```",
                "title": "What is the difference between `jq -nR inputs` and `jq -R split(&quot;\\n&quot;)`?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1706256936,
        "creation_date": 1706201944,
        "last_edit_date": 1706241286,
        "question_id": 77881699,
        "body_markdown": "At the first glace using `inputs` and `splits` seem to produce the same result:\r\n~~~\r\n$ seq 3 | jq -nR &#39;inputs|tonumber&#39;\r\n1\r\n2\r\n3\r\n~~~\r\n~~~\r\n$ seq 3 | jq -R &#39;splits(&quot;\\n&quot;)|tonumber&#39;\r\n1\r\n2\r\n3\r\n~~~\r\nBut when I try to reduce the input, `inputs` works:\r\n~~~\r\n$ seq 3 | jq -nR &#39;reduce inputs as $_ (0; . + ($_|tonumber))&#39;\r\n6\r\n~~~\r\nBut `splits` does not work:\r\n~~~\r\n$ seq 3 | jq -R &#39;reduce splits(&quot;\\n&quot;) as $_ (0; . + ($_|tonumber))&#39;\r\n1\r\n2\r\n3\r\n~~~\r\nWhy is `splits` not working?\r\n",
        "link": "https://stackoverflow.com/questions/77881699/what-is-the-difference-between-jq-nr-inputs-and-jq-r-split-n",
        "title": "What is the difference between `jq -nR inputs` and `jq -R split(&quot;\\n&quot;)`?"
    },
    {
        "tags": [
            "json",
            "optimization",
            "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": 1706273132,
                "post_id": 77886305,
                "comment_id": 137308911,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1706281941,
                "last_edit_date": 1706281941,
                "creation_date": 1706281623,
                "answer_id": 77887155,
                "question_id": 77886305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n- This answer assumes:\r\n  - Linux version: Debian 12 bookworm\r\n  - `jq` version: `1.6`\r\n  - Kubernetes version: `1.28.3`\r\n\r\n&lt;hr&gt;\r\n\r\n# Iterate over an array nested in a dict keyed by &#39;items&#39;\r\n\r\nUsing this (abbreviated) json output dumped from `kubectl get pods -o json -A`...\r\n\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;kind&quot;: &quot;Pod&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ubuntu1&quot;,\r\n        &quot;namespace&quot;: &quot;development-namespace1&quot;,\r\n      },\r\n   ],\r\n    {\r\n      &quot;kind&quot;: &quot;Pod&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ubuntu2&quot;,\r\n        &quot;namespace&quot;: &quot;development-namespace2&quot;,\r\n      },\r\n   ],\r\n}\r\n```\r\n\r\nAs [@pmf][1] said in a comment, you can select the value of a key nested in that array using this:\r\n\r\n```shell\r\njq &#39;.items[] | select(.metadata.name == &quot;ubuntu1&quot;).metadata.namespace&#39;\r\n```\r\n\r\n## Explanation\r\n\r\n- `.items[]` returns the array keyed by `items`\r\n- `select(.metadata.name == &quot;ubuntu1&quot;)`:\r\n  - searches all the dicts\r\n  - finds the dict matching the nested key: `metadata.name` and value: `ubuntu1`\r\n- `select(.metadata.name == &quot;ubuntu1&quot;).metadata.namespace` returns value of the `.metadata.namespace` in the selected dictionary\r\n\r\nTo reiterate, `jq &#39;.items[] | select(.metadata.name == &quot;ubuntu1&quot;)` returns:\r\n\r\n```json\r\n{\r\n  &quot;metadata&quot;: {\r\n    &quot;name&quot;: &quot;ubuntu1&quot;,\r\n    &quot;namespace&quot;: &quot;development-namespace1&quot;,\r\n  }\r\n}\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n# Bonus material, use jq for any shell command with columns\r\n\r\n## Parse &#39;ps&#39; output\r\n\r\nAssume you want to parse the output of the ps command...\r\n\r\nAssume `ps | &lt;insert-sed-jq-pipe-here&gt;` returns the following...\r\n\r\n```shell\r\n$ ps | &lt;insert-sed-jq-pipe-here&gt;\r\n    PID TTY          TIME CMD\r\n  11899 pts/0    00:00:18 bash\r\n2694259 pts/0    00:00:00 ps\r\n2694260 pts/0    00:00:00 sed\r\n2694261 pts/0    00:00:00 jq\r\n$\r\n```\r\n\r\nYou can convert any columnized text to json with:\r\n\r\n```shell\r\njq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]]&#39;\r\n```\r\n\r\n### Parse &#39;ps&#39; output as json\r\n\r\nThis example will dump the aforementioned `ps` as json...\r\n\r\n```shell\r\n$ ps | sed -ne &#39;/PID/,$ p&#39; | jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]]&#39;\r\n[\r\n  [\r\n    &quot;PID&quot;,\r\n    &quot;TTY&quot;,\r\n    &quot;TIME&quot;,\r\n    &quot;CMD&quot;\r\n  ],\r\n  [\r\n    &quot;11899&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;00:00:18&quot;,\r\n    &quot;bash&quot;\r\n  ],\r\n  [\r\n    &quot;2694259&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;00:00:00&quot;,\r\n    &quot;ps&quot;\r\n  ],\r\n  [\r\n    &quot;2694260&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;00:00:00&quot;,\r\n    &quot;sed&quot;\r\n  ],\r\n  [\r\n    &quot;2694261&quot;,\r\n    &quot;pts/0&quot;,\r\n    &quot;00:00:00&quot;,\r\n    &quot;jq&quot;\r\n  ]\r\n]\r\n$\r\n```\r\n\r\n## Parse &#39;top&#39; output as json\r\n\r\nYou can even use this technique on `top`... but `top` looks a little tricky at first because:\r\n\r\n- It&#39;s interactive by default\r\n- You get extra text before the `PID` column header.... example:\r\n\r\n```shell\r\n$ top -bn 1 | head -n 8\r\ntop - 08:54:54 up 14 days,  1:13,  0 user,  load average: 0.11, 0.22, 0.30\r\nTasks:  96 total,   1 running,  95 sleeping,   0 stopped,   0 zombie\r\n%Cpu(s):  0.0 us,  6.7 sy,  0.0 ni, 93.3 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st\r\nMiB Mem :   3767.1 total,    109.5 free,   2140.8 used,   1990.5 buff/cache\r\nMiB Swap:   1024.0 total,    898.2 free,    125.8 used.   1626.4 avail Mem\r\n\r\n    PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND\r\n2371290 root      20   0 1931856  48168  27024 S   6.7   1.2   0:30.64 flanneld\r\n$\r\n```\r\n\r\nYou can solve the interactive `top` problem with `top -bn 1`, which will run top once in non-interactive mode.\r\n\r\nFinally, that same `sed` we used in the `ps` command will strip off the lines before the `top` `PID`... so the final `top` command as json is:\r\n\r\n```shell\r\n$ top -bn 1 | sed -ne &#39;/PID/,$ p&#39; | jq -sR &#39;[sub(&quot;\\n$&quot;;&quot;&quot;) | splits(&quot;\\n&quot;) | sub(&quot;^ +&quot;;&quot;&quot;) | [splits(&quot; +&quot;)]]&#39;\r\n\r\n... insert-top-json-output-here\r\n$\r\n```\r\n\r\n  [1]: https://stackoverflow.com/users/2158479/pmf",
                "title": "Shorten kubectl jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1706281941,
        "creation_date": 1706272796,
        "last_edit_date": 1706272927,
        "question_id": 77886305,
        "body_markdown": "I am iterating over `kubectl` output that looks similar to this:\r\n\r\n```json\r\n{\r\n  &quot;apiVersion&quot;: &quot;v1&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;kind&quot;: &quot;Pod&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ubuntu1&quot;,\r\n        &quot;namespace&quot;: &quot;development-namespace1&quot;,\r\n      },\r\n   ],\r\n    {\r\n      &quot;kind&quot;: &quot;Pod&quot;,\r\n      &quot;metadata&quot;: {\r\n        &quot;name&quot;: &quot;ubuntu2&quot;,\r\n        &quot;namespace&quot;: &quot;development-namespace2&quot;,\r\n      },\r\n   ],\r\n}\r\n```\r\n\r\nI am trying to learn `jq`, but my command to get a value out of the first dictionary is really long:\r\n\r\n```shell\r\nkubectl get pods -o json -A | jq &#39;.items | .[] | select(.metadata.name == &quot;ubuntu1&quot;)  | .metadata.namespace&#39;\r\n```\r\n\r\nHow can I shorten this?",
        "link": "https://stackoverflow.com/questions/77886305/shorten-kubectl-jq-command",
        "title": "Shorten kubectl jq command"
    },
    {
        "tags": [
            "json",
            "gitlab",
            "gitlab-ci",
            "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": 1706319527,
                "post_id": 77889755,
                "comment_id": 137315400,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14633561,
                    "reputation": 46,
                    "user_id": 13848594,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/10217624343339024/picture?type=large",
                    "display_name": "Dura",
                    "link": "https://stackoverflow.com/users/13848594/dura"
                },
                "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": 1706319940,
                "post_id": 77889755,
                "comment_id": 137315427,
                "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": 1706320126,
                "post_id": 77889755,
                "comment_id": 137315439,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1706319574,
        "creation_date": 1706319307,
        "last_edit_date": 1706319574,
        "question_id": 77889755,
        "body_markdown": "I&#39;m trying to delete old environments (eg, more than 30 days old) using [GitLab&#39;s API](https://docs.gitlab.com/ee/api/environments.html#delete-an-environment). I have a working script; however, I can&#39;t seem to replace the &quot;filter date&quot; with an dynamic date, for example &quot;30 days ago&quot;.\r\n\r\n```yml\r\ndelete-environments:\r\n  before_script:\r\n    - apk add --update curl jq coreutils &amp;&amp; rm -rf /var/cache/apk/*\r\n  script:\r\n    - FILTER_DATE=$(date -d &#39;2024-01-26T20:00:58.531Z&#39; +%s)\r\n    - echo $FILTER_DATE\r\n    - OLD_ENVIRONMENTS=$(curl --header &quot;PRIVATE-TOKEN:${ENVIRONMENT_DELETER}&quot; &quot;https://gitlab.mycompany.net/api/v4/projects/${CI_PROJECT_ID}/environments?states=stopped&quot; | jq &#39;[.[] | select(.updated_at | .[0:19] +&quot;Z&quot; | fromdateiso8601 &lt; 1706299258)]&#39;)\r\n    - echo $OLD_ENVIRONMENTS\r\n```\r\n\r\nThat works, but as soon as I try to replace `1706299258` with `$FILTER_DATE`...\r\n\r\n```\r\n    - OLD_ENVIRONMENTS=$(curl --header &quot;PRIVATE-TOKEN:${ENVIRONMENT_DELETER}&quot; &quot;https://gitlab.mycompany.net/api/v4/projects/${CI_PROJECT_ID}/environments?states=stopped&quot; | jq &#39;[.[] | select(.updated_at | .[0:19] +&quot;Z&quot; | fromdateiso8601 &lt; $FILTER_DATE)]&#39;)\r\n```\r\n\r\nI get this error:\r\n\r\n```\r\njq: error: $FILTER_DATE is not defined at &lt;top-level&gt;, line 1:\r\n[.[] | select(.updated_at | .[0:19] +&quot;Z&quot; | fromdateiso8601 &lt; $FILTER_DATE)]\r\njq: 1 compile error\r\ncurl: (23) Failure writing output to destination\r\n```\r\n\r\nI&#39;ve tried all kinds of quoting schemas around `$FILTER_DATE`, but I just can&#39;t seem to get the syntax right. Help!",
        "link": "https://stackoverflow.com/questions/77889755/get-and-delete-gitlab-ci-environments-more-than-30-days-old",
        "title": "Get (and delete) GitLab CI environments more than 30 days old"
    },
    {
        "tags": [
            "json",
            "unix",
            "command-line",
            "jq",
            "text-processing"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1706465238,
                "last_edit_date": 1706465238,
                "creation_date": 1706463274,
                "answer_id": 77895746,
                "question_id": 77895726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get your desired output, use `@json` to [JSON-encode](https://jqlang.github.io/jq/manual/#format-strings-and-escaping) any input as strings. Then, use the `--raw-output` (or `-r`) flag to print the string values as is.\r\n\r\nThe simplest way would be to use [string interpolation](https://jqlang.github.io/jq/manual/#string-interpolation):\r\n```sh\r\n… | jq -r &#39;.[] | to_entries[] | @json &quot;\\(.key)\\t\\(.value)&quot;&#39;\r\n```\r\n\r\nBut you can also use `join(&quot;\\t&quot;)` from your attempt on a prepared array. In this case, using the `tojson` converter is also possible:\r\n```sh\r\n… | jq -r &#39;.[] | to_entries[] | [.key, .value | @json] | join(&quot;\\t&quot;)&#39;\r\n# or\r\n… | jq -r &#39;.[] | to_entries[] | [.key, .value | tojson] | join(&quot;\\t&quot;)&#39;\r\n```\r\n\r\nOutput:\r\n```json\r\n&quot;a1&quot;\t{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}\r\n&quot;a2&quot;\t{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:null}}\r\n```",
                "title": "how to use jq to print JSON array elements separated by tabs &quot;\\t&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1706465238,
        "creation_date": 1706462872,
        "question_id": 77895726,
        "body_markdown": "I am trying to import a json document to a sqlite3 database using the `.import` function. from what I can tell, sqlite3 .import expect the JSON data to be one line per row, with number of items matching the table column, and separated by `.separate`.\r\n\r\nif I define `.separator=&quot;\\t&quot;`, I am trying to create a reformatted json file using jq, but got an error.\r\n\r\nhere is my test\r\n```\r\n$echo &#39;[{&quot;a1&quot;:{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}},{&quot;a2&quot;:{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:&quot;test&quot;,&quot;c2&quot;:null}}}]&#39; | jq -c &#39;.[] | to_entries&#39;\r\n\r\n[{&quot;key&quot;:&quot;a1&quot;,&quot;value&quot;:{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}}]\r\n[{&quot;key&quot;:&quot;a2&quot;,&quot;value&quot;:{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:null}}}]\r\n```\r\nmy goal is to create the following tab-separated lines (\\t below means tab `\\x09`)\r\n```\r\n&quot;a1&quot;\\t{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}\r\n&quot;a2&quot;\\t{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:null}}\r\n```\r\nbut I failed to achieve this format with jq alone.\r\nI could get this separated by new-lines\r\n\r\n```\r\n$echo &#39;[{&quot;a1&quot;:{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}},{&quot;a2&quot;:{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:&quot;test&quot;,&quot;c2&quot;:null}}}]&#39; | jq -c &#39;.[] | to_entries |.[] | [.key, .value] | .[]&#39;\r\n&quot;a1&quot;\r\n{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}\r\n&quot;a2&quot;\r\n{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:null}}\r\n```\r\nbut if I use join(&quot;\\t&quot;), it complains that it can not join a string with an object\r\n```\r\necho &#39;[{&quot;a1&quot;:{&quot;b1&quot;:1,&quot;c1&quot;:{&quot;c1&quot;:&quot;test&quot;,&quot;c2&quot;:null}}},{&quot;a2&quot;:{&quot;b2&quot;:1,&quot;c&quot;:{&quot;c2&quot;:&quot;test&quot;,&quot;c2&quot;:null}}}]&#39; | jq -c &#39;.[] | to_entries | .[] | [.key, .value] | join(&quot;\\t&quot;)&#39;\r\njq: error (at &lt;stdin&gt;:1): string (&quot;a1\\t&quot;) and object ({&quot;b1&quot;:1,&quot;c1...) cannot be added\r\n```\r\n\r\nI could use perl or sed to postprocess the new-line separated text to get what I wanted, but I hope to learn how to do this properly with `jq`.\r\n\r\nis this possible?",
        "link": "https://stackoverflow.com/questions/77895726/how-to-use-jq-to-print-json-array-elements-separated-by-tabs-t",
        "title": "how to use jq to print JSON array elements separated by tabs &quot;\\t&quot;"
    },
    {
        "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": 1706625146,
                "post_id": 77906806,
                "comment_id": 137346771,
                "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": 1706625376,
                "post_id": 77906806,
                "comment_id": 137346815,
                "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": 1706626047,
                "post_id": 77906806,
                "comment_id": 137346957,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29508804,
                    "reputation": 21,
                    "user_id": 22614294,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/562bc4d3ae3f3a8813aee33e9ac03f03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pkulkarni",
                    "link": "https://stackoverflow.com/users/22614294/pkulkarni"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706856907,
                "post_id": 77906806,
                "comment_id": 137378309,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1713046990,
                "creation_date": 1713046990,
                "answer_id": 78322192,
                "question_id": 77906806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As explained into comments by Inian to get the uniques values just run `.sc | unique` [example here](https://jqplay.org/s/GLcV2ll2wDW) (or `unique[]` to get as an array).\r\n\r\nBy the way if &quot;unique&quot; constraint is based on some field, then you can run `.sc | unique_by(.pn)`. [Here](https://jqplay.org/s/3sskss0pyr-) the constraint is by `pn`.\r\n\r\nBut it seems it is not the problem. It is not quite clear what do you want because the first JSON defined as &quot;input JSON&quot; is not even a list but you said you have two lists (where are the two lists???)\r\n\r\nSo assuming the second JSON as input one (if this assumption is not true the key concept will be the same) you can try something like this: Concatenate your lists and then you can use `unique` as explained above.\r\n\r\nJust try something like [this example](https://jqplay.org/s/Zu8h_KcTySi) where I&#39;ve used `.[0] + .[1] | unique` but maybe your lists are in some object key or whatever, then just get the desired lists to concatenate and it will be the same.",
                "title": "How to select unique JSON objects from Identical JSON array with JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1713046990,
        "creation_date": 1706622248,
        "question_id": 77906806,
        "body_markdown": "Below is the input JSON: \r\n\r\n```\r\n{\r\n  &quot;sn&quot;: &quot;fdd&quot;,\r\n \r\n  &quot;sc&quot;: [\r\n    {\r\n      &quot;pn&quot;: &quot;di&quot;,\r\n      &quot;pv&quot;: {\r\n        &quot;val&quot;: &quot;26&quot;,\r\n        &quot;com&quot;: &quot;=&quot;\r\n      },\r\n      &quot;fix&quot;: &quot;Hello&quot;,\r\n      &quot;tp&quot;: &quot;String&quot;\r\n    },\r\n    {\r\n      &quot;pn&quot;: &quot;di2&quot;,\r\n      &quot;pv&quot;: {\r\n        &quot;val&quot;: &quot;28&quot;,\r\n        &quot;com&quot;: &quot;=&quot;\r\n      },\r\n      &quot;fix&quot;: &quot;Hello2&quot;,\r\n      &quot;tp&quot;: &quot;String&quot;\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nBelow is the JQ Command I have tried which is generating identical objects:\r\n```\r\ndef getWhereVal(input):\r\n[input.sc[]] | unique;\r\ndef getPreVal(input):\r\ninput.sc[].fix;\r\n. as $input | getPreVal($input) as $preVal | getWhereVal($input)\r\n```\r\n\r\nI am getting below output from above JQ command:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;pn&quot;: &quot;di&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;26&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  },\r\n  {\r\n    &quot;pn&quot;: &quot;di2&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;28&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello2&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;pn&quot;: &quot;di&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;26&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  },\r\n  {\r\n    &quot;pn&quot;: &quot;di2&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;28&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello2&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nI aim to retrieve a distinct object from a set of identical objects, as illustrated below:\r\n\r\n```\r\n{\r\n    &quot;pn&quot;: &quot;di&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;26&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  },\r\n  {\r\n    &quot;pn&quot;: &quot;di2&quot;,\r\n    &quot;pv&quot;: {\r\n      &quot;val&quot;: &quot;28&quot;,\r\n      &quot;com&quot;: &quot;=&quot;\r\n    },\r\n    &quot;fix&quot;: &quot;Hello2&quot;,\r\n    &quot;tp&quot;: &quot;String&quot;\r\n  }\r\n```\r\n\r\nCan someone please help me to get desired output, I am not able to get result using unique function.",
        "link": "https://stackoverflow.com/questions/77906806/how-to-select-unique-json-objects-from-identical-json-array-with-jq",
        "title": "How to select unique JSON objects from Identical JSON array with JQ"
    },
    {
        "tags": [
            "streaming",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1706646993,
                "last_edit_date": 1706646993,
                "creation_date": 1706629571,
                "answer_id": 77907614,
                "question_id": 77907536,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand correctly, your input is a already stream of objects which you want to filter by the presence of a key. This can simply be done using `select` and `has` as follows:\r\n```sh\r\njq &#39;select(has(&quot;process_exit&quot;))&#39;\r\n```\r\n\r\nIf this should be a continuation of another filter (as suggested by your preceding question) which closed with a `select` by itself, simply use a pipe  to combine the two:\r\n```sh\r\n… | jq &#39;… | select(… and has(&quot;process_exit&quot;))&#39;\r\n```\r\n\r\n---\r\n\r\nIf for some reason you need to generate the input with `--stream`, use `inputs` with the `-n` flag to capture and process the broken-down parts:\r\n```\r\njq --stream -n &#39;fromstream(inputs) | select(has(&quot;process_exit&quot;))&#39;\r\n```\r\n\r\nCapturing on a deeper level (as with `truncate_stream` and then `select(.[0][0] …)`) doesn&#39;t make sense (here), as\r\n- you&#39;d miss the sibling nodes, and would only be able to reconstruct the object on that deeper level (i.e. only the parts below `.process_exit`), but you actually want to reproduce the whole object if it matches (if I understand correctly)\r\n- you don&#39;t get any memory benefits from individually processing only parts of the input objects (this is often the reason for using `truncate_stream`) because in the end you still have to reconstruct the whole object in memory in order to produce it as output (again, if I understand correctly that whole objects is your expected output)",
                "title": "Non-trivial example with jq --stream"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1706646993,
        "creation_date": 1706628840,
        "question_id": 77907536,
        "body_markdown": "This is a follow-up to @kojiro&#39;s comment on my earlier question [*Bash losing string escapes when piping*][1] that recommends `jq --stream`. My problem involves a stream of [Tetragon events][2] that arrive in a JSON file. The structure is as follows:\r\n\r\n```\r\n...\r\n{\r\n  &quot;process_exec&quot;: {\r\n    &quot;process&quot;: {\r\n      &quot;pid&quot;: ...,\r\n      &quot;uid&quot;: ...,\r\n      &quot;binary&quot;: &quot;...&quot;,\r\n      ...\r\n    },\r\n    &quot;parent&quot;: {\r\n      ...\r\n    }\r\n  },\r\n  &quot;time&quot;: &quot;...&quot;\r\n}\r\n{\r\n  &quot;process_exit&quot;: {\r\n    &quot;process&quot;: {\r\n      ...\r\n    },\r\n    &quot;parent&quot;: {\r\n      ...\r\n    }\r\n  },\r\n  &quot;time&quot;: &quot;...&quot;\r\n}\r\n...\r\n```\r\n\r\nI would like to filter the stream such that only records of &quot;type&quot; `process_exit` remain. I have consulted the jq manual section on [*Streaming*][3] and a writeup [*Streaming With JQ*][4], but to no avail so far. I have also tried the following expression and many similar variants: jq streaming [isn&#39;t easy to deal with][3] indeed. So how can I solve my particular problem? In summary: how can I employ `jq --streaming` in this case?\r\n\r\n \r\n```\r\ntail -f file | jq --stream \\\r\n  &#39;fromstream(0 | truncate_stream(select(.[0][0] == &quot;process_exit&quot;)))\r\n```\r\n  [1]: https://stackoverflow.com/questions/77902601/bash-losing-string-escapes-when-piping\r\n  [2]: https://tetragon.io/docs/concepts/events/\r\n  [3]: https://jqlang.github.io/jq/manual/#streaming\r\n  [4]: https://www.reddit.com/r/bash/comments/myoft4/streaming_with_jq/",
        "link": "https://stackoverflow.com/questions/77907536/non-trivial-example-with-jq-stream",
        "title": "Non-trivial example with jq --stream"
    },
    {
        "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": 1706632999,
                "post_id": 77907894,
                "comment_id": 137348409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1706639330,
                "post_id": 77907894,
                "comment_id": 137349529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1706648975,
                "post_id": 77907894,
                "comment_id": 137351074,
                "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": 1706649031,
                "post_id": 77907894,
                "comment_id": 137351080,
                "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": 1706696915,
                "post_id": 77907894,
                "comment_id": 137356236,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1706683041,
                "last_edit_date": 1706683041,
                "creation_date": 1706648357,
                "answer_id": 77909376,
                "question_id": 77907894,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming &quot;$param&quot; has the value &quot;def.args-pod&quot; won&#39;t work when interpolated into the invocation of jq.\r\n\r\n`jq &quot;.$param&quot; &quot;$file&quot;` would become `jq &#39;.def.args-pod&#39; &#39;/path/to/file&#39;` which is obviously incorrect. For the program to be correct, this needs to be `.&quot;def.args-pod&quot;` or `.[&quot;def.args-pod&quot;]`.\r\n\r\nBut you shouldn&#39;t use string interpolation to build jq programs anyway, instead pass variables and use those:\r\n\r\n```\r\njq --arg prop &quot;$param&quot; &#39;.[$prop]&#39; &quot;$file&quot;\r\n```\r\n\r\nThis assumes your input JSON looks like this:\r\n\r\n```\r\n{\r\n  &quot;def.args-pod&quot;: &quot;some value, array, or nested object&quot;\r\n}\r\n```\r\n\r\nIf it doesn&#39;t, please edit your answer to provide a [minimal, reproducible example](https://stackoverflow.com/help/minimal-reproducible-example).\r\n\r\nFurther reading: https://stackoverflow.com/questions/37018393/how-to-use-jq-when-the-variable-has-reserved-characters",
                "title": "jq: error: versions/0 is not defined at &lt;top-level&gt;, line 1:"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1706696636,
        "creation_date": 1706631961,
        "last_edit_date": 1706696636,
        "question_id": 77907894,
        "body_markdown": "This is my script that should compare 2 files but parameters bring from 3rd txt file\r\n\r\n```\r\ndiff_output=$(diff &lt;(jq &quot;.$param&quot; &quot;$path_to_file1&quot;) &lt;(jq &quot;.$param&quot; &quot;$path_to_file2&quot;))\r\n```\r\nin my txt file \r\n\r\n```\r\n.txt\r\nargs1,args2,def.args-pod,def.car\r\n```\r\nargs1,args2,def.car are work but def.args-pod no and send answer \r\n\r\n```\r\njq: error: pod/0 is not defined at &lt;top-level&gt;, line 1:\r\n```\r\n\r\nplease help me change this \r\ndiff_output=$(diff &lt;(jq &quot;.$param&quot; &quot;$path_to_file1&quot;) &lt;(jq &quot;.$param&quot; &quot;$path_to_file2&quot;))\r\n\r\n\r\nmy yaml \r\n\r\n```\r\n{\r\n  &quot;args1&quot;: &quot;/my-api/&quot;,\r\n  &quot;def&quot;: {\r\n    &quot;args-pod&quot;: &quot;^0.7.9&quot;,\r\n    &quot;car&quot;: &quot;^0.8.8&quot;},\r\n   &quot;args2&quot;: &quot;^0.9.5&quot;,\r\n}\r\n```\r\n \r\n",
        "link": "https://stackoverflow.com/questions/77907894/jq-error-versions-0-is-not-defined-at-top-level-line-1",
        "title": "jq: error: versions/0 is not defined at &lt;top-level&gt;, line 1:"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq",
            "text-processing"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1706643571,
                "last_edit_date": 1706643571,
                "creation_date": 1706642434,
                "answer_id": 77908906,
                "question_id": 77908875,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have very limited options how jq does pretty-printing.\r\nYour best bet is to write your own. Here&#39;s a very manual approach using `to_entries` and `@json`\r\n```sh\r\njq -r &#39;\r\n  &quot;{&quot;, ([to_entries[] | @json &quot;\\(.key):\\(.value)&quot;] | .[:-1][] += &quot;,&quot;)[], &quot;}&quot;\r\n&#39;\r\n```\r\n```json\r\n{\r\n&quot;a&quot;:{&quot;a1&quot;:1,&quot;a2&quot;:[null]},\r\n&quot;b&quot;:{&quot;b1&quot;:&quot;test&quot;},\r\n&quot;c&quot;:[1,2,3]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/MFxSVvQkIe9)",
                "title": "how to use jq to print one-line per root-level object key?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1706643571,
        "creation_date": 1706642190,
        "last_edit_date": 1706643103,
        "question_id": 77908875,
        "body_markdown": "I would like to compress the space for a json file by printing in compact mode (`-c`) but I want to add a new line after each root-level object.\r\n\r\nfor example, for the below object\r\n```json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;a1&quot;: 1,\r\n    &quot;a2&quot;: [\r\n      null\r\n    ]\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;b1&quot;: &quot;test&quot;\r\n  },\r\n  &quot;c&quot;: [\r\n    1,\r\n    2,\r\n    3\r\n  ]\r\n}\r\n```\r\nI would like to print it as\r\n```json\r\n{\r\n&quot;a&quot;:{&quot;a1&quot;:1,&quot;a2&quot;:[null]},\r\n&quot;b&quot;:{&quot;b1&quot;:&quot;test&quot;},\r\n&quot;c&quot;:[1,2,3]\r\n}\r\n```\r\ni.e., one root-level object per line (adding the start/end brackets)\r\n\r\nI got as far as printing each item in one line using\r\n```json\r\necho &#39;{&quot;a&quot;:{&quot;a1&quot;:1, &quot;a2&quot;:[null]}, &quot;b&quot;: {&quot;b1&quot;:&quot;test&quot;}, &quot;c&quot;: [1,2,3]}&#39; | jq -c -r &#39;. | to_entries | .[] | &quot;\\&quot;\\(.key)\\&quot;: \\(.value)&quot;&#39;\r\n\r\n&quot;a&quot;: {&quot;a1&quot;:1,&quot;a2&quot;:[null]}\r\n&quot;b&quot;: {&quot;b1&quot;:&quot;test&quot;}\r\n&quot;c&quot;: [1,2,3]\r\n```\r\nbut I am not able to form a single valid JSON object.\r\n\r\ncan someone offer some suggestions?\r\nthanks\r\n\r\nUpdate:\r\n\r\nI managed to achieve the goal using a combination of jq and perl\r\n```\r\necho &#39;{&quot;a&quot;:{&quot;a1&quot;:1, &quot;a2&quot;:[null]}, &quot;b&quot;: {&quot;b1&quot;:&quot;test&quot;}, &quot;c&quot;: [1,2,3]}&#39; | jq -c -r &#39;. | to_entries | .[] | @json &quot;\\(.key): \\(.value)&quot;&#39; | perl -pe &#39;s/$/,/m if !eof&#39; | perl -p0e &#39;s/^/{\\n/&#39; | perl -p0e &#39;s/$/\\n}/&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/77908875/how-to-use-jq-to-print-one-line-per-root-level-object-key",
        "title": "how to use jq to print one-line per root-level object key?"
    },
    {
        "tags": [
            "json",
            "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": 1706669305,
                "post_id": 77910541,
                "comment_id": 137353064,
                "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": 1706669322,
                "post_id": 77910541,
                "comment_id": 137353067,
                "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": 1706669906,
                "post_id": 77910541,
                "comment_id": 137353108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16534042,
                    "reputation": 81,
                    "user_id": 11946521,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fbTnO.png?s=256",
                    "display_name": "Varesh Gandham",
                    "link": "https://stackoverflow.com/users/11946521/varesh-gandham"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706670016,
                "post_id": 77910541,
                "comment_id": 137353118,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13448212,
                    "reputation": 1,
                    "user_id": 18742579,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d7a18e028f71a6872edc4cb85741c67b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Navaratnam",
                    "link": "https://stackoverflow.com/users/18742579/navaratnam"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706672600,
                "post_id": 77910541,
                "comment_id": 137353273,
                "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": 1706673633,
                "post_id": 77910541,
                "comment_id": 137353349,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706729282,
                "post_id": 77910541,
                "comment_id": 137362270,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1706975612,
                "last_edit_date": 1706975612,
                "creation_date": 1706715481,
                "answer_id": 77914588,
                "question_id": 77910541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should give you exactly what you want:\r\n```\r\n$ cat filename | jq -r &#39;&quot;\\&quot;username\\&quot;: \\&quot;&quot; + .requestData.username + &quot;\\&quot;, \\&quot;eventTime\\&quot;: \\&quot;&quot; + .eventTime + &quot;\\&quot;&quot;&#39;\r\n&quot;username&quot;: &quot;admin&quot;, &quot;eventTime&quot;: &quot;2023-12-01T23:50:02.554+0000&quot;\r\n```\r\nIf you just want the values:\r\n```\r\n$ cat filename | jq -r &#39;&quot;\\&quot;&quot; + .requestData.username + &quot;\\&quot;, \\&quot;&quot; + .eventTime + &quot;\\&quot;&quot;&#39;\r\n&quot;admin&quot;, &quot;2023-12-01T23:50:02.554+0000&quot;\r\n```\r\nOr, if you want to use string interpolation as Jeff suggests:\r\n```\r\n$ cat filename | jq -r &#39;&quot;\\&quot;username\\&quot;: \\&quot;\\(.requestData.username)\\&quot;, \\&quot;eventTime\\&quot;: \\&quot;\\(.eventTime)\\&quot;&quot;&#39;\r\n&quot;username&quot;: &quot;admin&quot;, &quot;eventTime&quot;: &quot;2023-12-01T23:50:02.554+0000&quot;\r\n```",
                "title": "how to get objects from json file?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707071270,
                "creation_date": 1707071270,
                "answer_id": 77937079,
                "question_id": 77910541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not pretty, but building an array first, then joining the json-encoded values on colon, followed by a join on comma:\r\n\r\n```\r\njq -r &#39;\r\n[[&quot;username&quot;, .requestData.username], [&quot;eventTime&quot;, .eventTime]]\r\n| map(map(tojson)|join(&quot;:&quot;))\r\n| join(&quot;,&quot;)\r\n&#39;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;username&quot;:&quot;admin&quot;,&quot;eventTime&quot;:&quot;2023-12-01T23:50:02.554+0000&quot;\r\n```",
                "title": "how to get objects from json file?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1707071270,
        "creation_date": 1706669077,
        "question_id": 77910541,
        "body_markdown": "I have a json file as below\r\n\r\n    {\r\n      &quot;requestData&quot;: {\r\n        &quot;username&quot;: &quot;admin&quot;\r\n      },\r\n      &quot;eventTime&quot;: &quot;2023-12-01T23:50:02.554+0000&quot;,\r\n      &quot;observer&quot;: {\r\n        &quot;id&quot;: &quot;target&quot;\r\n      }\r\n\r\nI want to get only the below output side by side,O/P\r\n\r\n    &quot;username&quot;: &quot;admin&quot;,&quot;eventTime&quot;: &quot;2023-12-01T23:50:02.554+0000&quot;\r\n\r\nI tried using below but, able to get only one record at a time, how to nest both and get above output\r\n\r\n    cat filename  | jq &#39;.requestData.username&#39;\r\n\r\n\r\n}",
        "link": "https://stackoverflow.com/questions/77910541/how-to-get-objects-from-json-file",
        "title": "how to get objects from json file?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1706724396,
                "post_id": 77915548,
                "comment_id": 137361495,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1707070939,
                "creation_date": 1707070939,
                "answer_id": 77937061,
                "question_id": 77915548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming you want a stream of objects having a key with the string value `&quot;10270&quot;`:\r\n\r\n```\r\n.issuesData.issues[] | select(.statusId == &quot;10270&quot;)\r\n```\r\n\r\nAssuming you want an _array_ containing all matching objects:\r\n\r\n```\r\n.issuesData.issues | map(select(.statusId == &quot;10270&quot;))\r\n```\r\n\r\nAssuming you want to modify the original structure to only keep the matching objects:\r\n\r\n```\r\n.issuesData.issues |= map(select(.statusId == &quot;10270&quot;))\r\n```\r\n\r\nIf you only want the ids of the objects having the specified statusId:\r\n\r\n```\r\n.issuesData.issues[] | select(.statusId == &quot;10270&quot;).id\r\n```\r\n\r\nIf you need the ids as JSON array:\r\n\r\n```\r\n.issuesData.issues | map(select(.statusId == &quot;10270&quot;).id)\r\n```",
                "title": "JSON element selection using jq - how to do?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707070939,
        "creation_date": 1706724253,
        "last_edit_date": 1706729992,
        "question_id": 77915548,
        "body_markdown": "I am following the examples online when trying to select elements of that array but something very weird happens.\r\n\r\nWhen I run\r\n```.issuesData.issues[] ``` it displays the array as expected.  Fine.\r\n\r\nThen I try to select only the nodes with `statusId == 10270`.  this would give me, as expected result, just the last node.\r\n\r\nBut the result is the array of the 2 objects having all elements assigned with `statusId = 10270`.\r\n\r\n```.issuesData.issues[].statusId=&quot;10270&quot;  ```\r\n\r\nIf I try a slightly different approach like that\r\n\r\n```.issuesData.issues[].statusId==&quot;10270&quot;  ```\r\n\r\nI get an array \r\n```\r\nfalse\r\ntrue\r\n```\r\nand this makes sense because only the second elements fits he criteria.  But what I am trying to get is just the element itself or at least the &quot;key&quot;\r\nThe JSON object is like below.\r\n\r\n``` \r\n{\r\n  &quot;issuesData&quot;: {\r\n    &quot;issues&quot;: [\r\n      {\r\n        &quot;id&quot;: 3619364,\r\n        &quot;key&quot;: &quot;AIG-1992&quot;,\r\n        &quot;hidden&quot;: false,\r\n        &quot;typeId&quot;: &quot;1&quot;,\r\n        &quot;summary&quot;: &quot;XXXXXX&quot;,\r\n        &quot;priorityId&quot;: &quot;2&quot;,\r\n        &quot;done&quot;: false,\r\n        &quot;assignee&quot;: &quot;XXXX&quot;,\r\n        &quot;assigneeName&quot;: &quot;XXXX&quot;,\r\n        &quot;hasCustomUserAvatar&quot;: false,\r\n        &quot;autoUserAvatar&quot;: {\r\n          &quot;letter&quot;: &quot;B&quot;,\r\n          &quot;color&quot;: &quot;#d39c3f&quot;\r\n        },\r\n        &quot;color&quot;: &quot;#ff0000&quot;,\r\n        &quot;epicId&quot;: &quot;3557134&quot;,\r\n        &quot;epic&quot;: &quot;AIG-1&quot;,\r\n        &quot;estimateStatisticRequired&quot;: false,\r\n        &quot;statusId&quot;: &quot;10370&quot;,\r\n        &quot;fixVersions&quot;: [\r\n          120044\r\n        ],\r\n        &quot;projectId&quot;: 49202\r\n      },\r\n      {\r\n        &quot;id&quot;: 3617950,\r\n        &quot;key&quot;: &quot;AIG-1938&quot;,\r\n        &quot;hidden&quot;: false,\r\n        &quot;typeId&quot;: &quot;1&quot;,\r\n        &quot;summary&quot;: &quot;YYYYYY&quot;,\r\n        &quot;priorityId&quot;: &quot;2&quot;,\r\n        &quot;done&quot;: false,\r\n        &quot;assignee&quot;: &quot;YYYY&quot;,\r\n        &quot;assigneeName&quot;: &quot;YYY&quot;,\r\n        &quot;hasCustomUserAvatar&quot;: false,\r\n        &quot;autoUserAvatar&quot;: {\r\n          &quot;letter&quot;: &quot;F&quot;,\r\n          &quot;color&quot;: &quot;#7bc1a1&quot;\r\n        },\r\n        &quot;color&quot;: &quot;#ff0000&quot;,\r\n        &quot;epicId&quot;: &quot;3658470&quot;,\r\n        &quot;epic&quot;: &quot;AIG-574&quot;,\r\n        &quot;estimateStatisticRequired&quot;: false,\r\n        &quot;statusId&quot;: &quot;10270&quot;,\r\n        &quot;fixVersions&quot;: [],\r\n        &quot;projectId&quot;: 49202\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nWhat I am doing wrong here?",
        "link": "https://stackoverflow.com/questions/77915548/json-element-selection-using-jq-how-to-do",
        "title": "JSON element selection using jq - how to do?"
    },
    {
        "tags": [
            "json",
            "jwt",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1706748644,
                "last_edit_date": 1706748644,
                "creation_date": 1706748452,
                "answer_id": 77917170,
                "question_id": 77917165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Split the value of `.token` at the dot into an array, take the second item, and use `@base64d` to decode base64, and `fromjson` to interpret the output as JSON:\r\n```sh\r\njq &#39;.token |= ((./&quot;.&quot;)[1] | @base64d | fromjson)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: 7,\r\n  &quot;time&quot;: &quot;now&quot;,\r\n  &quot;token&quot;: {\r\n    &quot;name&quot;: &quot;bobby&quot;,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;tree&quot;: &quot;elm&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/nAoI7N6loN_h)",
                "title": "How to get the claims from a JWT token in JSON into the object?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1707147632,
                "last_edit_date": 1707147632,
                "creation_date": 1706748490,
                "answer_id": 77917173,
                "question_id": 77917165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [string division](https://jqlang.github.io/jq/manual/#multiplication-division-modulo) to split the token on dots, the `@base64d` filter to base64 decode the data, and the `fromjson` filter to turn the string into JSON.\r\n\r\nThe `|=` update operator can be used to assign the result back to the `.token` field.\r\n\r\n    jq &#39;.token |= ((. / &quot;.&quot;)[1] | @base64d | fromjson)&#39; file.json\r\n\r\nResult:\r\n\r\n    {\r\n      &quot;id&quot;: 7,\r\n      &quot;time&quot;: &quot;now&quot;,\r\n      &quot;token&quot;: {\r\n        &quot;name&quot;: &quot;bobby&quot;,\r\n        &quot;color&quot;: &quot;blue&quot;,\r\n        &quot;tree&quot;: &quot;elm&quot;\r\n      }\r\n    }\r\n\r\nYou can also use the `splits` function to split the token on dots:\r\n\r\n    jq &#39;.token |= ([splits(&quot;\\\\.&quot;)][1] | @base64d | fromjson)&#39; file.json\r\n",
                "title": "How to get the claims from a JWT token in JSON into the object?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1707147632,
        "creation_date": 1706748305,
        "question_id": 77917165,
        "body_markdown": "I have a JSON object that contains a JWT token. I would like to extract the claims from the token and put them into the JSON object, replacing the token. Here is my object:\r\n\r\n```\r\n{\r\n  &quot;id&quot;: 7,\r\n  &quot;time&quot;: &quot;now&quot;,\r\n  &quot;token&quot;: &quot;eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiYm9iYnkiLCJjb2xvciI6ImJsdWUiLCJ0cmVlIjoiZWxtIn0K.9JCVXpkI6ICc5RnIsIiN1IzUIJiOicGbhJye&quot;\r\n}\r\n```\r\n\r\nThe JWT contains these claims (base64 encoded in the middle field of the JWT, delimited by dots):\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;bobby&quot;,\r\n    &quot;color&quot;: &quot;blue&quot;,\r\n    &quot;tree&quot;: &quot;elm&quot;\r\n}\r\n```\r\n\r\nHow can I pull out the claims and put them into the JSON in place of the JWT token using jq?",
        "link": "https://stackoverflow.com/questions/77917165/how-to-get-the-claims-from-a-jwt-token-in-json-into-the-object",
        "title": "How to get the claims from a JWT token in JSON into the object?"
    },
    {
        "tags": [
            "jq",
            "azure-cli"
        ],
        "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": 1706776452,
                "post_id": 77918614,
                "comment_id": 137367193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23957303,
                    "reputation": 21,
                    "user_id": 17947984,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx_VN9lcdhm1v3kPHr7fjVZaSgodbY3Toq9ldko=k-s256",
                    "display_name": "Gapi",
                    "link": "https://stackoverflow.com/users/17947984/gapi"
                },
                "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": 1706789134,
                "post_id": 77918614,
                "comment_id": 137369273,
                "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": 1706791787,
                "post_id": 77918614,
                "comment_id": 137369724,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23957303,
                    "reputation": 21,
                    "user_id": 17947984,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJx_VN9lcdhm1v3kPHr7fjVZaSgodbY3Toq9ldko=k-s256",
                    "display_name": "Gapi",
                    "link": "https://stackoverflow.com/users/17947984/gapi"
                },
                "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": 1706835402,
                "post_id": 77918614,
                "comment_id": 137376705,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707202745,
                "last_edit_date": 1707202745,
                "creation_date": 1707070652,
                "answer_id": 77937043,
                "question_id": 77918614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your loop looks unnecessarily complex (and maybe you don&#39;t even need it at all). Here&#39;s how you would construct a JSON array with computed values with jq in a shell loop:\r\n\r\n```\r\ninput=&quot;names.csv&quot;\r\nwhile IFS= read -r secretName || [ -n &quot;$secretName&quot; ];\r\ndo\r\n    jq --arg name &quot;$secretName&quot; -n &#39;{$name, newValue: &quot;****&quot;}&#39;\r\ndone &lt; &quot;$input&quot; | jq -s &#39;{secrets:.}&#39; &gt; jsonOutput.json\r\n```\r\n\r\nThis will create a stream of JSON objects first and will then collect them into a single array with the `-s` (`--slurp`) option.\r\n\r\nIt&#39;s also imperative, that you quote all your shell variables when expanding!\r\n\r\n*****\r\n\r\nBut you don&#39;t need to read the file with the shell at all, jq can already read text files just fine:\r\n\r\n```\r\njq -R &#39;{name: ., newValue: &quot;****&quot;}&#39; &quot;$input&quot; | jq -s &quot;{secrets:.}&quot;\r\n```\r\n\r\nAlternatively, with a single jq process:\r\n\r\n```\r\njq -Rn &#39;[{name: inputs, newValue: &quot;****&quot;}]|{secrets:.}&#39; &quot;$input&quot;\r\n```",
                "title": "Not all JSON array elements are created using jq command in Bash"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707202745,
        "creation_date": 1706775744,
        "last_edit_date": 1706790718,
        "question_id": 77918614,
        "body_markdown": "Inside of a while loop I&#39;m trying to build json objects and add them to an array then write this array to a json file using jq commands. Each json object in the array gets one of its  properties from a file as shown below:\r\n```\r\ninput=&quot;names.csv&quot; \r\nwhile IFS= read -r secretName || [ -n &quot;$secretName&quot; ]; \r\ndo      \r\n    value=&quot;&quot;\r\n    value=$(echo &quot;$secretValue&quot; | tr -d &#39;\\n&#39; | tr -d &#39;\\r&#39; )\r\n    value=&quot;{\\&quot;name\\&quot;:\\&quot;$secretName\\&quot;,\\&quot;newValue\\&quot;:\\&quot;****\\&quot;}&quot;  #get $secretname from names.txt \r\n    \r\n    echo &#39;[]&#39; | jq &quot;. += [$value]&quot; &gt; jsonOutput.json\r\n    \r\ndone &lt; $input  \r\n```\r\nThe expected output should be a JSON array of objects with multiple objects in it but I&#39;m only seeing the last object. Since the input file has three names in it, the output should also have three objects in the array. I would also like to give the array a key and the output should look something like the following:\r\n```\r\n{&quot;secrets&quot;:[\r\n  {\r\n    &quot;name&quot;: &quot;name1&quot;,\r\n    &quot;newValue&quot;: &quot;****&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name2&quot;,\r\n    &quot;newValue&quot;: &quot;****&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name3&quot;,\r\n    &quot;newValue&quot;: &quot;****&quot;\r\n  }\r\n]\r\n}\r\n```\r\nI am very new to jq and the examples in various posts that I have seen left more questions than they answer. Please let me know why the first two objects are missing in the array and how I can assign a key to the array object.  ",
        "link": "https://stackoverflow.com/questions/77918614/not-all-json-array-elements-are-created-using-jq-command-in-bash",
        "title": "Not all JSON array elements are created using jq command in Bash"
    },
    {
        "tags": [
            "python",
            "bash",
            "csv",
            "awk",
            "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": 1706817076,
                "post_id": 77922966,
                "comment_id": 137374539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706817876,
                "post_id": 77922966,
                "comment_id": 137374661,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706817978,
                "post_id": 77922966,
                "comment_id": 137374684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1706818047,
                "post_id": 77922966,
                "comment_id": 137374691,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706822025,
                "post_id": 77922966,
                "comment_id": 137375301,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 89455,
                    "reputation": 11388,
                    "user_id": 246801,
                    "user_type": "registered",
                    "accept_rate": 81,
                    "profile_image": "https://www.gravatar.com/avatar/54ac1ed63d1eb6bfc3eb0d89a8c2e135?s=256&d=identicon&r=PG",
                    "display_name": "Zach Young",
                    "link": "https://stackoverflow.com/users/246801/zach-young"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1706850533,
                "post_id": 77922966,
                "comment_id": 137377782,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707069828,
                "creation_date": 1707069828,
                "answer_id": 77936995,
                "question_id": 77922966,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nsubprocess.run([&quot;jq -r &#39;.accountdata[] | [id, name, number, date] | @csv&#39;&quot;])\r\n```\r\n\r\nRuns a single binary with the name `jq -r &#39;.accountdata[] | [id, name, number, date] | @csv&#39;` without any parameters – but the name of your binary is `jq` and you want to run it with 2 parameters!\r\n\r\n```\r\nsubprocess.run([&quot;jq&quot;, &quot;-r&quot;, &quot;&#39;.accountdata[] | [id, name, number, date] | @csv&#39;&quot;])\r\n```\r\n\r\nWill run the binary with 2 parameters. Alternatively, pass a single string instead of the array and specify `shell=True`:\r\n\r\n```\r\nsubprocess.run(&quot;jq -r &#39;.accountdata[] | [id, name, number, date] | @csv&#39;&quot;, shell=True)\r\n```\r\n\r\nSame goes for your `awk` call. But even better: use python directly, it can already manipulate JSON and line-based data just fine.",
                "title": "Keep getting type error in awk command in Python"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707069828,
        "creation_date": 1706816911,
        "last_edit_date": 1706821167,
        "question_id": 77922966,
        "body_markdown": "Trying to turn a bash script into python using a subprocess but its not working. keep getting type errors on the jq command\r\n\r\n```\r\nfilename = temp.csv\r\nwith open (filename, &#39;a&#39;) as file_name: \r\n  ndfile=&quot;account.csv&quot; \r\n  with open(ndfile, &#39;a&#39;)\r\n    for line in ndfile: \r\n      line = line.strip()\r\n      result = subprocess.run([&quot;jq -r &#39;.accountdata[] | [id, name, number, date] | @csv&#39;&quot;], stdout=open(file_name, &#39;a&#39;))\r\n      result.write(line)\r\n   subprocess.run([&#39;awk&#39;, &#39;-F&#39;, &#39;,&#39;, &#39;!seen[$1]++&#39;, file_name], stdout=open(ndfile, &#39;w&#39;))\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77922966/keep-getting-type-error-in-awk-command-in-python",
        "title": "Keep getting type error in awk command in Python"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1706849711,
                "creation_date": 1706849711,
                "answer_id": 77924759,
                "question_id": 77924502,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your `filter.jq` contains DOS line endings. Strip them using the `dos2unix` utility or run your script using the Windows build; `jq-win64.exe` from the [releases page](https://github.com/jqlang/jq/releases) works fine on both Cygwin and WSL2.",
                "title": "How do I use use multiple lines in a jq filter file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1706849711,
        "creation_date": 1706843938,
        "last_edit_date": 1706844674,
        "question_id": 77924502,
        "body_markdown": "I&#39;m reading [the jq manual][1] and it says: \r\n\r\n\r\n&gt;     -f filename / --from-file filename:\r\n&gt; \r\n&gt; Read filter from the file rather than from a command line, like awk&#39;s\r\n&gt; -f option. You can also use &#39;#&#39; to make comments.\r\n\r\nI typed this into my command line:\r\n\r\n    $ cat input.json | jq -rf filter.jq\r\n\r\nand my `filter.jq` file is:\r\n\r\n```\r\n.signal[] | .name\r\n# .signal[] | select(.name | contains(&quot;signal&quot;)) as $matches\r\n```\r\n\r\nThis gives me an error:\r\n\r\n```\r\n$ cat input.json | jq -rf filter.jq \r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\njq: 1 compile error\r\n```\r\n\r\nIf I append `\\` to the end of the first line, I get a different error:\r\n\r\n```\r\n$ cat input.json | jq -rf filter.jq \r\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n                  \\\r\njq: 1 compile error\r\n```\r\n\r\nI also tried `\\\\`, with similar results. \r\n\r\nThe only fix I found is to merge the two lines into one. But this limits my ability to document my filter and use the file as a playground for experimentation. How do I use use multiple lines in a jq filter file?\r\n\r\n---\r\n\r\nNote: I have tried this on both cygwin and WSL and get the same result.\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.6/",
        "link": "https://stackoverflow.com/questions/77924502/how-do-i-use-use-multiple-lines-in-a-jq-filter-file",
        "title": "How do I use use multiple lines in a jq filter file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line-interface",
            "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": 1706849849,
                "post_id": 77924756,
                "comment_id": 137377741,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1706850144,
                "post_id": 77924756,
                "comment_id": 137377755,
                "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": 1706850464,
                "post_id": 77924756,
                "comment_id": 137377776,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1706850808,
                "post_id": 77924756,
                "comment_id": 137377805,
                "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": 1706851183,
                "post_id": 77924756,
                "comment_id": 137377832,
                "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": 1706852219,
                "post_id": 77924756,
                "comment_id": 137377901,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707227120,
                "post_id": 77924756,
                "comment_id": 137418424,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1707260315,
                "last_edit_date": 1707260315,
                "creation_date": 1707234674,
                "answer_id": 77949066,
                "question_id": 77924756,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Simpler example:\r\n\r\n```sh\r\nprintf &#39;%s\\n&#39; &#39;[ &quot;abc&quot;, &quot;def&quot; ]&#39; | jq -c &#39;.[] as $x | .&#39;\r\n```\r\n\r\n```json\r\n[&quot;abc&quot;,&quot;def&quot;]\r\n[&quot;abc&quot;,&quot;def&quot;]\r\n```\r\n\r\nWe could also write this as follows:\r\n\r\n```sh\r\nprintf &#39;%s\\n&#39; &#39;[ &quot;abc&quot;, &quot;def&quot; ]&#39; | jq -rc &#39;.[] as $x | &quot;. is &quot; + tojson&#39;\r\n```\r\n\r\n```json\r\n. is [&quot;abc&quot;,&quot;def&quot;]\r\n. is [&quot;abc&quot;,&quot;def&quot;]\r\n```\r\n\r\nYou say `.` isn&#39;t producing the original input, but we clearly see it is in this latest snippet.\r\n\r\nWhat you&#39;re really actually asking about is why the expression that follows the `|` is evaluated multiple times. This results from the use of `.[]`.\r\n\r\n&gt; If you use the `.[index]` syntax, but omit the index entirely, it will return *all* of the elements of an array. Running `.[]` with the input `[1,2,3]` will produce the numbers as three separate results, rather than as a single array. A filter of the form `.foo[]` is equivalent to `.foo | .[]`.\r\n\r\nWhen something produces multiple values, the rest of the pipeline is evaluated for each of those values.&lt;sup&gt;[1]&lt;/sup&gt;\r\n\r\n&gt; Some filters produce multiple results, for instance there&#39;s one that produces all the elements of its input array. Piping that filter into a second runs the second filter for each element of the array. Generally, things that would be done with loops and iteration in other languages are just done by gluing filters together in jq.\r\n\r\nThis is repeated in `as`&#39;s documentation.\r\n\r\n&gt; The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus `as` functions as something of a foreach loop.\r\n\r\nLet&#39;s look at a slightly more elaborate version of my original version:\r\n\r\n```sh\r\nprintf &#39;%s\\n&#39; &#39;[ &quot;abc&quot;, &quot;def&quot; ]&#39; | jq -c &#39;.[] as $x | [ ., $x ]&#39;\r\n```\r\n\r\n```json\r\n[[&quot;abc&quot;,&quot;def&quot;],&quot;abc&quot;]\r\n[[&quot;abc&quot;,&quot;def&quot;],&quot;def&quot;]\r\n```\r\n\r\nThe documentation I&#39;ve quoted says this should be equivalent to the following:\r\n\r\n```sh\r\nprintf &#39;%s\\n&#39; &#39;[ &quot;abc&quot;, &quot;def&quot; ]&#39; | jq -c &#39;\r\n   . as $orig |  # Save original input.\r\n   .[] |         # Produces multiple values.\r\n   .  as $x |    # This is evaluated for each of those values.\r\n   $orig |       # Set `.` to the original input.\r\n   [ ., $x ]\r\n&#39;\r\n```\r\n\r\n```json\r\n[[&quot;abc&quot;,&quot;def&quot;],&quot;abc&quot;]\r\n[[&quot;abc&quot;,&quot;def&quot;],&quot;def&quot;]\r\n```\r\n\r\n---\r\n\r\n1. And when something produces no values, the rest of the pipeline isn&#39;t evaluated.\r\n\r\n",
                "title": "Why doesn&#39;t the jq filter &#39;exp as $var | .&#39; print the original input as documented?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1707260315,
        "creation_date": 1706849670,
        "question_id": 77924756,
        "body_markdown": "[jq&#39;s documentation][1] says (emphasis mine):\r\n\r\n&gt; The expression `exp as $x | ...` means: for each value of expression `exp`, **run the rest of the pipeline with the entire original input**, and with `$x` set to that value. \r\n\r\nHere&#39;s my own interpretation: in `exp as $x | ...`, the `...`&#39;s context starts at the original input to the `jq` command. If that&#39;s the case, why doesn&#39;t `exp as $x | .` print the original input? Here&#39;s my example ([playground link][2]):\r\n\r\nFilter: `(.signal[] | select(.name | contains(&quot;signal&quot;))) as $matches | .`\r\n\r\nInput: \r\n```lang-json\r\n{\r\n  &quot;noise1&quot;: 5,\r\n  &quot;signal&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;noise2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOutput:\r\n\r\n```lang-json\r\n{\r\n  &quot;noise1&quot;: 5,\r\n  &quot;signal&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;noise2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;noise1&quot;: 5,\r\n  &quot;signal&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;noise2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;d also like to understand why my output prints the input twice, thereby making it invalid json. I think that relates to `(.signal[] | select(.name | contains(&quot;signal&quot;)))` returning 2 results, but I don&#39;t understand how that&#39;s relevant if I&#39;m not referencing the variable on the RHS. \r\n\r\n  [1]: https://jqlang.github.io/jq/manual/v1.6/#variable-symbolic-binding-operator\r\n  [2]: https://jqplay.org/s/X8sJ_U9KGmU",
        "link": "https://stackoverflow.com/questions/77924756/why-doesnt-the-jq-filter-exp-as-var-print-the-original-input-as-document",
        "title": "Why doesn&#39;t the jq filter &#39;exp as $var | .&#39; print the original input as documented?"
    },
    {
        "tags": [
            "json",
            "bash",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1706857737,
                "post_id": 77925097,
                "comment_id": 137378408,
                "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": 1706857844,
                "post_id": 77925097,
                "comment_id": 137378421,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1706863217,
                "post_id": 77925097,
                "comment_id": 137379234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1706863286,
                "post_id": 77925097,
                "comment_id": 137379245,
                "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": 1706864836,
                "post_id": 77925097,
                "comment_id": 137379490,
                "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": 1706868143,
                "post_id": 77925097,
                "comment_id": 137380044,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1706883973,
                "post_id": 77925097,
                "comment_id": 137382657,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24269,
                    "reputation": 68079,
                    "user_id": 61624,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://www.gravatar.com/avatar/1e011d13433f12be7dc754180cb38ca8?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Kaplan",
                    "link": "https://stackoverflow.com/users/61624/daniel-kaplan"
                },
                "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": 1707010710,
                "post_id": 77925097,
                "comment_id": 137394393,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1706874656,
                "last_edit_date": 1706874656,
                "creation_date": 1706869467,
                "answer_id": 77926257,
                "question_id": 77925097,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; 1. Is there a simpler way to write the above?\r\n\r\nHere&#39;s my alternative approach. It updates every item in the `.signal` array by providing a new value to `.nested.prop` under the condition that the value of `.name` contains a given substring. The new value itself is a concatenation of a literal part and the final digit from that `.name` value. If the condition is not met, the original value is kept implicitly. (Versions of jq prior to 1.7 needed to spell out `else .` explicitly.)\r\n```sh\r\n.signal[] |= if .name | contains(&quot;signal&quot;) then\r\n  .nested.prop = &quot;CHANGED-\\(.name | scan(&quot;\\\\d$&quot;))&quot;\r\nend\r\n```\r\n[Demo](https://jqplay.org/s/12Ln25Z5by4)\r\n\r\n---\r\n&gt; 2. Why did all my other attempts print multiple json objects:\r\n&gt; ```\r\n&gt; .signal[]\r\n&gt; | select(.name | contains(&quot;signal&quot;)) as $matches\r\n&gt; | .\r\n&gt; ```\r\n\r\n`.signal[]` has three outputs (each being an object of the form `{&quot;name&quot;:…, &quot;nested&quot;:…}`). `select` then filters out one of them (as it doesn&#39;t match the provided condition), and `as` binds the remaining two to a variable. Finally, `.` unconditionally produces both. Note that no traversal was performed with the binding, so the context produced by `.` is identical to the value bound to the variable (in both cases).\r\n\r\n\r\n&gt; ```\r\n&gt; (.signal[] | select(.name | contains(&quot;signal&quot;))) as $matches\r\n&gt; | .\r\n&gt; ```\r\n\r\nHere, the whole parenthesis became the expression for the binding, which, as shown in the previous snippet, evaluates to two objects of the form `{&quot;name&quot;:…, &quot;nested&quot;:…}`. These are still the values bound to the variable, but as the traversal (`.signal[]`) now occurs inside the binding expression, the &quot;original&quot; context, i.e. [the one from before the binding expression](https://stackoverflow.com/questions/77924756/why-doesnt-the-jq-filter-exp-as-var-print-the-original-input-as-document#comment137377901_77924756), here being the overall input provided to jq (`{&quot;noise1&quot;: 5, &quot;signal&quot;: […]}`), is the one produced (twice) by the final `.`, each with one of the bindings accessible in the variable.\r\n\r\n&gt; ```\r\n&gt; .signal[]\r\n&gt; | select(.name | contains(&quot;signal&quot;))\r\n&gt; | .nested.prop = (\r\n&gt;     .name\r\n&gt;     | gsub(&quot;.*-(?&lt;namedigit&gt;[0-9])&quot;; &quot;CHANGED-\\(.namedigit)&quot;)\r\n&gt;   )\r\n&gt; ```\r\n\r\nThis attempt suffers from the impossibility to backtrack from a traversal while being inside the traversing context. Compare how in the previous snippet the traversal only affected the context for the filters inside the parentheses, while the &quot;original&quot; context was &quot;saved&quot; for the filter following it. Likewise in this snippet, `.nested.prop = (…)` sets a value which is evaluated by traversing into `.name`, which becomes the context for `gsub`, but the context after the assignment (which also happens to be the final context) is still the one `.nested.prop` was valid in. But as you start out with `.signal[] | …` you leave the top-level context without being able to return.\r\n\r\nThere are generally two ways to make returning possible. One is to use variables to store a context that would otherwise be unreachably left behind. For example, if you continued your first snippet by further traversing down, you&#39;d see how you can still access the saved context (which wasn&#39;t the top level context, though) by reading the variable. You could even make it a new context by having `$matches` as a filter by itself. But variables are immutable (as in most FP paradigms), so you can only read from them, and restoring a context this way would simply just expunge any previous context that you may have carefully transformed on your way there.\r\n\r\nThe other way would be to only traverse within parentheses, which is what the solution you &quot;stumbled upon&quot; is doing: `.signal[] |= (…)`. The (update-)assignment is performed on top level, while all traversal happens inside parentheses (which by themselves may again contain other assignments and traversals). Note that the LHS traversals in `.signal[]` and `.nested.prop` are just shorthands for `(.signal | .[])` and `(.nested | .prop)`, respectively. This is generally the way how to produce a higher level context with modifications on a deeper level.",
                "title": "Using jq, how do I conditionally modify a portion of its input and output the original structure with those changes?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707010673,
        "creation_date": 1706856028,
        "last_edit_date": 1707010673,
        "question_id": 77925097,
        "body_markdown": "I have an `input.json` file with this content:\r\n\r\n```lang-json\r\n{\r\n  &quot;noise1&quot;: 5,\r\n  &quot;signal&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;noise2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing `jq`, I want to read in that file and output this:\r\n\r\n```lang-json\r\n{\r\n  &quot;noise1&quot;: 5,\r\n  &quot;signal&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;CHANGED-1&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;CHANGED-3&quot;\r\n      }\r\n    }\r\n  ],\r\n  &quot;noise2&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-1&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-noise-2&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;child-signal-3&quot;,\r\n      &quot;nested&quot;: {\r\n        &quot;prop&quot;: &quot;child-prop-3&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHere&#39;s the change in words: `.signal[]` objects with a `.name` that contains &quot;signal&quot; should set their `.nested.prop` value to `&quot;CHANGED-&quot;` plus the aforementioned `.name`&#39;s last digit. The result should be the original json with this modification.\r\n\r\n---\r\n\r\nI&#39;ve somehow stumbled upon [the answer][1], but I don&#39;t fully understand why it works, especially when compared to everything I tried previously (see #2 below):\r\n\r\n    .signal[] |= (select(.name | contains(&quot;signal&quot;)) .nested.prop = (.name | gsub(&quot;.*-(?&lt;namedigit&gt;[0-9])&quot;; &quot;CHANGED-\\(.namedigit)&quot;)))\r\n\r\n1. Is there a simpler way to write the above?\r\n1. Why did all my other attempts print multiple json objects:\r\n\r\n    ```\r\n    .signal[] | select(.name | contains(&quot;signal&quot;)) as $matches | .\r\n    (.signal[] | select(.name | contains(&quot;signal&quot;))) as $matches | .\r\n    .signal[] | select(.name | contains(&quot;signal&quot;)) | .nested.prop = (.name | gsub(&quot;.*-(?&lt;namedigit&gt;[0-9])&quot;; &quot;CHANGED-\\(.namedigit)&quot;))\r\n    ```\r\n\r\n    To be clear: I&#39;m not asking for a detailed explanation of each, I just assume they share a common theme that causes multiple json outputs, and I&#39;d like to understand what that is.\r\n\r\n  [1]: https://jqplay.org/s/TilSRhvCWW6",
        "link": "https://stackoverflow.com/questions/77925097/using-jq-how-do-i-conditionally-modify-a-portion-of-its-input-and-output-the-or",
        "title": "Using jq, how do I conditionally modify a portion of its input and output the original structure with those changes?"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq",
            "i3"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707030406,
                "post_id": 77934601,
                "comment_id": 137395226,
                "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": 1707032036,
                "post_id": 77934601,
                "comment_id": 137395295,
                "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": 1707032243,
                "post_id": 77934601,
                "comment_id": 137395308,
                "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": 1707034589,
                "post_id": 77934601,
                "comment_id": 137395443,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28830809,
                    "reputation": 3,
                    "user_id": 23343425,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/3399363053653174/picture?type=large",
                    "display_name": "Jameson Bradfield",
                    "link": "https://stackoverflow.com/users/23343425/jameson-bradfield"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707038450,
                "post_id": 77934601,
                "comment_id": 137395769,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28830809,
                    "reputation": 3,
                    "user_id": 23343425,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/3399363053653174/picture?type=large",
                    "display_name": "Jameson Bradfield",
                    "link": "https://stackoverflow.com/users/23343425/jameson-bradfield"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707070354,
                "post_id": 77934601,
                "comment_id": 137398944,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707205534,
                "last_edit_date": 1707205534,
                "creation_date": 1707040012,
                "answer_id": 77935270,
                "question_id": 77934601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the values in .name have no spaces or certain other characters,\r\nyou would be able to get away with something along the lines of the following:\r\n\r\n```\r\nX=($(i3-msg -t get_workspaces | jq -r &#39;.[] | select(.visible == true).name&#39; ))\r\n\r\nfor var in &quot;${X[@]}&quot;\r\ndo\r\n  echo &quot;$var&quot;\r\ndone \r\n```\r\nOutput:\r\n```\r\n9\r\n1:Browsing\r\n```\r\n\r\nMore robustly, if your shell has `readarray`:\r\n```\r\nreadarray -t X &lt; &lt;(... | jq -r &#39;.[] | select(.visible == true).name &#39;)\r\n```\r\n\r\nOtherwise, you could use the idiom:\r\n```\r\nvars=(); while IFS= read -r line; do vars+=(&quot;$line&quot;); done &lt; .....\r\n```",
                "title": "save json jq output as seperate variables or as an array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707053684,
                "creation_date": 1707053684,
                "answer_id": 77935979,
                "question_id": 77934601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; the ideal solution would be to have it stored in a array\r\n\r\nAssuming you mean a bash array, you can use `declare` to declare it, and use jq&#39;s `@sh` to properly escape the contents.\r\n\r\nFor an indexed array, use `declare -a`:\r\n```sh\r\n$ declare -a cw=&quot;($(i3-msg … | jq -r &#39;.[]  | select(.visible).name | @sh&#39;))&quot;\r\n\r\n$ declare -p cw  # print for testing\r\ndeclare -a cw=([0]=&quot;9&quot; [1]=&quot;1:Browsing&quot;)\r\n```\r\n\r\nFor an associative array, use `declare -A`, and output each keys before its value:\r\n```sh\r\n$ declare -A cw=&quot;($(i3-msg … | jq -r &#39;.[]  | select(.visible) | .output, .name | @sh&#39;))&quot;\r\n\r\n$ declare -p cw  # print for testing\r\ndeclare -A cw=([DisplayPort-2]=&quot;9&quot; [DisplayPort-1]=&quot;1:Browsing&quot; )\r\n```",
                "title": "save json jq output as seperate variables or as an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1707205534,
        "creation_date": 1707021041,
        "last_edit_date": 1707021122,
        "question_id": 77934601,
        "body_markdown": "I am currently working with i3 and would like to parse the visible workspaces with `i3-msg -t get_workspaces`, to &quot;save the workspace&quot; and return to them when my pomodoro break is over, problem is I&#39;ve never worked with json in bash before (aside from a couple quick examples maybe an hour ago).\r\nbasically I am trying to return the name value of the visible workspaces.\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 94475011596992,\r\n    &quot;num&quot;: 6,\r\n    &quot;name&quot;: &quot;6:NoteTaking&quot;,\r\n    &quot;visible&quot;: false,\r\n    &quot;focused&quot;: false,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 65,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-2&quot;,\r\n    &quot;urgent&quot;: false\r\n  },\r\n  {\r\n    &quot;id&quot;: 94475011603104,\r\n    &quot;num&quot;: 7,\r\n    &quot;name&quot;: &quot;7:Entertainment&quot;,\r\n    &quot;visible&quot;: false,\r\n    &quot;focused&quot;: false,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 65,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-2&quot;,\r\n    &quot;urgent&quot;: false\r\n  },\r\n  {\r\n    &quot;id&quot;: 94475011612464,\r\n    &quot;num&quot;: 9,\r\n    &quot;name&quot;: &quot;9&quot;,\r\n    &quot;visible&quot;: true,\r\n    &quot;focused&quot;: true,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 65,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-2&quot;,\r\n    &quot;urgent&quot;: false\r\n  },\r\n  {\r\n    &quot;id&quot;: 94475011631328,\r\n    &quot;num&quot;: 1,\r\n    &quot;name&quot;: &quot;1:Browsing&quot;,\r\n    &quot;visible&quot;: true,\r\n    &quot;focused&quot;: false,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 1145,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-1&quot;,\r\n    &quot;urgent&quot;: false\r\n  },\r\n  {\r\n    &quot;id&quot;: 94475011637712,\r\n    &quot;num&quot;: 2,\r\n    &quot;name&quot;: &quot;2:Messaging&quot;,\r\n    &quot;visible&quot;: false,\r\n    &quot;focused&quot;: false,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 1145,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-1&quot;,\r\n    &quot;urgent&quot;: false\r\n  },\r\n  {\r\n    &quot;id&quot;: 94475011644096,\r\n    &quot;num&quot;: 3,\r\n    &quot;name&quot;: &quot;3&quot;,\r\n    &quot;visible&quot;: false,\r\n    &quot;focused&quot;: false,\r\n    &quot;rect&quot;: {\r\n      &quot;x&quot;: 40,\r\n      &quot;y&quot;: 1145,\r\n      &quot;width&quot;: 1840,\r\n      &quot;height&quot;: 975\r\n    },\r\n    &quot;output&quot;: &quot;DisplayPort-1&quot;,\r\n    &quot;urgent&quot;: false\r\n  }\r\n]\r\n```\r\n\r\n\r\n\r\n\r\nCurrently I have this line doing most of the heavy lifting,\r\n```bash\r\n  local currentWorkspaces=$(i3-msg -t get_workspaces | jq -r &#39;map(select(.visible == true)).name&#39;)\r\n```\r\nit&#39;s returning the right values (granted they are in quotes.)\r\n```json\r\n[\r\n  &quot;9&quot;,\r\n  &quot;1:Browsing&quot;\r\n]\r\n```\r\n\r\nI&#39;ve been trying to call them with a simple array (never worked with arrays either so might be messing stuff up)\r\n`i3-msg workspace &quot;$currentWorkspaces[@]&quot;`\r\n\r\ncurrently I have no idea how to move forward, and any help would be appreciated (-r the option I thought would return the values without quotes isn&#39;t doing so)",
        "link": "https://stackoverflow.com/questions/77934601/save-json-jq-output-as-seperate-variables-or-as-an-array",
        "title": "save json jq output as seperate variables or as an array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1707255732,
                "post_id": 77950999,
                "comment_id": 137423522,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707256077,
                "post_id": 77950999,
                "comment_id": 137423551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707256467,
                "post_id": 77950999,
                "comment_id": 137423599,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707256795,
                "creation_date": 1707256795,
                "answer_id": 77951084,
                "question_id": 77950999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In order to result in the JSON that I was expecting, I used the following jq statement.\r\n\r\n`jq &#39;. |= sort_by(.submitted_at) | reverse | unique_by(.user.login)&#39; &quot;$tmp_response_file_pr_reviews_request&quot;`\r\n\r\nThis sorted the resulting array by it&#39;s `submitted_at` revered so that the highest date is at the top, and then using `unique_by` to filter down to only the first instance of each `user.login Key-Value pair in the array, resulting in what I needed.\r\n",
                "title": "How do I extract only the first time a key/value pair exists in a json object in bash with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707257423,
                "creation_date": 1707257423,
                "answer_id": 77951116,
                "question_id": 77950999,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; only the first occurrence of the `user.login` for each item, with the highest `submitted_at` key\r\n\r\nWith `group_by(.user.login)` you can group together into subarrays all objects with the same `.user.login` value. Then, from each subarray, pick the one item with the highest `.submitted_at` value using `max_by(.submitted_at)`. The final array can be created either using an array constructor `[…]` and iterating over the groups using `.[]`, or by re-using the grouping array and accessing the groups using a `map`.\r\n\r\n```sh\r\n# Using an array constructor\r\n[group_by(.user.login)[] | max_by(.submitted_at)]\r\n\r\n# Using map\r\ngroup_by(.user.login) | map(max_by(.submitted_at))\r\n```\r\n[Demo](https://jqplay.org/s/3UVgIOb7LyP)\r\n",
                "title": "How do I extract only the first time a key/value pair exists in a json object in bash with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1707257423,
        "creation_date": 1707255552,
        "question_id": 77950999,
        "body_markdown": "Can anyone help me using `bash` and `jq` to be able to filter this JSON down to only the first occurrence of the `user.login` for each item, with the highest `submitted_at` key. An endpoint is giving me back historical information and I only want the most up to date details for the response. Take for example this JSON\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user1&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;CHANGE_REQUESTED&quot;,\r\n    &quot;submitted_at&quot;: &quot;2024-01-23T19:18:31Z&quot;,\r\n  },\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user1&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;DISMISSED&quot;,\r\n    &quot;submitted_at&quot;: &quot;2024-02-05T16:49:58Z&quot;,\r\n  },\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user1&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;APPROVED&quot;\r\n    &quot;submitted_at&quot;: &quot;2024-02-06T19:18:31Z&quot;,\r\n  },\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user2&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;APPROVED&quot;\r\n    &quot;submitted_at&quot;: &quot;2024-01-23T19:18:31Z&quot;,\r\n  },\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user2&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;DISMISSED&quot;\r\n    &quot;submitted_at&quot;: &quot;2024-01-21T19:18:31Z&quot;,\r\n  }\r\n]\r\n```\r\n\r\nThe result should be the following JSON with only the most recent duplicate of `user.login` that I can then loop over\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user1&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;APPROVED&quot;\r\n    &quot;submitted_at&quot;: &quot;2024-02-06T19:18:31Z&quot;,\r\n  },\r\n  {\r\n    &quot;user&quot;: {\r\n      &quot;login&quot;: &quot;user2&quot;,\r\n    },\r\n    &quot;state&quot;: &quot;APPROVED&quot;\r\n    &quot;submitted_at&quot;: &quot;2024-01-23T19:18:31Z&quot;,\r\n  }\r\n]\r\n```\r\n\r\nAfter which I can loop through in bash to gather the information that I need from the object. \r\n\r\nThis may be answered already somewhere but I think I&#39;m struggling to word the ask in a search engine to be able to get the desired result.",
        "link": "https://stackoverflow.com/questions/77950999/how-do-i-extract-only-the-first-time-a-key-value-pair-exists-in-a-json-object-in",
        "title": "How do I extract only the first time a key/value pair exists in a json object in bash with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1707326344,
                "last_edit_date": 1707326344,
                "creation_date": 1707326034,
                "answer_id": 77956709,
                "question_id": 77956650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `split(&quot;/&quot;)` to convert `rootPath` to an array, then set the last index (`.[-1]`) to `new_name` and then `join(&quot;/&quot;)` them back together.\r\n\r\nWe use `|=` inside `map()` to just update those objects found by `select()` and then overwrite `.name` and `rootPath` as needed.\r\n\r\n```\r\nmap(select(.name == &quot;architecture-design-detailed&quot;) \r\n    |= ( \r\n        .name = &quot;new_name&quot;,\r\n        .rootPath = (.rootPath | split(&quot;/&quot;) | .[-1] = &quot;new_name&quot; | join(&quot;/&quot;))\r\n    ) \r\n)\r\n```\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;new_name&quot;,\r\n    &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name&quot;,\r\n    &quot;paths&quot;: [],\r\n    &quot;group&quot;: &quot;&quot;,\r\n    &quot;enabled&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;architecture-design-detailed-engineering&quot;,\r\n    &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering&quot;,\r\n    &quot;paths&quot;: [],\r\n    &quot;group&quot;: &quot;&quot;,\r\n    &quot;enabled&quot;: true\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/_RWJeCclv2X)",
                "title": "Replace part of the value of a json using regex and jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707335729,
                "creation_date": 1707335729,
                "answer_id": 77957571,
                "question_id": 77956650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another approach that updates at once the two fields `.name, .rootPath` for selected items matching `.name == $from` by right-trimming by the old name using `rtrimstr($from)`, and then adding the new one with `+ $to`:\r\n```sh\r\njq --arg from &#39;architecture-design-detailed&#39; --arg to &#39;new_name_here&#39; &#39;\r\n  map((select(.name == $from) | .name, .rootPath) |= rtrimstr($from) + $to)\r\n&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;new_name_here&quot;,\r\n    &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here&quot;,\r\n    &quot;paths&quot;: [],\r\n    &quot;group&quot;: &quot;&quot;,\r\n    &quot;enabled&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;architecture-design-detailed-engineering&quot;,\r\n    &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering&quot;,\r\n    &quot;paths&quot;: [],\r\n    &quot;group&quot;: &quot;&quot;,\r\n    &quot;enabled&quot;: true\r\n  }\r\n]\r\n```",
                "title": "Replace part of the value of a json using regex and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1707591825,
        "creation_date": 1707325509,
        "last_edit_date": 1707591825,
        "question_id": 77956650,
        "body_markdown": "I have a json like bellow:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;architecture-design-detailed&quot;,\r\n        &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed&quot;,\r\n        &quot;paths&quot;: [],\r\n        &quot;group&quot;: &quot;&quot;,\r\n        &quot;enabled&quot;: true\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;architecture-design-detailed-engineering&quot;,\r\n        &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering&quot;,\r\n        &quot;paths&quot;: [],\r\n        &quot;group&quot;: &quot;&quot;,\r\n        &quot;enabled&quot;: true\r\n      }\r\n    ]\r\n\r\nIf name is `architecture-design-detailed`, \r\n\r\n* change name to `new_name_here`\r\n\r\n* replace last part of rootPath (which is architecture-design-detailed, after the last /) with new_name_here.\r\n\r\nSo the expected output is:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;new_name_here&quot;,\r\n        &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here&quot;,\r\n        &quot;paths&quot;: [],\r\n        &quot;group&quot;: &quot;&quot;,\r\n        &quot;enabled&quot;: true\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;architecture-design-detailed-engineering&quot;,\r\n        &quot;rootPath&quot;: &quot;/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering&quot;,\r\n        &quot;paths&quot;: [],\r\n        &quot;group&quot;: &quot;&quot;,\r\n        &quot;enabled&quot;: true\r\n      }\r\n    ]\r\n\r\nWhat I came up with so far is:\r\n\r\n    jq &#39;map(if .name == &quot;architecture-design-detailed&quot; then .name = &quot;new_name_here&quot; else . end)&#39;\r\n\r\nBut not understanding how to replace last part of rootPath. I think we have to use `sub` or `gsub`. But not understanding how. ",
        "link": "https://stackoverflow.com/questions/77956650/replace-part-of-the-value-of-a-json-using-regex-and-jq",
        "title": "Replace part of the value of a json using regex and jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707344722,
                "post_id": 77958241,
                "comment_id": 137436085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707344858,
                "post_id": 77958241,
                "comment_id": 137436109,
                "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": 1707344914,
                "post_id": 77958241,
                "comment_id": 137436113,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26572863,
                    "reputation": 43,
                    "user_id": 22867523,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0uOe0LnRq0f0LFDhaYP25xhOHKwmEP5wUxrQHu=k-s256",
                    "display_name": "Miguel7799",
                    "link": "https://stackoverflow.com/users/22867523/miguel7799"
                },
                "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": 1707345044,
                "post_id": 77958241,
                "comment_id": 137436135,
                "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": 1707345091,
                "post_id": 77958241,
                "comment_id": 137436142,
                "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": 1707345141,
                "post_id": 77958241,
                "comment_id": 137436147,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26572863,
                    "reputation": 43,
                    "user_id": 22867523,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0uOe0LnRq0f0LFDhaYP25xhOHKwmEP5wUxrQHu=k-s256",
                    "display_name": "Miguel7799",
                    "link": "https://stackoverflow.com/users/22867523/miguel7799"
                },
                "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": 1707345246,
                "post_id": 77958241,
                "comment_id": 137436159,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707345280,
                "post_id": 77958241,
                "comment_id": 137436165,
                "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": 1707345352,
                "post_id": 77958241,
                "comment_id": 137436176,
                "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": 1707345462,
                "post_id": 77958241,
                "comment_id": 137436188,
                "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": 1707345498,
                "post_id": 77958241,
                "comment_id": 137436198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26572863,
                    "reputation": 43,
                    "user_id": 22867523,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0uOe0LnRq0f0LFDhaYP25xhOHKwmEP5wUxrQHu=k-s256",
                    "display_name": "Miguel7799",
                    "link": "https://stackoverflow.com/users/22867523/miguel7799"
                },
                "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": 1707345655,
                "post_id": 77958241,
                "comment_id": 137436221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707345746,
                "post_id": 77958241,
                "comment_id": 137436227,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1707345797,
                "post_id": 77958241,
                "comment_id": 137436232,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26572863,
                    "reputation": 43,
                    "user_id": 22867523,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ALm5wu0uOe0LnRq0f0LFDhaYP25xhOHKwmEP5wUxrQHu=k-s256",
                    "display_name": "Miguel7799",
                    "link": "https://stackoverflow.com/users/22867523/miguel7799"
                },
                "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": 1707345824,
                "post_id": 77958241,
                "comment_id": 137436236,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707346084,
                "post_id": 77958241,
                "comment_id": 137436263,
                "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": 1707346159,
                "post_id": 77958241,
                "comment_id": 137436273,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707346174,
                "post_id": 77958241,
                "comment_id": 137436276,
                "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": 1707346365,
                "post_id": 77958241,
                "comment_id": 137436302,
                "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": 1707346475,
                "post_id": 77958241,
                "comment_id": 137436314,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707347012,
                "post_id": 77958241,
                "comment_id": 137436378,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707345983,
                "creation_date": 1707345983,
                "answer_id": 77958329,
                "question_id": 77958241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are extra moving parts that can be removed to simplify how this code is executed.\r\n\r\n```\r\nIFS=&#39;|&#39; read -r doc doc2 &lt; &lt;(callapi server:id | jq -r &#39;.[].Documentation&#39;)\r\n```\r\n\r\nNote:\r\n\r\n- Passing the `-r` argument to `jq` tells it not to escape content as JSON (preventing `&quot;`s at the beginning and end of the output, and possibly other escaping of characters within).\r\n- Passing the `-r` argument to `read` prevents it from consuming backslashes when they should instead be added to the results as data.\r\n- Setting `IFS=&#39;|&#39;` _on the same line_ as running `read`, such that we&#39;re changing the IFS value only for the `read` command and not for the larger shell.\r\n- Removing the `echo $(...)` avoids the set of bugs described in [Why is printf better than echo?](https://unix.stackexchange.com/questions/65803/why-is-printf-better-than-echo), and also those in https://stackoverflow.com/questions/29378566/i-just-assigned-a-variable-but-echo-variable-shows-something-else",
                "title": "split variable with a pipe separator and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707345983,
        "creation_date": 1707344499,
        "question_id": 77958241,
        "body_markdown": "I&#39;m trying to split a value in two values.\r\nThe value is:\r\n\r\n    HOUSE|CAR\r\n\r\nAnd I do:\r\n\r\n    IFS=&quot;|&quot;\r\n    read doc doc2 &lt; &lt;(echo $(callapi server:id| jq &#39;.[].Documentation&#39;))\r\n\r\nbut it gives me:\r\n\r\n    echo $doc\r\n    &quot;HOUSE|CAR&quot;\r\n    echo $doc2\r\n    &lt;empty&gt;\r\n\r\nHow could I get these:\r\n\r\n    echo $doc\r\n    HOUSE\r\n    eccho $doc2\r\n    CAR\r\n\r\nThanks\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77958241/split-variable-with-a-pipe-separator-and-jq",
        "title": "split variable with a pipe separator and jq"
    },
    {
        "tags": [
            "bigdata",
            "jq",
            "geojson"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1707400136,
                "post_id": 77962098,
                "comment_id": 137442871,
                "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"
                },
                "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": 1,
                "creation_date": 1707400434,
                "post_id": 77962098,
                "comment_id": 137442926,
                "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"
                },
                "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": 1707400451,
                "post_id": 77962098,
                "comment_id": 137442928,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22989199,
                    "reputation": 408,
                    "user_id": 17114959,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/k53S6.jpg?s=256",
                    "display_name": "defuneste",
                    "link": "https://stackoverflow.com/users/17114959/defuneste"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707400589,
                "post_id": 77962098,
                "comment_id": 137442950,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22989199,
                    "reputation": 408,
                    "user_id": 17114959,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/k53S6.jpg?s=256",
                    "display_name": "defuneste",
                    "link": "https://stackoverflow.com/users/17114959/defuneste"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1707400860,
                "post_id": 77962098,
                "comment_id": 137443009,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1707401460,
                "last_edit_date": 1707401460,
                "creation_date": 1707401143,
                "answer_id": 77962313,
                "question_id": 77962098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your original filter can be simplified as follows:\r\n- `.features` remains as-is\r\n- `map(.geometry.coordinates) | map(.[]) | map(first)` is actually just `map(.geometry.coordinates | .[] | first)`\r\n- `map(…) | .[]` can then be reduced to `.[] | …`\r\n- `{&quot;long&quot;: first, &quot;lat&quot;: last} | [.long, .lat]` builds an object, and immediately turns it into an array. This can be simplified to `[first,last]`, but as the array only had two items to begin with, this part actually just returns the input, and can be dropped entirely\r\n- `@csv` remains as-is\r\n\r\nIn summary, with further contractions like `.[] | first` to `.[][0]`, you can achieve the same using\r\n```sh\r\n.features[].geometry.coordinates[][0] | @csv\r\n```\r\n\r\nThis goes five levels deep, then picks the first item, and turns it into a CSV output. So, this can be translated to a `--stream` version as folloews:\r\n```sh\r\nfromstream(5|truncate_stream(inputs))[0] | @csv\r\n```\r\n```csv\r\n-114.127454,34.265674\r\n-114.127694,34.260939\r\n-114.127988,34.264977\r\n-114.129007,34.260229\r\n-114.129611,34.261105\r\n-114.130311,34.263922\r\n-114.131834,34.284069\r\n-114.132183,34.28509\r\n-114.132634,34.281492\r\n-114.133764,34.282816\r\n:\r\n```",
                "title": "Streaming a big geojson with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1707591667,
        "creation_date": 1707399187,
        "last_edit_date": 1707591667,
        "question_id": 77962098,
        "body_markdown": "I have some big geojson (see `California.geojson` has an example https://github.com/microsoft/USBuildingFootprints?tab=readme-ov-file#download-links). That I want to convert to a `.csv` (faster to import in Postgres with `\\copy`). I am passing it to STDIN. \r\n\r\nThey are  `&quot;type&quot;: &quot;Polygon&quot;` but for my needs this is mostly point data and I do not need the full geometry (and neither the attributes). `jq` is perfect for this task. \r\n\r\nSadly, some of the biggest file seems to be big to be stored in memory (the process generated a &quot;Killed&quot; message). I tried the `--stream` argument but I failed to understand it or the process seems to be very slow (more than 3 hours and still &quot;running&quot;). \r\n\r\n\r\n\r\nA sample can be produced thanks to (see at the bottom of this post to get a copy of it): \r\n\r\n```bash\r\njq &#39;.features = .features[:5]&#39; data/Alabama.geojson &gt; sample.geojson \r\n```\r\n\r\nThis is working great for &quot;smaller&quot; geojson (&lt; 1.4 GB):\r\n\r\n```bash\r\njq &#39;.features | map(.geometry.coordinates) | map(.[]) | map(first) | .[] | {&quot;long&quot;: first, &quot;lat&quot;: last} | [.long, .lat] | @csv&#39; small.geojson\r\n```\r\n\r\nBut I got a &quot;Killed&quot; message (I am assuming I am running out of memory)\r\n\r\nThen I tried the `--stream`, I am not sure that I understand it correctly (this [post](https://subtxt.in/library-data/2016/03/28/json_stream_jq) and this [issue](https://github.com/jqlang/jq/issues/1984) were a big help)  \r\n\r\nThis is my version with --stream (lot of &quot;hacking&quot;)\r\n\r\n```bash\r\ncat sample.geojson | jq --stream &quot;fromstream(1|truncate_stream(inputs))&quot; | jq &#39; map(.geometry.coordinates) | map(.[]) | map(first) | .[] | {&quot;long&quot;: first, &quot;lat&quot;: last} | [.long, .lat] | @csv&#39;\r\n```\r\n\r\nIt works against sample.geojson but failed on a big geojson (say &#39;Ohio.geojson&#39;). Any Ideas? \r\n\r\nI also tried to write in a file but without any more success. \r\n\r\n### geojson sample:\r\n\r\n```\r\n{\r\n  &quot;type&quot;: &quot;FeatureCollection&quot;,\r\n  &quot;features&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -84.959634,\r\n              32.421887\r\n            ],\r\n            [\r\n              -84.95982,\r\n              32.421889\r\n            ],\r\n            [\r\n              -84.959822,\r\n              32.421797\r\n            ],\r\n            [\r\n              -84.959767,\r\n              32.421796\r\n            ],\r\n            [\r\n              -84.959767,\r\n              32.421771\r\n            ],\r\n            [\r\n              -84.959636,\r\n              32.421769\r\n            ],\r\n            [\r\n              -84.959634,\r\n              32.421887\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;release&quot;: 2,\r\n        &quot;capture_dates_range&quot;: &quot;3/26/2020-7/22/2020&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -84.959636,\r\n              32.42095\r\n            ],\r\n            [\r\n              -84.959715,\r\n              32.42095\r\n            ],\r\n            [\r\n              -84.959714,\r\n              32.420984\r\n            ],\r\n            [\r\n              -84.959816,\r\n              32.420985\r\n            ],\r\n            [\r\n              -84.959818,\r\n              32.420849\r\n            ],\r\n            [\r\n              -84.959637,\r\n              32.420848\r\n            ],\r\n            [\r\n              -84.959636,\r\n              32.42095\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;release&quot;: 2,\r\n        &quot;capture_dates_range&quot;: &quot;3/26/2020-7/22/2020&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -84.959998,\r\n              32.235231\r\n            ],\r\n            [\r\n              -84.959877,\r\n              32.235231\r\n            ],\r\n            [\r\n              -84.959877,\r\n              32.235288\r\n            ],\r\n            [\r\n              -84.959998,\r\n              32.235288\r\n            ],\r\n            [\r\n              -84.959998,\r\n              32.235231\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;release&quot;: 1,\r\n        &quot;capture_dates_range&quot;: &quot;&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -84.960253,\r\n              32.422248\r\n            ],\r\n            [\r\n              -84.960069,\r\n              32.422245\r\n            ],\r\n            [\r\n              -84.960067,\r\n              32.422321\r\n            ],\r\n            [\r\n              -84.960165,\r\n              32.422323\r\n            ],\r\n            [\r\n              -84.960164,\r\n              32.422364\r\n            ],\r\n            [\r\n              -84.96025,\r\n              32.422365\r\n            ],\r\n            [\r\n              -84.960253,\r\n              32.422248\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;release&quot;: 2,\r\n        &quot;capture_dates_range&quot;: &quot;3/26/2020-7/22/2020&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;Feature&quot;,\r\n      &quot;geometry&quot;: {\r\n        &quot;type&quot;: &quot;Polygon&quot;,\r\n        &quot;coordinates&quot;: [\r\n          [\r\n            [\r\n              -84.961602,\r\n              32.419206\r\n            ],\r\n            [\r\n              -84.961599,\r\n              32.419354\r\n            ],\r\n            [\r\n              -84.961707,\r\n              32.419355\r\n            ],\r\n            [\r\n              -84.961708,\r\n              32.419291\r\n            ],\r\n            [\r\n              -84.961794,\r\n              32.419292\r\n            ],\r\n            [\r\n              -84.961796,\r\n              32.419208\r\n            ],\r\n            [\r\n              -84.961602,\r\n              32.419206\r\n            ]\r\n          ]\r\n        ]\r\n      },\r\n      &quot;properties&quot;: {\r\n        &quot;release&quot;: 2,\r\n        &quot;capture_dates_range&quot;: &quot;3/26/2020-7/22/2020&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77962098/streaming-a-big-geojson-with-jq",
        "title": "Streaming a big geojson with jq"
    },
    {
        "tags": [
            "bash",
            "filter",
            "dynamic",
            "syntax",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1707602790,
                "last_edit_date": 1707602790,
                "creation_date": 1707602334,
                "answer_id": 77974874,
                "question_id": 77974838,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use variables defined with `--arg` options to import the parameters into the filter, and then just call `jq` without capturing its result in a variable. Its output automatically becomes the output of the function, and as the call to `jq` is the last (and only) one in the function, its exit code is also automatically re-used as exit code for the function call. To use dot notation for paths containing a series of field names, split the string by the dots, and use `getpath` with the resulting array.\r\n```sh\r\nretrieve_from_array2() {\r\n  jq --arg cat &quot;$1&quot; --arg key &quot;$2&quot; --arg val &quot;$3&quot; \\\r\n    &#39;getpath($cat / &quot;.&quot;)[] | select(.[$key] == $val)&#39; ./silly-sample.json\r\n}\r\n```\r\n```json\r\n$ retrieve_from_array2 &quot;fruits_with_a&quot; &quot;fruitName&quot; &quot;Apricot&quot;\r\n{\r\n  &quot;fruitName&quot;: &quot;Apricot&quot;,\r\n  &quot;value&quot;: &quot;...&quot;\r\n}\r\n```\r\n```json\r\n$ retrieve_from_array2 &quot;vegetables.with_a&quot; &quot;n&quot; &quot;asparagus&quot;\r\n{\r\n  &quot;n&quot;: &quot;asparagus&quot;,\r\n  &quot;value&quot;: &quot;...&quot;\r\n}\r\n```",
                "title": "Syntax problems when parameterizing filters in jq in a bash function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1707602790,
        "creation_date": 1707601493,
        "question_id": 77974838,
        "body_markdown": "I&#39;m using `jq` in a `bash` script to search for items in arrays that can be found anywhere in a json file. I have already written a function that has bad practices that solves the problem. I want to know how to do it correctly before writing more scripts that use `jq`.\r\n\r\nHere is an example of a json file, `silly-sample.json`:\r\n\r\n```\r\n{\r\n  &quot;fruits_with_a&quot;:[\r\n    {&quot;fruitName&quot;:&quot;Apple&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;fruitName&quot;:&quot;Apricot&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;fruitName&quot;:&quot;Aratiles&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;fruitName&quot;:&quot;Araza&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;fruitName&quot;:&quot;Avocado&quot;,&quot;value&quot;:&quot;...&quot;}\r\n  ],\r\n  &quot;fruits_with_b&quot;:[\r\n    {&quot;name&quot;:&quot;Banana&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;name&quot;:&quot;Blackberry&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;name&quot;:&quot;Black sapote&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;name&quot;:&quot;Blueberry&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;name&quot;:&quot;Breadfruit&quot;,&quot;value&quot;:&quot;...&quot;}\r\n  ],\r\n  &quot;fruits_with_c&quot;:[\r\n    {&quot;id&quot;:&quot;Cherry&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;id&quot;:&quot;Coconut&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;id&quot;:&quot;Cranberry&quot;,&quot;value&quot;:&quot;...&quot;}\r\n  ],\r\n  &quot;fruits_with_d&quot;:[\r\n    {&quot;sku&quot;:&quot;Dragonfruit&quot;,&quot;value&quot;:&quot;...&quot;},\r\n    {&quot;sku&quot;:&quot;Durian&quot;,&quot;value&quot;:&quot;...&quot;}\r\n  ],\r\n  &quot;vegetables&quot;:{\r\n    &quot;with_a&quot;:[\r\n      {&quot;n&quot;:&quot;artichoke&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;aubergine&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;asparagus&quot;,&quot;value&quot;:&quot;...&quot;}\r\n    ],\r\n    &quot;with_b&quot;:[\r\n      {&quot;n&quot;:&quot;broccoflower&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;broccoli&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;brussels sprouts&quot;,&quot;value&quot;:&quot;...&quot;}\r\n    ],\r\n    &quot;with_c&quot;:[\r\n      {&quot;n&quot;:&quot;cabbage&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;cauliflower&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;celery&quot;,&quot;value&quot;:&quot;...&quot;},\r\n      {&quot;n&quot;:&quot;cichory&quot;,&quot;value&quot;:&quot;...&quot;}\r\n    ]\r\n  }\r\n}\r\n```\r\nMost of the searches I perform are pretty simple and follow a pattern. The parameters that change are: the _array_ on which I want to perform the search, the _field_ I want to use for the search and the _value_ I want to search for. Here are some examples of the queries I perform with `jq`:\r\n\r\n`jq -r &#39;.fruits_with_b[] | select(.name==&quot;Blackberry&quot;)&#39; &quot;./silly-sample.json&quot;`\r\n\r\n`jq -r &#39;.fruits_with_c[] | select(.id==&quot;Coconut&quot;)&#39; &quot;./silly-sample.json&quot;`\r\n\r\n`jq -r &#39;.vegetables.with_a[] | select(.n==&quot;aubergine&quot;)&#39; &quot;./silly-sample.json&quot;`\r\n\r\nAs mentioned, I created a `bash` function (`retrieve_from_array`) to generalize the way my script searches for an item in an array. At that time I didn&#39;t know the correct way to pass parameters to `jq` using `--arg` and what I ended up doing was concatenating the entire command into a string and then executing it using eval. So far, that solution has worked perfectly.\r\n\r\n```\r\nretrieve_from_array(){\r\n  local jq_query jq_result &amp;&amp; \\\r\n  jq_query=&quot;jq -r &#39;.${1}[] | select(.${2}==\\&quot;${3}\\&quot;)&#39; \\&quot;./silly-sample.json\\&quot;&quot; &amp;&amp; \\\r\n  jq_result=&quot;$(eval &quot;${jq_query}&quot;)&quot; &amp;&amp; \\\r\n  echo &quot;${jq_result}&quot; &amp;&amp; \\\r\n  return 0\r\n\r\n  return 1\r\n}\r\n\r\nretrieve_from_array &quot;fruits_with_a&quot; &quot;fruitName&quot; &quot;Apricot&quot; &amp;&amp; echo &quot;Executed successfully!!!&quot;\r\nretrieve_from_array &quot;vegetables.with_a&quot; &quot;n&quot; &quot;asparagus&quot; &amp;&amp; echo &quot;Executed successfully!!!&quot;\r\n```\r\nNow I need to write more `bash` functions with `jq` to perform additional searches with more conditions. The logical thing to do would be to continue using string concatenation and add more conditions, more operators and more values as the searches need it and then execute with eval, but that does not seem to be a good practice to scale.\r\n\r\nI have tried to rewrite the `retrieve_from_array` function by passing parameters to `jq` using `--arg` and interpolating the parameters in various ways within `jq`&#180;s filter syntax, but have had no success.\r\n\r\n```\r\nretrieve_from_array_v2(){\r\n  local jq_result &amp;&amp; \\\r\n  jq_result=&quot;$(jq -r --arg a &quot;${1}&quot; --arg k &quot;${2}&quot; --arg v &quot;${3}&quot; &#39;.$a[] | select(.$k==&quot;$v&quot;)&#39; &quot;./silly-sample.json&quot;)&quot; &amp;&amp; \\\r\n  echo &quot;${jq_result}&quot; &amp;&amp; \\\r\n  return 0\r\n\r\n  return 1\r\n}\r\n```\r\nI get a `jq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:` error message.\r\n\r\nThe problem is not in replacing the _value_ I want to search for (`==&quot;Blackberry&quot;`, `==&quot;celery&quot;`). Syntax errors start appearing when I try to replace the _array_ (`.vegetables.with_a[]`, `.fruits_with_a[]`) and _field_ (`.sku`, `.name`) with the arguments received in `jq.\r\n\r\nHow could I rewrite my `bash` function to work without using eval?",
        "link": "https://stackoverflow.com/questions/77974838/syntax-problems-when-parameterizing-filters-in-jq-in-a-bash-function",
        "title": "Syntax problems when parameterizing filters in jq in a bash function"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707635362,
                "last_edit_date": 1707635362,
                "creation_date": 1707632437,
                "answer_id": 77975816,
                "question_id": 77975793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    . as $arr | $arr\r\n    | keys                        # Get all keys (names) of the array\r\n    | map_values(\r\n        . as $item | {\r\n            item,                 # Preserve the original item\r\n            attribute: $item | keys # Move name to &quot;attribute&quot; property\r\n        }\r\n    )\r\n\r\n",
                "title": "JSON: moving item&#39;s key/name into attribute and convert it to array with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707635347,
                "creation_date": 1707635347,
                "answer_id": 77975902,
                "question_id": 77975793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of `keys` I would start with `to_entries`:\r\n\r\n    to_entries | map({name: .key} + .value)\r\n\r\n&lt;sup&gt;([online demo](https://jqplay.org/s/98DMHXY56WS))&lt;/sup&gt;\r\n\r\nThe reverse then is\r\n\r\n    map({key: .name, value: del(.name)}) | from_entries\r\n\r\n&lt;sup&gt;([online demo](https://jqplay.org/s/uEIXGTe3dNy))&lt;/sup&gt;",
                "title": "JSON: moving item&#39;s key/name into attribute and convert it to array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1707635362,
        "creation_date": 1707631813,
        "last_edit_date": 1707632161,
        "question_id": 77975793,
        "body_markdown": "here is original json example:\r\n\r\n    {\r\n      &quot;item1&quot;: {\r\n        &quot;foo1&quot;: 1,\r\n        &quot;foo2&quot;: 2\r\n    },\r\n      &quot;item2&quot;: {\r\n        &quot;foo1&quot;: 11,\r\n        &quot;foo2&quot;: 22\r\n      }\r\n    }\r\n\r\nhow can i convert it into json array with new attribute using jq:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;item1&quot;,\r\n        &quot;foo1&quot;: 1,\r\n        &quot;foo2&quot;: 2\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;item2&quot;,\r\n        &quot;foo1&quot;: 11,\r\n        &quot;foo2&quot;: 22\r\n      }\r\n    ]\r\n\r\nalso, it&#39;s very interesting, how opposite conversion can be done as well!\r\n\r\nthanks in advance!\r\n\r\ni have been trying different approaches using &quot;keys&quot; and &quot;keys_unsorted&quot;, but never got it work ((",
        "link": "https://stackoverflow.com/questions/77975793/json-moving-items-key-name-into-attribute-and-convert-it-to-array-with-jq",
        "title": "JSON: moving item&#39;s key/name into attribute and convert it to array with jq"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1707753416,
                "post_id": 77981950,
                "comment_id": 137478789,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707748925,
                "last_edit_date": 1707748925,
                "creation_date": 1707746533,
                "answer_id": 77981988,
                "question_id": 77981950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterating over an array produces its items. To instead join the items into a single string, use the [`join` filter](https://jqlang.github.io/jq/manual/#join). Also, inside strings you can use `\\&quot;` to generate quotes, and [string interpolation `\\(…)`](https://jqlang.github.io/jq/manual/#string-interpolation) to inject values.\r\n```sh\r\njq -r &#39;&quot;alicreate \\&quot;\\(.&quot;alias-name&quot;)\\&quot;,\\&quot;\\(\r\n  .&quot;member-entry&quot;.&quot;alias-entry-name&quot; | join(&quot;;&quot;)\r\n)\\&quot;&quot;&#39;\r\n```\r\n```text\r\nalicreate &quot;soufriere&quot;,&quot;21:00:f4:e9:d4:50:56:7e;21:00:f4:e9:d4:50:56:7f&quot;\r\nalicreate &quot;stromboli&quot;,&quot;21:00:f4:e9:d4:50:56:8e;21:00:f4:e9:d4:50:56:9e&quot;\r\n```\r\n[Demo](https://jqplay.org/s/qW2LqbcMGZl)\r\n\r\nNote that you might want to properly escape the values, rather than just enclosing them with double quotes, but which encoding to use highly depends on the use-case of your output.",
                "title": "Transforming a JSON input subarray into a string sequential list output"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707753525,
                "creation_date": 1707753525,
                "answer_id": 77982725,
                "question_id": 77981950,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "We can use the `@csv` filter to handle quoting for us:\r\n```sh\r\njq -r &#39;\r\n  [.&quot;alias-name&quot;, (.&quot;member-entry&quot;.&quot;alias-entry-name&quot; | join(&quot;;&quot;))]\r\n  | @csv\r\n  | &quot;alicreate &quot; + .\r\n&#39;\r\n```\r\n```none\r\nalicreate &quot;soufriere&quot;,&quot;21:00:f4:e9:d4:50:56:7e;21:00:f4:e9:d4:50:56:7f&quot;\r\nalicreate &quot;stromboli&quot;,&quot;21:00:f4:e9:d4:50:56:8e;21:00:f4:e9:d4:50:56:9e&quot;\r\n```",
                "title": "Transforming a JSON input subarray into a string sequential list output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1707757814,
        "creation_date": 1707746217,
        "last_edit_date": 1707757814,
        "question_id": 77981950,
        "body_markdown": "Here is my input:\r\n```lang-json\r\n{\r\n  &quot;alias-name&quot;: &quot;soufriere&quot;,\r\n  &quot;member-entry&quot;: {\r\n    &quot;alias-entry-name&quot;: [\r\n      &quot;21:00:f4:e9:d4:50:56:7e&quot;,\r\n      &quot;21:00:f4:e9:d4:50:56:7f&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;alias-name&quot;: &quot;stromboli&quot;,\r\n  &quot;member-entry&quot;: {\r\n    &quot;alias-entry-name&quot;: [\r\n      &quot;21:00:f4:e9:d4:50:56:8e&quot;\r\n      &quot;21:00:f4:e9:d4:50:56:9e&quot;\r\n    ]\r\n  }\r\n}\r\n```\r\nI&#39;d like to turn this into output \r\n```\r\nalicreate &quot;soufriere&quot;,&quot;21:00:f4:e9:d4:50:56:7e;21:00:f4:e9:d4:50:56:7f&quot;\r\nalicreate &quot;stromboli&quot;,&quot;21:00:f4:e9:d4:50:56:8e;21:00:f4:e9:d4:50:56:9e&quot;\r\n```\r\n\r\nI tried this:\r\n```lang-bash\r\njq -r --arg quote &quot;\\&quot;&quot; (&quot;alicreate &quot; + $quote + .&quot;alias-name&quot; + $quote + &quot;,&quot; + $quote + .&quot;member-entry&quot;.&quot;alias-entry-name&quot;[] + $quote)&#39;\r\n```\r\nbut it gives a one by one line instead of a sequential.\r\n```\r\nalicreate &quot;soufriere&quot;,&quot;21:00:f4:e9:d4:50:56:7e&quot;\r\nalicreate &quot;soufriere&quot;,&quot;21:00:f4:e9:d4:50:56:7f&quot;\r\nalicreate &quot;stromboli&quot;,&quot;21:00:f4:e9:d4:50:56:8e&quot;\r\nalicreate &quot;stromboli&quot;,&quot;21:00:f4:e9:d4:50:56:9e&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77981950/transforming-a-json-input-subarray-into-a-string-sequential-list-output",
        "title": "Transforming a JSON input subarray into a string sequential list output"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1707832096,
                "creation_date": 1707832096,
                "answer_id": 77988419,
                "question_id": 77988392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson`, and update the fields in question using `.[].b |=`.\r\n```sh\r\n.[].b |= fromjson\r\n```\r\n[Demo](https://jqplay.org/s/NAgc9RiyBf6)\r\n\r\nIf you want to decode all JSON-encoded strings, unknowing which ones are, you could `try` using `fromjson`, and in case of a failure resort to the original input `.`. `try` can be abbreviated to `?`:\r\n```sh\r\n.[][] |= (fromjson? // .)\r\n```\r\n[Demo](https://jqplay.org/s/fIHctyWqpMa)\r\n\r\nBoth output:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: {\r\n      &quot;c&quot;: 2\r\n    }\r\n  }\r\n]\r\n```\r\n",
                "title": "How do I replace a JSON string with its parsed equivalent in place with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1707832096,
        "creation_date": 1707831897,
        "question_id": 77988392,
        "body_markdown": "I have a JSON array with a bunch of objects, all the same keys, but some of the keys contain serialized JSON instead of actual JSON. Something like this.\r\n\r\n```js\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: &quot;{\\&quot;c\\&quot;:2}&quot;\r\n  },\r\n]\r\n```\r\n\r\nand I&#39;d like to replace the contents of all the `b`s with their parsed form.\r\n\r\n\r\n```js\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: { &quot;c&quot;: 2 }\r\n  },\r\n]\r\n```\r\n\r\nHow can I do this, ideally with jq?",
        "link": "https://stackoverflow.com/questions/77988392/how-do-i-replace-a-json-string-with-its-parsed-equivalent-in-place-with-jq",
        "title": "How do I replace a JSON string with its parsed equivalent in place with jq?"
    },
    {
        "tags": [
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707862121,
                "creation_date": 1707862121,
                "answer_id": 77991127,
                "question_id": 77991126,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\ncat ./my-input-file | jq -R --slurp . &gt; ./my-output.json\r\n```",
                "title": "I want to convert a text file into one JSON string using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1707862121,
        "creation_date": 1707862121,
        "question_id": 77991126,
        "body_markdown": "I have a text file, I want to make it into a single JSON string with quotes and \\n, ideally from the command line. I don&#39;t want multiple strings, or dictionaries.",
        "link": "https://stackoverflow.com/questions/77991126/i-want-to-convert-a-text-file-into-one-json-string-using-jq",
        "title": "I want to convert a text file into one JSON string using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1707921871,
                "last_edit_date": 1707921871,
                "creation_date": 1707873450,
                "answer_id": 77991677,
                "question_id": 77991602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I imagine there are lots of ways to do this, and some probably better, but here&#39;s a `jq` filter that does it (using the `--raw-output` option).\r\n```\r\n.[]\r\n| [.field1, .field2, (.Tags[]|select(.Key == &quot;Name&quot;).Value)]\r\n| join(&quot; &quot;)\r\n```\r\nExample output:\r\n```\r\n1 x Name1\r\n2 y Name2\r\n3 z\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/7A5aooFmOXT &quot;Click me!&quot;).\r\n\r\nIf `&quot;Tags&quot;` includes multiple `.Key == &quot;Name&quot;` objects, each `&quot;Value&quot;` is appended on the same line, like:\r\n```\r\n1 x Name1 AnotherName\r\n2 y Name2\r\n3 z\r\n```\r\nTry this on [jqplay.org](https://jqplay.org/s/t3WeLDoJUqS &quot;Click this too!&quot;).",
                "title": "How to include a object when it doesn&#39;t include a field from a select() call"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707877802,
                "creation_date": 1707877802,
                "answer_id": 77991844,
                "question_id": 77991602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What if the `.Tags` array contains more than just one match? Say, there was a third item `{&quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;AnotherName&quot;}` in the `.Tags` array of the first (&quot;1 x&quot;) record. Would you then prefer as output one combined line like `1 x Name1 AnotherName`, or rather two separate lines like `1 x Name1` and `1 x AnotherName`? Anyway, here&#39;s both variants using [string interpolation](https://jqlang.github.io/jq/manual/#string-interpolation), and showing outputs based on the extended input with the one added match mentioned above.\r\n\r\nCombined lines ([Demo](https://jqplay.org/s/SKj2cnd70tQ)):\r\n```sh\r\n.[] | (.Tags | map(select(.Key == &quot;Name&quot;).Value)) as $m\r\n| &quot;\\(.field1) \\(.field2) \\($m | join(&quot; &quot;))&quot;\r\n```\r\n```\r\n1 x Name1 AnotherName\r\n2 y Name2\r\n3 z \r\n```\r\n\r\nSeparate lines ([Demo](https://jqplay.org/s/LPRICfk0QXU)):\r\n```sh\r\n.[] | (.Tags | map(select(.Key == &quot;Name&quot;).Value)) as $m\r\n| &quot;\\(.field1) \\(.field2) \\($m[] // &quot;&quot;)&quot;\r\n```\r\n```\r\n1 x Name1\r\n1 x AnotherName\r\n2 y Name2\r\n3 z \r\n```",
                "title": "How to include a object when it doesn&#39;t include a field from a select() call"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1707921871,
        "creation_date": 1707871429,
        "question_id": 77991602,
        "body_markdown": "I want to list a couple fields from a JSON structure, including an optional one, that is potentially in an array with other fields I don&#39;t want to display. I&#39;ve been using select() to get the one value from the array I want, but if I have an object that doesn&#39;t have that optional key, it is skipped all together. Let me show an example. Here&#39;s the data:\r\n```\r\n[\r\n{&quot;field1&quot;:&quot;1&quot;, &quot;field2&quot;:&quot;x&quot;, &quot;Tags&quot;:[{&quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;Name1&quot;}, {&quot;Key&quot;: &quot;tag1&quot;, &quot;Value&quot;: &quot;tag1valuea&quot;}]},\r\n{&quot;field1&quot;:&quot;2&quot;, &quot;field2&quot;:&quot;y&quot;, &quot;Tags&quot;:[{&quot;Key&quot;: &quot;Name&quot;, &quot;Value&quot;: &quot;Name2&quot;}]},\r\n{&quot;field1&quot;:&quot;3&quot;, &quot;field2&quot;:&quot;z&quot;, &quot;Tags&quot;:[{&quot;Key&quot;: &quot;tag2&quot;, &quot;Value&quot;: &quot;tag2valueb&quot;}]}\r\n]\r\n```\r\nThe output I want is:\r\n```\r\n1 x name1\r\n2 y name2\r\n3 z\r\n```\r\nI have tried:\r\n```\r\njq -r &#39;.[] | .field1 + &quot; &quot; + .field2 + &quot; &quot; + (.Tags[] | select(.Key == &quot;Name&quot;) .Value)&#39;\r\n1 x Name1\r\n2 y Name2\r\n```\r\nBut, as you can see, it drops the 3rd entry because it doesn&#39;t have a &quot;Key&quot; that is set to &quot;Name&quot;.\r\n\r\nThen I tried:\r\n```\r\njq -r &#39;.[] | .field1 + &quot; &quot; + .field2 + &quot; &quot; + (.Tags[] | if(.Key == &quot;Name&quot;) then .Value else null end)&#39;\r\n1 x Name1\r\n1 x\r\n2 y Name2\r\n3 z\r\n```\r\nYou can see I ended up with two entries for the first object because it has an extra element in the array that I don&#39;t care about.\r\n\r\nI have tried numerous permutations of the above two options all to no avail. I&#39;m hoping someone has a clever way to get jq to not &quot;empty&quot; the item if it doesn&#39;t have key I am select&#39;ing and/or repeat when there are items in the array I don&#39;t want to select.",
        "link": "https://stackoverflow.com/questions/77991602/how-to-include-a-object-when-it-doesnt-include-a-field-from-a-select-call",
        "title": "How to include a object when it doesn&#39;t include a field from a select() call"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "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": 1707969377,
                "post_id": 77998185,
                "comment_id": 137507455,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5333366,
                    "reputation": 33,
                    "user_id": 4253298,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SRDEzHDAm1c/AAAAAAAAAAI/AAAAAAAA3DE/m6LAEbfuldQ/s256-rj/photo.jpg",
                    "display_name": "Chris F",
                    "link": "https://stackoverflow.com/users/4253298/chris-f"
                },
                "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": 1707969825,
                "post_id": 77998185,
                "comment_id": 137507483,
                "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": 1707969948,
                "post_id": 77998185,
                "comment_id": 137507492,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5333366,
                    "reputation": 33,
                    "user_id": 4253298,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SRDEzHDAm1c/AAAAAAAAAAI/AAAAAAAA3DE/m6LAEbfuldQ/s256-rj/photo.jpg",
                    "display_name": "Chris F",
                    "link": "https://stackoverflow.com/users/4253298/chris-f"
                },
                "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": 1707970035,
                "post_id": 77998185,
                "comment_id": 137507497,
                "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": 1707970070,
                "post_id": 77998185,
                "comment_id": 137507502,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5333366,
                    "reputation": 33,
                    "user_id": 4253298,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SRDEzHDAm1c/AAAAAAAAAAI/AAAAAAAA3DE/m6LAEbfuldQ/s256-rj/photo.jpg",
                    "display_name": "Chris F",
                    "link": "https://stackoverflow.com/users/4253298/chris-f"
                },
                "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": 1707970381,
                "post_id": 77998185,
                "comment_id": 137507523,
                "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": 1707970572,
                "post_id": 77998185,
                "comment_id": 137507532,
                "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": 1707971282,
                "post_id": 77998185,
                "comment_id": 137507569,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5333366,
                    "reputation": 33,
                    "user_id": 4253298,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-SRDEzHDAm1c/AAAAAAAAAAI/AAAAAAAA3DE/m6LAEbfuldQ/s256-rj/photo.jpg",
                    "display_name": "Chris F",
                    "link": "https://stackoverflow.com/users/4253298/chris-f"
                },
                "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": 1707972120,
                "post_id": 77998185,
                "comment_id": 137507628,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1707982874,
                "creation_date": 1707982874,
                "answer_id": 77999075,
                "question_id": 77998185,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the [comments thread](https://stackoverflow.com/questions/77998185/how-to-merge-unique-values-for-a-child-array-when-merging-objects?noredirect=1#comment137507455_77998185):\r\n\r\n&gt; The env list should be unique by name and the secrets list should be unique by secretID. […] I was wondering if it could be unique by the first object key in the array? […] name always comes before value and secretID always comes before mountPath\r\n\r\n&gt; Object fields don&#39;t have an order conveyed by the format, only array items do. The order you observe in a specific file is just its current representation.\r\n\r\n&gt; Just for the fun of it, how would you do it anyway?\r\n\r\nSo, let the fun begin:\r\n\r\nThis captures and iterates over all items of non-empty arrays from the `.default` branch (saving the array path with `paths(arrays | select(has(0)))`, each item&#39;s value with `getpath(…)[]`, and the first item&#39;s key and value using `to_entries[0]`). The iteration&#39;s base document is the merge you already performed, but with these arrays removed from the `.default` branch, so the saved items can be individually tested and appended to it if they pass the condition that no other first key&#39;s value matches theirs: `IN(.[][$v0.key]; $v0.value) | not`.\r\n```sh\r\n.environments | [.default | paths(arrays | select(has(0))) as $p\r\n  | getpath($p)[] as $v | {$p,$v,v0:($v | to_entries[0])}\r\n] as $a | reduce $a[] as {$p,$v,$v0} ((.default | delpaths([$a[].p])) * .dev;\r\n  setpath($p; getpath($p) | . + [select(IN(.[][$v0.key]; $v0.value) | not) | $v])\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/-435Dd59AzD)",
                "title": "How to merge unique values for a child array when merging objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1707982874,
        "creation_date": 1707964634,
        "last_edit_date": 1707977349,
        "question_id": 77998185,
        "body_markdown": "I want to merge the `.environments.default` and `.environments.dev` objects together, so that `dev` values override any `default` values and `default` values fill in anything not defined in the `dev` object. If I use `.environments.default * .environments.dev` most of the objects are merged correctly, except for the array lists under the `env` and `secrets` objects. The entire `dev` object is used, but I want the array lists to be merged with unique values.\r\n\r\nIs there anyway to get this result with `jq`? If it helps I could also try doing this in `yq` with the YAML file.\r\n\r\nI would also really like to know if this is possible without hardcoding `&quot;env&quot;` or `&quot;secrets&quot;` anywhere in the code.\r\n\r\nWhen I use `.environments.default * .environments.dev` on the below source...\r\n\r\n**Source:**\r\n```json\r\n{\r\n&quot;environments&quot;: {\r\n    &quot;default&quot;: {\r\n      &quot;config&quot;: {\r\n        &quot;security&quot;: {\r\n          &quot;user&quot;: 0,\r\n          &quot;group&quot;: 0\r\n        },\r\n        &quot;resources&quot;: {\r\n          &quot;limits&quot;: {\r\n            &quot;memory&quot;: &quot;256Mi&quot;,\r\n            &quot;cpu&quot;: &quot;500m&quot;\r\n          }\r\n        },\r\n        &quot;env&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;DEFAULT_ENV&quot;,\r\n            &quot;value&quot;: &quot;DEFAULT_ENV_VALUE&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;BASE_URL&quot;,\r\n            &quot;value&quot;: &quot;DEFAULT_BASE_URL&quot;\r\n          }\r\n        ],\r\n        &quot;secrets&quot;: [\r\n          {\r\n            &quot;secretID&quot;: &quot;567&quot;,\r\n            &quot;mountPath&quot;: &quot;/default/dir/to/567/path&quot;\r\n          },\r\n          {\r\n            &quot;secretID&quot;: &quot;123&quot;,\r\n            &quot;mountPath&quot;: &quot;/default/dir/to/123/path&quot;\r\n          },\r\n          {\r\n            &quot;secretUUID&quot;: &quot;789&quot;,\r\n            &quot;mountPath&quot;: &quot;/default/dir/to/789/path&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;dev&quot;: {\r\n      &quot;config&quot;: {\r\n        &quot;replicas&quot;: 1,\r\n        &quot;resources&quot;: {\r\n          &quot;limits&quot;: {\r\n            &quot;cpu&quot;: &quot;5000m&quot;\r\n          }\r\n        },\r\n        &quot;env&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;BASE_URL&quot;,\r\n            &quot;value&quot;: &quot;DEV_BASE_URL&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;DEV_ENV_1&quot;,\r\n            &quot;value&quot;: &quot;DEV_ENV_1&quot;\r\n          }\r\n        ],\r\n        &quot;secrets&quot;: [\r\n          {\r\n            &quot;secretID&quot;: &quot;456&quot;,\r\n            &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n          },\r\n          {\r\n            &quot;secretID&quot;: &quot;123&quot;,\r\n            &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI get...\r\n\r\n**Current output:**\r\n```json\r\n{\r\n  &quot;config&quot;: {\r\n    &quot;security&quot;: {\r\n      &quot;user&quot;: 0,\r\n      &quot;group&quot;: 0\r\n    },\r\n    &quot;resources&quot;: {\r\n      &quot;limits&quot;: {\r\n        &quot;memory&quot;: &quot;256Mi&quot;,\r\n        &quot;cpu&quot;: &quot;5000m&quot;\r\n      }\r\n    },\r\n    &quot;env&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;BASE_URL&quot;,\r\n        &quot;value&quot;: &quot;DEV_BASE_URL&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;DEV_ENV_1&quot;,\r\n        &quot;value&quot;: &quot;DEV_ENV_1&quot;\r\n      }\r\n    ],\r\n    &quot;secrets&quot;: [\r\n      {\r\n        &quot;secretID&quot;: &quot;456&quot;,\r\n        &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n      },\r\n      {\r\n        &quot;secretID&quot;: &quot;123&quot;,\r\n        &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n      }\r\n    ],\r\n    &quot;replicas&quot;: 1\r\n  }\r\n}\r\n```\r\nbut I want...\r\n\r\n**Desired output:**\r\n```json\r\n{\r\n  &quot;config&quot;: {\r\n    &quot;security&quot;: {\r\n      &quot;user&quot;: 0,\r\n      &quot;group&quot;: 0\r\n    },\r\n    &quot;resources&quot;: {\r\n      &quot;limits&quot;: {\r\n        &quot;memory&quot;: &quot;256Mi&quot;,\r\n        &quot;cpu&quot;: &quot;5000m&quot;\r\n      }\r\n    },\r\n    &quot;env&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;BASE_URL&quot;,\r\n        &quot;value&quot;: &quot;DEV_BASE_URL&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;DEV_ENV_1&quot;,\r\n        &quot;value&quot;: &quot;DEV_ENV_1&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;DEFAULT_ENV&quot;,\r\n        &quot;value&quot;: &quot;DEFAULT_ENV_VALUE&quot;\r\n      }\r\n    ],\r\n    &quot;secrets&quot;: [\r\n      {\r\n        &quot;secretID&quot;: &quot;456&quot;,\r\n        &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n      },\r\n      {\r\n        &quot;secretID&quot;: &quot;123&quot;,\r\n        &quot;mountPath&quot;: &quot;/dev/dir/to/456/path&quot;\r\n      },\r\n      {\r\n        &quot;secretID&quot;: &quot;567&quot;,\r\n        &quot;mountPath&quot;: &quot;/default/dir/to/567/path&quot;\r\n      },\r\n      {\r\n        &quot;secretUUID&quot;: &quot;789&quot;,\r\n        &quot;mountPath&quot;: &quot;/default/dir/to/789/path&quot;\r\n      }\r\n    ],\r\n    &quot;replicas&quot;: 1\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77998185/how-to-merge-unique-values-for-a-child-array-when-merging-objects",
        "title": "How to merge unique values for a child array when merging objects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708003046,
                "last_edit_date": 1708003046,
                "creation_date": 1708002049,
                "answer_id": 78000990,
                "question_id": 78000879,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With a slight bit of reform, it could be written as below. The key is to reuse the variable `$k` once for forming the key name and then later to exclude it from the members.\r\n\r\n```none\r\n.body.primarykey[] as $k | \r\n{ \r\n  parameters: {($k): &quot;&quot; }, \r\n  body: (.body.members | map(select(.name != $k) | {(.name): .type | ascii_downcase}) | add)\r\n}\r\n```\r\n\r\njqplay - https://jqplay.org/s/hdTpOhvZ0I2",
                "title": "How to form correct JQ Expression to get exact output data from JSON file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708021511,
        "creation_date": 1708001039,
        "last_edit_date": 1708021511,
        "question_id": 78000879,
        "body_markdown": "I am using JQ Play. \r\n\r\nHere is my JSON Data - \r\n```lang-json\r\n{\r\n  &quot;body&quot;: {\r\n    &quot;name&quot;: &quot;DATATYPES&quot;,\r\n    &quot;primarykey&quot;: [\r\n      &quot;db_number&quot;\r\n    ],\r\n    &quot;members&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;db_number&quot;,\r\n        &quot;type&quot;: &quot;NUMBER&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_date&quot;,\r\n        &quot;type&quot;: &quot;DATE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6)&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp_with_local_time_zone&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6) WITH LOCAL TIME ZONE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_char&quot;,\r\n        &quot;type&quot;: &quot;CHAR&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_float&quot;,\r\n        &quot;type&quot;: &quot;FLOAT&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_nchar&quot;,\r\n        &quot;type&quot;: &quot;NCHAR&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_nvarchar2&quot;,\r\n        &quot;type&quot;: &quot;NVARCHAR2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_varchar2&quot;,\r\n        &quot;type&quot;: &quot;VARCHAR2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_binary_float&quot;,\r\n        &quot;type&quot;: &quot;BINARY_FLOAT&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_binary_double&quot;,\r\n        &quot;type&quot;: &quot;BINARY_DOUBLE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp_with_time_zone&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6) WITH TIME ZONE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_interval_year_to_month&quot;,\r\n        &quot;type&quot;: &quot;INTERVAL YEAR(2) TO MONTH&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_interval_day_to_second&quot;,\r\n        &quot;type&quot;: &quot;INTERVAL DAY(2) TO SECOND(6)&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_long&quot;,\r\n        &quot;type&quot;: &quot;LONG&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_blob&quot;,\r\n        &quot;type&quot;: &quot;BLOB&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_clob&quot;,\r\n        &quot;type&quot;: &quot;CLOB&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_boolean&quot;,\r\n        &quot;type&quot;: &quot;CHAR&quot;\r\n      }\r\n    ],\r\n    &quot;links&quot;: [\r\n      {\r\n        &quot;rel&quot;: &quot;collection&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;canonical&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/datatypes/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;alternate&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/datatypes/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/openapi+json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;describes&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/datatypes/&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nMy JQ - \r\n```lang-js\r\n{parameters: (.body.primarykey[] | {(.): &quot;&quot;}), body: (.body.members | map({(.name): .type |ascii_downcase}) | add)}\r\n```\r\nOutput -\r\n```lang-json\r\n{\r\n  &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;&quot;\r\n  },\r\n  &quot;body&quot;: {\r\n    &quot;db_number&quot;: &quot;number&quot;,\r\n    &quot;db_date&quot;: &quot;date&quot;,\r\n    &quot;db_timestamp&quot;: &quot;timestamp(6)&quot;,\r\n    &quot;db_timestamp_with_local_time_zone&quot;: &quot;timestamp(6) with local time zone&quot;,\r\n    &quot;db_char&quot;: &quot;char&quot;,\r\n    &quot;db_float&quot;: &quot;float&quot;,\r\n    &quot;db_nchar&quot;: &quot;nchar&quot;,\r\n    &quot;db_nvarchar2&quot;: &quot;nvarchar2&quot;,\r\n    &quot;db_varchar2&quot;: &quot;varchar2&quot;,\r\n    &quot;db_binary_float&quot;: &quot;binary_float&quot;,\r\n    &quot;db_binary_double&quot;: &quot;binary_double&quot;,\r\n    &quot;db_timestamp_with_time_zone&quot;: &quot;timestamp(6) with time zone&quot;,\r\n    &quot;db_interval_year_to_month&quot;: &quot;interval year(2) to month&quot;,\r\n    &quot;db_interval_day_to_second&quot;: &quot;interval day(2) to second(6)&quot;,\r\n    &quot;db_long&quot;: &quot;long&quot;,\r\n    &quot;db_blob&quot;: &quot;blob&quot;,\r\n    &quot;db_clob&quot;: &quot;clob&quot;,\r\n    &quot;db_boolean&quot;: &quot;char&quot;\r\n  }\r\n}\r\n```\r\nHere, my requirement is - I want to remove record / field from output `body:{}` which is having same name as `primarykey`. \r\n\r\nSo I am not able to form such JQ that will not fetch matching record with `primarykey` inside body. \r\n\r\n\r\nMy expected output is -\r\n```lang-json\r\n{\r\n  &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;&quot;\r\n  },\r\n  &quot;body&quot;: {\r\n    &quot;db_date&quot;: &quot;date&quot;,\r\n    &quot;db_timestamp&quot;: &quot;timestamp(6)&quot;,\r\n    &quot;db_timestamp_with_local_time_zone&quot;: &quot;timestamp(6) with local time zone&quot;,\r\n    &quot;db_char&quot;: &quot;char&quot;,\r\n    &quot;db_float&quot;: &quot;float&quot;,\r\n    &quot;db_nchar&quot;: &quot;nchar&quot;,\r\n    &quot;db_nvarchar2&quot;: &quot;nvarchar2&quot;,\r\n    &quot;db_varchar2&quot;: &quot;varchar2&quot;,\r\n    &quot;db_binary_float&quot;: &quot;binary_float&quot;,\r\n    &quot;db_binary_double&quot;: &quot;binary_double&quot;,\r\n    &quot;db_timestamp_with_time_zone&quot;: &quot;timestamp(6) with time zone&quot;,\r\n    &quot;db_interval_year_to_month&quot;: &quot;interval year(2) to month&quot;,\r\n    &quot;db_interval_day_to_second&quot;: &quot;interval day(2) to second(6)&quot;,\r\n    &quot;db_long&quot;: &quot;long&quot;,\r\n    &quot;db_blob&quot;: &quot;blob&quot;,\r\n    &quot;db_clob&quot;: &quot;clob&quot;,\r\n    &quot;db_boolean&quot;: &quot;char&quot;\r\n  }\r\n}\r\n```\r\nPlease help me with correct JQ that will work in jqplay.org \r\n\r\n",
        "link": "https://stackoverflow.com/questions/78000879/how-to-form-correct-jq-expression-to-get-exact-output-data-from-json-file",
        "title": "How to form correct JQ Expression to get exact output data from JSON file?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1708026765,
                "post_id": 78003589,
                "comment_id": 137516262,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9080709,
                    "reputation": 382,
                    "user_id": 11043583,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Pe14cz7MVX0/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclDE38POj1LGm3xYztVZYg4G01KsA/s256-rj/photo.jpg",
                    "display_name": "amkgi",
                    "link": "https://stackoverflow.com/users/11043583/amkgi"
                },
                "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": 1708027393,
                "post_id": 78003589,
                "comment_id": 137516365,
                "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": 1708027892,
                "post_id": 78003589,
                "comment_id": 137516459,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9080709,
                    "reputation": 382,
                    "user_id": 11043583,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Pe14cz7MVX0/AAAAAAAAAAI/AAAAAAAAAAA/AMZuuclDE38POj1LGm3xYztVZYg4G01KsA/s256-rj/photo.jpg",
                    "display_name": "amkgi",
                    "link": "https://stackoverflow.com/users/11043583/amkgi"
                },
                "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": 1708028782,
                "post_id": 78003589,
                "comment_id": 137516601,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708028255,
                "last_edit_date": 1708028255,
                "creation_date": 1708027477,
                "answer_id": 78003662,
                "question_id": 78003589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach that sorts each `.thread_siblings` array, and then the array of all sibling arrays, transposes it to get all first numbers in one array, and all last ones in another, and joins both with a glue string:\r\n```sh\r\njq -r &#39;\r\n  [.numa_topology.cpus[] | select(.numa_node == 0).thread_siblings | sort]\r\n  | sort | transpose[] | join(&quot;, &quot;)\r\n&#39;\r\n```\r\n```csv\r\n0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19\r\n40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59\r\n```\r\n[Demo](https://jqplay.org/s/RvfMTT2FrPO)\r\n\r\n",
                "title": "Complex sorting and output by values in jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1708028629,
                "last_edit_date": 1708028629,
                "creation_date": 1708028100,
                "answer_id": 78003711,
                "question_id": 78003589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.numa_topology.cpus | map(\r\n  select(.numa_node == 0) .thread_siblings | sort\r\n) | sort | transpose[] | @csv\r\n```",
                "title": "Complex sorting and output by values in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1708029287,
                "creation_date": 1708029287,
                "answer_id": 78003789,
                "question_id": 78003589,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand correctly, here&#39;s another way to do it using `--raw-output`.\r\n```\r\n.numa_topology.cpus\r\n| map(select(.numa_node == 0).thread_siblings)\r\n| sort_by(min)\r\n| map(sort)\r\n| transpose | .[] | @csv\r\n```\r\nExample output:\r\n```\r\n0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19\r\n40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/DDlAD_-ZF47 &quot;Click me!&quot;).",
                "title": "Complex sorting and output by values in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1708029287,
        "creation_date": 1708026459,
        "last_edit_date": 1708026812,
        "question_id": 78003589,
        "body_markdown": "I&#39;m trying to get a human-readable representation of thread siblings.\r\n\r\nI have following output: [output][1].\r\n\r\n```\r\nundercloud) [stack@undercloud ~]$ os baremetal introspection data save compute0 |jq &#39;.numa_topology.cpus[] | select(.numa_node == 0) | .thread_siblings&#39;\r\n[\r\n  11,\r\n  51\r\n]\r\n[\r\n  9,\r\n  49\r\n]\r\n[\r\n  58,\r\n  18\r\n],\r\n\r\n....\r\n...\r\n..\r\n.\r\n\r\n(undercloud) [stack@undercloud ~]$\r\n```\r\nCommon View: [Common view.][2]\r\n\r\n```\r\n(undercloud) [stack@undercloud ~]$ os baremetal introspection data save compute0 | jq &#39;.numa_topology.cpus&#39;\r\n[\r\n  {\r\n    &quot;thread_siblings&quot;: [\r\n      11,\r\n      51\r\n    ],\r\n    &quot;cpu&quot;: 11,\r\n    &quot;numa_node&quot;: 0\r\n  },\r\n  {\r\n    &quot;thread_siblings&quot;: [\r\n      9,\r\n      49\r\n    ],\r\n    &quot;cpu&quot;: 9,\r\n    &quot;numa_node&quot;: 0\r\n  },\r\n  {\r\n    &quot;thread_siblings&quot;: [\r\n      58,\r\n      18\r\n    ],\r\n    &quot;cpu&quot;: 18,\r\n    &quot;numa_node&quot;: 0\r\n  },\r\n....\r\n...\r\n..\r\n.\r\n(undercloud) [stack@undercloud ~]$\r\n```\r\n\r\n\r\n\r\nI want to get next output:\r\n\r\n```\r\n0, 1, 2, 3, 4, ... etc\r\n40 41 42 43 44 ... etc\r\n```\r\n\r\nIs it possible to get such a list using `jq`? Perhaps with subsequent `awk/sed` processing.\r\n\r\nP.S.: *JSON moved to pastebin because the stackoverflow engine thinks my post has little detail and a lot of code, but I think I gave a pretty specific question and it doesn&#39;t fall into the XY problem.*\r\n\r\n  [1]: https://pastebin.com/vJVQSM6L\r\n  [2]: https://pastebin.com/qsvwkZyJ",
        "link": "https://stackoverflow.com/questions/78003589/complex-sorting-and-output-by-values-in-jq",
        "title": "Complex sorting and output by values in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708075280,
                "creation_date": 1708075280,
                "answer_id": 78006263,
                "question_id": 78005777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re losing reference if you cut too early, and still to get the value you need you&#39;d then have to iterate over `.members` again, find the right key, adjust the case again, etc.\r\n\r\nHere&#39;s a restructured version of your original attempt which just groups the members by containedness in the primary keys array, then assigns each section to to the right keys in the output object.\r\n\r\n```sh\r\n.body | . as {$primarykey} | .members\r\n| map(.value = (.type | ascii_downcase))\r\n| group_by(IN(.name; $primarykey[])) | map(from_entries)\r\n| {parameters: last, body: first}\r\n```\r\n```json\r\n{\r\n  &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;number&quot;\r\n  },\r\n  &quot;body&quot;: {\r\n    &quot;db_date&quot;: &quot;date&quot;,\r\n    &quot;db_timestamp&quot;: &quot;timestamp(6)&quot;,\r\n    &quot;db_timestamp_with_local_time_zone&quot;: &quot;timestamp(6) with local time zone&quot;,\r\n    &quot;db_char&quot;: &quot;char&quot;,\r\n    &quot;db_float&quot;: &quot;float&quot;,\r\n    &quot;db_nchar&quot;: &quot;nchar&quot;,\r\n    &quot;db_nvarchar2&quot;: &quot;nvarchar2&quot;,\r\n    &quot;db_varchar2&quot;: &quot;varchar2&quot;,\r\n    &quot;db_binary_float&quot;: &quot;binary_float&quot;,\r\n    &quot;db_binary_double&quot;: &quot;binary_double&quot;,\r\n    &quot;db_timestamp_with_time_zone&quot;: &quot;timestamp(6) with time zone&quot;,\r\n    &quot;db_interval_year_to_month&quot;: &quot;interval year(2) to month&quot;,\r\n    &quot;db_interval_day_to_second&quot;: &quot;interval day(2) to second(6)&quot;,\r\n    &quot;db_long&quot;: &quot;long&quot;,\r\n    &quot;db_blob&quot;: &quot;blob&quot;,\r\n    &quot;db_clob&quot;: &quot;clob&quot;,\r\n    &quot;db_boolean&quot;: &quot;char&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/sw5VuVYgGiA)",
                "title": "Unable to form correct JQ to get proper output from JSON data"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1708335903,
                "last_edit_date": 1708335903,
                "creation_date": 1708077698,
                "answer_id": 78006505,
                "question_id": 78005777,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For your first result :\r\n\r\n```\r\njq &#39;.body\r\n   |( .members | map(.value=(.type|ascii_downcase)) | from_entries ) as $mapping\r\n   |{parameters:(.primarykey | map({key:., value:$mapping[.]}) | from_entries)\r\n}&#39; input.json\r\n```\r\n\r\nthen second result :\r\n\r\n```\r\njq &#39;.body\r\n   |( .members | map(.value=(.type|ascii_downcase)) | from_entries ) as $mapping\r\n   |{parameters:(.primarykey | map({key:., value:$mapping[.]}) | from_entries),\r\n     body:$mapping\r\n}&#39; input.json\r\n```\r\n\r\n&lt;a href=&quot;https://jqplay.org/s/b7sHXWWwBLK&quot;&gt;jq-play&lt;/a&gt;",
                "title": "Unable to form correct JQ to get proper output from JSON data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708335903,
        "creation_date": 1708069126,
        "last_edit_date": 1708069794,
        "question_id": 78005777,
        "body_markdown": "I am using JQ Play.\r\n\r\nHere is my JSON Data -\r\n\r\n    {\r\n    &quot;body&quot;: {\r\n    &quot;name&quot;: &quot;DATATYPES&quot;,\r\n    &quot;primarykey&quot;: [\r\n      &quot;db_number&quot;\r\n    ],\r\n    &quot;members&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;db_number&quot;,\r\n        &quot;type&quot;: &quot;NUMBER&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_date&quot;,\r\n        &quot;type&quot;: &quot;DATE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6)&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp_with_local_time_zone&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6) WITH LOCAL TIME ZONE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_char&quot;,\r\n        &quot;type&quot;: &quot;CHAR&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_float&quot;,\r\n        &quot;type&quot;: &quot;FLOAT&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_nchar&quot;,\r\n        &quot;type&quot;: &quot;NCHAR&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_nvarchar2&quot;,\r\n        &quot;type&quot;: &quot;NVARCHAR2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_varchar2&quot;,\r\n        &quot;type&quot;: &quot;VARCHAR2&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_binary_float&quot;,\r\n        &quot;type&quot;: &quot;BINARY_FLOAT&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_binary_double&quot;,\r\n        &quot;type&quot;: &quot;BINARY_DOUBLE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_timestamp_with_time_zone&quot;,\r\n        &quot;type&quot;: &quot;TIMESTAMP(6) WITH TIME ZONE&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_interval_year_to_month&quot;,\r\n        &quot;type&quot;: &quot;INTERVAL YEAR(2) TO MONTH&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_interval_day_to_second&quot;,\r\n        &quot;type&quot;: &quot;INTERVAL DAY(2) TO SECOND(6)&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_long&quot;,\r\n        &quot;type&quot;: &quot;LONG&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_blob&quot;,\r\n        &quot;type&quot;: &quot;BLOB&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_clob&quot;,\r\n        &quot;type&quot;: &quot;CLOB&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;db_boolean&quot;,\r\n        &quot;type&quot;: &quot;CHAR&quot;\r\n      }\r\n      ],\r\n      &quot;links&quot;: [\r\n      {\r\n        &quot;rel&quot;: &quot;collection&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;canonical&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/datatypes/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;alternate&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/datatypes/&quot;,\r\n        &quot;mediaType&quot;: &quot;application/openapi+json&quot;\r\n      },\r\n      {\r\n        &quot;rel&quot;: &quot;describes&quot;,\r\n        &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/datatypes/&quot;\r\n      }\r\n      ]\r\n      }\r\n      }\r\n\r\n\r\nMy First JQ -\r\n\r\n    {&quot;parameters&quot;:([.body.primarykey[0]] | reduce .[] as $item ({}; .[$item] = &quot;&quot;))}\r\n\r\n\r\nOutput -\r\n\r\n    {\r\n    &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;&quot;\r\n    }\r\n    }\r\n\r\n\r\nHere, my requirement is - I want type of primary also in parameters in output by comparing it with matching record from members. \r\n\r\nMy expected output is -\r\n\r\n    {\r\n    &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;number&quot;\r\n    }\r\n    }\r\n\r\nPlease help me with correct JQ that will work in jqplay.org\r\n\r\n\r\nMy Second JQ -\r\n\r\n    .body.primarykey[] as $k | {  parameters: {($k): &quot;&quot; }, body: (.body.members | map( \r\n    select(.name != $k) | {(.name): .type |ascii_downcase}) | add)}\r\n\r\n\r\nHere, my requirement is - I want same parameters as above with type of primarykey along with body which eliminates matching primarykey from body.\r\n\r\nMy expected output is -\r\n\r\n    {\r\n    &quot;parameters&quot;: {\r\n    &quot;db_number&quot;: &quot;number&quot;\r\n    },\r\n    &quot;body&quot;: {\r\n    &quot;db_date&quot;: &quot;date&quot;,\r\n    &quot;db_timestamp&quot;: &quot;timestamp(6)&quot;,\r\n    &quot;db_timestamp_with_local_time_zone&quot;: &quot;timestamp(6) with local time zone&quot;,\r\n    &quot;db_char&quot;: &quot;char&quot;,\r\n    &quot;db_float&quot;: &quot;float&quot;,\r\n    &quot;db_nchar&quot;: &quot;nchar&quot;,\r\n    &quot;db_nvarchar2&quot;: &quot;nvarchar2&quot;,\r\n    &quot;db_varchar2&quot;: &quot;varchar2&quot;,\r\n    &quot;db_binary_float&quot;: &quot;binary_float&quot;,\r\n    &quot;db_binary_double&quot;: &quot;binary_double&quot;,\r\n    &quot;db_timestamp_with_time_zone&quot;: &quot;timestamp(6) with time zone&quot;,\r\n    &quot;db_interval_year_to_month&quot;: &quot;interval year(2) to month&quot;,\r\n    &quot;db_interval_day_to_second&quot;: &quot;interval day(2) to second(6)&quot;,\r\n    &quot;db_long&quot;: &quot;long&quot;,\r\n    &quot;db_blob&quot;: &quot;blob&quot;,\r\n    &quot;db_clob&quot;: &quot;clob&quot;,\r\n    &quot;db_boolean&quot;: &quot;char&quot;\r\n    }\r\n    }\r\n\r\nPlease help me with correct JQ that will work in jqplay.org",
        "link": "https://stackoverflow.com/questions/78005777/unable-to-form-correct-jq-to-get-proper-output-from-json-data",
        "title": "Unable to form correct JQ to get proper output from JSON data"
    },
    {
        "tags": [
            "python",
            "json",
            "continuous-integration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352124,
                "post_id": 78021300,
                "comment_id": 137546720,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "reply_to_user": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1708352214,
                "post_id": 78021300,
                "comment_id": 137546733,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352301,
                "post_id": 78021300,
                "comment_id": 137546752,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3353,
                    "reputation": 39479,
                    "user_id": 4834,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/6a04e124482c3750617f8dacde3388ce?s=256&d=identicon&r=PG",
                    "display_name": "quamrana",
                    "link": "https://stackoverflow.com/users/4834/quamrana"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1708352409,
                "post_id": 78021300,
                "comment_id": 137546777,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352482,
                "post_id": 78021300,
                "comment_id": 137546791,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352529,
                "post_id": 78021300,
                "comment_id": 137546807,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 76368,
                    "reputation": 13537,
                    "user_id": 218663,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6694b1d1fbbd6ce3cd15099363a057bd?s=256&d=identicon&r=PG",
                    "display_name": "JonSG",
                    "link": "https://stackoverflow.com/users/218663/jonsg"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1708352531,
                "post_id": 78021300,
                "comment_id": 137546809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352532,
                "post_id": 78021300,
                "comment_id": 137546810,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "reply_to_user": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1708352599,
                "post_id": 78021300,
                "comment_id": 137546820,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "reply_to_user": {
                    "account_id": 76368,
                    "reputation": 13537,
                    "user_id": 218663,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6694b1d1fbbd6ce3cd15099363a057bd?s=256&d=identicon&r=PG",
                    "display_name": "JonSG",
                    "link": "https://stackoverflow.com/users/218663/jonsg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352669,
                "post_id": 78021300,
                "comment_id": 137546836,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3353,
                    "reputation": 39479,
                    "user_id": 4834,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/6a04e124482c3750617f8dacde3388ce?s=256&d=identicon&r=PG",
                    "display_name": "quamrana",
                    "link": "https://stackoverflow.com/users/4834/quamrana"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352728,
                "post_id": 78021300,
                "comment_id": 137546848,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352753,
                "post_id": 78021300,
                "comment_id": 137546855,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user22990699"
                },
                "reply_to_user": {
                    "account_id": 23535348,
                    "reputation": 28660,
                    "user_id": 17580381,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kEvYxtLb.png?s=256",
                    "display_name": "Ramrab",
                    "link": "https://stackoverflow.com/users/17580381/ramrab"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352869,
                "post_id": 78021300,
                "comment_id": 137546877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708352980,
                "post_id": 78021300,
                "comment_id": 137546892,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708353308,
                "post_id": 78021300,
                "comment_id": 137546949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708383191,
                "last_edit_date": 1708383191,
                "creation_date": 1708352683,
                "answer_id": 78021380,
                "question_id": 78021300,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there a way to do this with an json parsers like `jq`\r\n\r\nYou can use jq&#39;s stream representation, which can be called either via the `--stream` flag or via the `tostream` function. The difference is that for the function, the input has already been parsed (and duplicate keys collapsed), whereas using the flag would start streaming while reading the input, thus before any collapsing could occur. So, being in bash, for example, just compare the output of both, e.g. using `diff`:\r\n\r\n```sh\r\n$ diff -q &lt;(jq --stream . nodupkeys.json) &lt;(jq tostream nodupkeys.json)\r\n# no output\r\n```\r\n\r\n```sh\r\n$ diff -q &lt;(jq --stream . withdupkeys.json) &lt;(jq tostream withdupkeys.json)\r\nFiles /dev/fd/63 and /dev/fd/62 differ\r\n```\r\n\r\n---\r\nAddressing @peak&#39;s [comment](https://stackoverflow.com/questions/78021300#comment137547244_78021380): The approach above would fail if using [itchyny/gojq](https://github.com/itchyny/gojq) instead of [jqlang/jq](https://github.com/jqlang/jq), as it automatically sorts the keys, but only after parsing the input (which is encountered when using the function, but not when using the flag), so for a document with unordered keys but without duplicates, it would still yield a difference.\r\n\r\nThe following (shell-free) approach tries to mitigate this by instead collecting all paths provided by the flag variant into an array, and then comparing its `sort`ed version with its `unique`d version (which is also automatically sorted), rendering irrelevant a potential sorting performed by the employed processor&#39;s implementation.\r\n\r\n```sh\r\n$ jq --stream -n &#39;[inputs[-2] | arrays] | sort == unique&#39; nodupkeys.json\r\ntrue\r\n```\r\n\r\n```sh\r\n$ jq --stream -n &#39;[inputs[-2] | arrays] | sort == unique&#39; withdupkeys.json\r\nfalse\r\n```\r\n\r\n---\r\n\r\nAddressing the discussion over duplicate keys being valid JSON or not:\r\n\r\nFrom [ECMA-404: The JSON Data Interchange Standard](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf) (December 2017), section 6 &quot;Objects&quot;:\r\n&gt; An object structure is represented as […] name/value pairs. A name is a *string*. […] The JSON syntax does not impose any restrictions on the *strings* used as names, does not require that name *strings* be unique, and does not assign any significance to the ordering of name/value pairs. These are all semantic considerations that may be defined by JSON processors […].\r\n\r\nAnd from section 2 &quot;Conformance&quot;:\r\n&gt; A conforming processor of JSON texts should not accept any inputs that are not conforming JSON texts. A conforming processor may impose semantic restrictions that limit the set of conforming JSON texts that it will process.\r\n\r\nThus, from a purely syntactical standopint (i.e. regarding the grammar, which is what these specs are all about), it is totally valid to have duplicate keys. As for the semantical side, though, (i.e. regarding the information conveyed according to a processor), processors are explicitly still &quot;conforming&quot; if they impose restrictions such as disallowing duplicate keys.\r\n\r\nMeanwhile, [RFC 8259: The JavaScript Object Notation (JSON) Data Interchange Format](https://datatracker.ietf.org/doc/html/rfc8259) (also December 2017) is a little more recommending. It even states in section 1.2 &quot;Specifications of JSON&quot;:\r\n\r\n&gt; Note, however, that ECMA-404 allows several practices that this specification recommends avoiding in the interests of maximal interoperability.\r\n\r\nAnd, in fact, in section 4 &quot;Objects&quot;, it essentially delivers the same message while explicitly advocating for the uniqueness of keys (using &quot;SHOULD&quot; as defined in [RFC 2119](https://datatracker.ietf.org/doc/html/rfc2119): &quot;This word […] mean[s] that there may exist valid reasons in particular circumstances to ignore a particular item, but the full implications must be understood and carefully weighed before choosing a different course.&quot;):\r\n\r\n&gt; An object structure is represented as […] name/value pairs (or members). A name is a string. […] The names within an object SHOULD be unique. […] When the names within an object are not unique, the behavior of software that receives such an object is unpredictable. Many implementations report the last name/value pair only. Other implementations report an error or fail to parse the object, and some implementations report all of the name/value pairs, including duplicates.\r\n\r\nVirtually all production-ready JSON processors I have played around with opted against refusing to parse a document containing duplicate keys, but at the same time they all performed some sort of collapsing to effectively make the keys unique.\r\n\r\nSo, in conclusion: duplicate keys are valid, but it has practical benefits to avoid, or at least not to rely on them. In this light, it makes perfect sense for the OP to find a way to spot them.\r\n\r\n\r\n",
                "title": "Check for duplicate keys in a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708383191,
        "creation_date": 1708352002,
        "question_id": 78021300,
        "body_markdown": "I have a json file with the following contents:\r\n\r\n```json\r\n{\r\n    &quot;id1&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n    },\r\n    &quot;id2&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n    }\r\n}\r\n```\r\n\r\nI want to check that each top level key ie. `id1, id2` is present only once in a file and if not produce an error. So something like\r\n\r\n```json\r\n{\r\n    &quot;id1&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n    },\r\n    &quot;id1&quot;: {\r\n        &quot;key&quot;: &quot;value&quot;\r\n    }\r\n}\r\n```\r\n\r\nmust show as error.\r\n\r\nIs there a way to do this with an json parsers like `jq` or `json-glib-validate`? \r\n\r\nI came up with a pythonic solution, that works, but would be nicer to have an actual parser.\r\n\r\nThis is supposed to be used in CI.\r\n\r\n```python\r\nimport collections\r\nimport json\r\nimport sys\r\n\r\ndef check_duplicates(pairs):\r\n    count = collections.Counter(i for i,j in pairs)\r\n    duplicates = &quot;, &quot;.join(i for i,j in count.items() if j&gt;1)\r\n\r\n    if len(duplicates) != 0:\r\n        print(&quot;Duplicate keys found: {}&quot;.format(duplicates))\r\n        sys.exit(1)\r\n\r\ndef validate(pairs):\r\n    check_duplicates(pairs)\r\n    return dict(pairs)\r\n\r\nwith open(&quot;file.json&quot;, &quot;r&quot;) as file:\r\n    try:\r\n        obj = json.load(file, object_pairs_hook=validate)\r\n    except ValueError as e:\r\n        print(&quot;Invalid json: %s&quot; % e)\r\n        sys.exit(1)\r\n```",
        "link": "https://stackoverflow.com/questions/78021300/check-for-duplicate-keys-in-a-json-file",
        "title": "Check for duplicate keys in a json file"
    },
    {
        "tags": [
            "json",
            "shell",
            "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": 1,
                "creation_date": 1708354839,
                "post_id": 78021543,
                "comment_id": 137547194,
                "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"
                },
                "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": 1708354972,
                "post_id": 78021543,
                "comment_id": 137547223,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1708355140,
        "creation_date": 1708354400,
        "question_id": 78021543,
        "body_markdown": "In my shell script, I&#39;m reading a JSON array from a file. Then I&#39;m looping over the array and send a POST request with each item from the array as json payload;\r\n\r\n`data.json`\r\n```json\r\n[\r\n  {\r\n    &quot;orderId&quot;: &quot;abc111&quot;,\r\n    &quot;amount&quot;: 2,\r\n    &quot;name&quot;: &quot;item 1&quot;\r\n  },\r\n  {\r\n    &quot;orderId&quot;: &quot;abc222&quot;,\r\n    &quot;amount&quot;: 5,\r\n    &quot;name&quot;: &quot;item 2&quot;\r\n  }\r\n]\r\n```\r\n\r\ntried like this;\r\n\r\n```sh\r\njq -c &#39;.[]&#39; ./data.json | while read i; do    \r\n    curl --location &#39;http://localhost:8080/endpoint&#39; \\\r\n    --header &#39;Authorization: Bearer xxx&#39; \\\r\n    --json $i\r\ndone\r\n```\r\n\r\nunfortunately getting this error\r\n\r\n```sh\r\n{&quot;message&quot;:{&quot;statusCode&quot;:400,&quot;message&quot;:&quot;Unexpected end of JSON input&quot;,&quot;error&quot;:&quot;Bad Request&quot;},&quot;status&quot;:400}\r\n\r\n{&quot;message&quot;:{&quot;statusCode&quot;:400,&quot;message&quot;:&quot;Unexpected end of JSON input&quot;,&quot;error&quot;:&quot;Bad Request&quot;},&quot;status&quot;:400}\r\n\r\n```\r\n\r\nhowever, this works nicely;\r\n\r\n```sh\r\ncurl --location &#39;http://localhost:8080/endpoint&#39; \\\r\n     --header &#39;Authorization: Bearer xxx&#39; \\ \r\n     --json &#39;{\r\n               &quot;orderId&quot;:&quot;abc111&quot;,\r\n               &quot;amount&quot;:2,\r\n               &quot;name&quot;: &quot;item 1&quot;\r\n       }&#39;\r\n```\r\n\r\nhow can I use JSON object in the loop to send as POST payload with CURL?",
        "link": "https://stackoverflow.com/questions/78021543/json-payload-in-shell-script-using-curl",
        "title": "JSON payload in shell script using CURL"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq",
            "jsonparser"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708421286,
                "creation_date": 1708421286,
                "answer_id": 78026107,
                "question_id": 78026070,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your snippet is the full file, it is missing an array around all the entries.\r\nA JSON file has to contain one &quot;element&quot; at &quot;root&quot;, this can be either an object (`{...}`) or an array (`[...]`).\r\n\r\nIn your case the JSON consists of multiple objects, so you have to wrap them in an array. Try to insert `[` at the beginning of the file and `]` at the very end, don&#39;t change anything else.\r\n\r\nThen try your call to jq again.",
                "title": "jq - Cannot index string with string &quot;key&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1708421286,
        "creation_date": 1708420934,
        "question_id": 78026070,
        "body_markdown": "I have a JSON file, which contains similar records like following:\r\n\r\n      {\r\n        &quot;timeZone&quot;: &quot;+0200&quot;,\r\n        &quot;deviceCode&quot;: 202590286,\r\n        &quot;type&quot;: 8,\r\n        &quot;version&quot;: 1622385523034,\r\n        &quot;recordId&quot;: &quot;TkgTDAAAAAAIAAAArF62vXkBAAA=&quot;,\r\n        &quot;dataId&quot;: 0,\r\n        &quot;healthDataSource&quot;: 0,\r\n        &quot;appType&quot;: 1,\r\n        &quot;startTime&quot;: 1622385516204,\r\n        &quot;endTime&quot;: 1622385516204,\r\n        &quot;samplePoints&quot;: [\r\n          {\r\n            &quot;mergedFlag&quot;: 0,\r\n            &quot;unit&quot;: &quot;0&quot;,\r\n            &quot;startTime&quot;: 1622385516204,\r\n            &quot;endTime&quot;: 1622385516204,\r\n            &quot;value&quot;: &quot;{\\&quot;age\\&quot;:29,\\&quot;basalMetabolism\\&quot;:2266.0,\\&quot;bmi\\&quot;:34.0,\\&quot;bodyAge\\&quot;:38,\\&quot;bodyFatRate\\&quot;:33.20000076293945,\\&quot;bodyScore\\&quot;:67.0,\\&quot;bodySize\\&quot;:5,\\&quot;bodyWeight\\&quot;:115.19999694824219,\\&quot;boneSalt\\&quot;:3.989405632019043,\\&quot;extendAttribute\\&quot;:\\&quot;0\\&quot;,\\&quot;gender\\&quot;:1,\\&quot;heartRate\\&quot;:84,\\&quot;height\\&quot;:184,\\&quot;moisture\\&quot;:51.61684036254883,\\&quot;moistureRate\\&quot;:44.8062858581543,\\&quot;muscleMass\\&quot;:72.9608154296875,\\&quot;pole\\&quot;:1,\\&quot;proteinRate\\&quot;:21.34735107421875,\\&quot;skeletalMusclelMass\\&quot;:42.30829620361328,\\&quot;visceralFatLevel\\&quot;:20.0}&quot;,\r\n            &quot;key&quot;: &quot;WEIGHT_BODYFAT_BROAD&quot;\r\n          }\r\n        ]\r\n      },\r\n     {\r\n        &quot;timeZone&quot;: &quot;+0200&quot;,\r\n        &quot;deviceCode&quot;: 202576998,\r\n        &quot;type&quot;: 7,\r\n        &quot;version&quot;: 1622408526036,\r\n        &quot;recordId&quot;: &quot;ZhQTDAAAAAAHAAAAIAvJvXkBAAA=&quot;,\r\n        &quot;dataId&quot;: 0,\r\n        &quot;healthDataSource&quot;: 0,\r\n        &quot;appType&quot;: 1,\r\n        &quot;startTime&quot;: 1622386740000,\r\n        &quot;endTime&quot;: 1622386800000,\r\n        &quot;samplePoints&quot;: [\r\n          {\r\n            &quot;mergedFlag&quot;: 0,\r\n            &quot;unit&quot;: &quot;0&quot;,\r\n            &quot;startTime&quot;: 1622386740000,\r\n            &quot;endTime&quot;: 1622386800000,\r\n            &quot;value&quot;: &quot;78.0&quot;,\r\n            &quot;key&quot;: &quot;DATA_POINT_DYNAMIC_HEARTRATE&quot;\r\n          }\r\n        ]\r\n      },\r\n     {\r\n        &quot;timeZone&quot;: &quot;+0800&quot;,\r\n        &quot;deviceCode&quot;: 202590286,\r\n        &quot;type&quot;: 8,\r\n        &quot;version&quot;: 1622615424878,\r\n        &quot;recordId&quot;: &quot;TkgTDAAAAAAIAAAAAHxqy3kBAAA=&quot;,\r\n        &quot;dataId&quot;: 0,\r\n        &quot;healthDataSource&quot;: 0,\r\n        &quot;appType&quot;: 1,\r\n        &quot;startTime&quot;: 1622615424000,\r\n        &quot;endTime&quot;: 1622615424000,\r\n        &quot;samplePoints&quot;: [\r\n          {\r\n            &quot;mergedFlag&quot;: 0,\r\n            &quot;startTime&quot;: 1622615424000,\r\n            &quot;endTime&quot;: 1622615424000,\r\n            &quot;value&quot;: &quot;{\\&quot;age\\&quot;:29,\\&quot;bodyWeight\\&quot;:114.3,\\&quot;extendAttribute\\&quot;:\\&quot;0\\&quot;,\\&quot;gender\\&quot;:1,\\&quot;height\\&quot;:184,\\&quot;pole\\&quot;:1,\\&quot;weightDivision\\&quot;:2}&quot;,\r\n            &quot;key&quot;: &quot;WEIGHT_BODYFAT_BROAD&quot;\r\n          }\r\n        ]\r\n      },\r\n\r\nI try to [use][1] `map(select(.key == &quot;WEIGHT_BODYFAT_BROAD&quot;))` to filter this type of records, but got error message.\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:22): Cannot index string with string &quot;key&quot; jq:\r\n&gt; parse error: Expected value before &#39;,&#39; at line 22, column 4 exit\r\n&gt; status 5\r\n\r\n  [1]: https://jqplay.org/s/LcrQI21opfy",
        "link": "https://stackoverflow.com/questions/78026070/jq-cannot-index-string-with-string-key",
        "title": "jq - Cannot index string with string &quot;key&quot;"
    },
    {
        "tags": [
            "json",
            "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": 2,
                "creation_date": 1708437690,
                "post_id": 78027649,
                "comment_id": 137558228,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "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": 1708440254,
                "post_id": 78027649,
                "comment_id": 137558770,
                "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": 1708442675,
                "post_id": 78027649,
                "comment_id": 137559266,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "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": 1708493173,
                "post_id": 78027649,
                "comment_id": 137565326,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "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": 1708495539,
                "post_id": 78027649,
                "comment_id": 137565510,
                "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": 1708497208,
                "post_id": 78027649,
                "comment_id": 137565712,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "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": 1708507051,
                "post_id": 78027649,
                "comment_id": 137567199,
                "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": 1708507152,
                "post_id": 78027649,
                "comment_id": 137567221,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "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": 1708508554,
                "post_id": 78027649,
                "comment_id": 137567460,
                "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": 1708509244,
                "post_id": 78027649,
                "comment_id": 137567579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1708511058,
                "last_edit_date": 1708511058,
                "creation_date": 1708439110,
                "answer_id": 78028117,
                "question_id": 78027649,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To produce the output as requested in the initial version of this question, i.e. multiple lines, each key quoted and enclosed in curly braces:\r\n\r\n```\r\n{&quot;book_id&quot;},\r\n{&quot;edition_id&quot;}\r\n```\r\n\r\nyou can run the following jq command (with raw output):\r\n\r\n```\r\njq -r &#39;.body.primarykey | map(&quot;{\\&quot;\\(.)\\&quot;}&quot;) | join(&quot;,\\n&quot;)&#39;\r\n```\r\n\r\n*****\r\n\r\nTo produce the new output after the question was edited, i.e. a single quoted line, each key enclosed in curly braces:\r\n\r\n```\r\n&quot;{book_id},{edition_id}&quot;\r\n```\r\n\r\nyou can run:\r\n\r\n```\r\njq &#39;.body.primarykey | map(&quot;{\\(.)}&quot;) | join(&quot;,&quot;)&#39;\r\n```\r\n\r\n*****\r\n\r\nTo produce the output of the third installment of the question, use the same command as for the first version, but join only with `,` and without a line break:\r\n\r\n```\r\njq -r &#39;.body.primarykey | map(&quot;{\\&quot;\\(.)\\&quot;}&quot;) | join(&quot;,&quot;)&#39;\r\n```\r\n\r\nThis will output a single line, each key quoted and enclosed in curly braces; and multiple keys separated by a comma:\r\n\r\n```\r\n{&quot;book_id&quot;},{&quot;edition_id&quot;}\r\n```\r\n\r\n****\r\n\r\nPlease note that neither output is valid JSON, and as such cannot be further processed with jq.",
                "title": "Unable to form JQ as per requirement"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1708511058,
        "creation_date": 1708435052,
        "last_edit_date": 1708508436,
        "question_id": 78027649,
        "body_markdown": "I am using JQ Play.\r\n\r\nHere is my JSON Data -\r\n\r\n    {\r\n    &quot;body&quot;:{\r\n    &quot;primarykey&quot;: [\r\n        &quot;book_id&quot;,\r\n        &quot;edition_id&quot;\r\n    ],\r\n    &quot;members&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;book_id&quot;,\r\n            &quot;type&quot;: &quot;NUMBER&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;edition_id&quot;,\r\n            &quot;type&quot;: &quot;NUMBER&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;title&quot;,\r\n            &quot;type&quot;: &quot;VARCHAR2&quot;\r\n        }\r\n    ],\r\n    &quot;links&quot;: [\r\n        {\r\n            &quot;rel&quot;: &quot;collection&quot;,\r\n            &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/&quot;,\r\n            &quot;mediaType&quot;: &quot;application/json&quot;\r\n        },\r\n        {\r\n            &quot;rel&quot;: &quot;canonical&quot;,\r\n            &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/books/&quot;,\r\n            &quot;mediaType&quot;: &quot;application/json&quot;\r\n        },\r\n        {\r\n            &quot;rel&quot;: &quot;alternate&quot;,\r\n            &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/books/&quot;,\r\n            &quot;mediaType&quot;: &quot;application/openapi+json&quot;\r\n        },\r\n        {\r\n            &quot;rel&quot;: &quot;describes&quot;,\r\n            &quot;href&quot;: &quot;https://tdcvm28s16.bcone.com:7002/ords/testords/books/&quot;\r\n        }\r\n    ]\r\n    }\r\n    }\r\n\r\nMy JQ -\r\n\r\n    .body.primarykey[] | &quot;{&quot; + . + &quot;}&quot;\r\n\r\n\r\nCurrent Output - \r\n\r\n    &quot;{book_id}&quot;\r\n    &quot;{edition_id}&quot;\r\n    \r\n\r\nMy expected output is -\r\n\r\n    {&quot;book_id&quot;},{&quot;edition_id&quot;}\r\n\r\n\r\nHere if there are more primary keys, they should also get appended in expected output.\r\n\r\nPlease help me with correct JQ that will work in jqplay.org",
        "link": "https://stackoverflow.com/questions/78027649/unable-to-form-jq-as-per-requirement",
        "title": "Unable to form JQ as per requirement"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq",
            "tee"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1708445030,
                "creation_date": 1708445030,
                "answer_id": 78028772,
                "question_id": 78028685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The second `jq` should read from the standard output of `tee`, then write to standard output. This entire pipeline is then put in another process substitution for `read` to read from.\r\n\r\n    read next_token &lt;( curl -u &quot;$user:$password&quot; &quot;https://mylink.dot&quot; |\r\n                         tee &gt;(jq -r &#39;.dataSummaries[] | .dataId&#39; &gt;&gt; my_data_file.txt ) |\r\n                         jq -r &#39;.nextToken&#39;)",
                "title": "Redirect tee output to the variable instead of file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708446365,
                "last_edit_date": 1708446365,
                "creation_date": 1708445883,
                "answer_id": 78028858,
                "question_id": 78028685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m planning to use this mechanism to get both values as variable. \r\n\r\n```\r\nread var1 var2 &lt;&lt;&lt;$(curl -u &quot;$user:$password&quot; &quot;https://mylink.dot&quot; | tee &gt;(jq -r &#39;.dataSummaries[] | .dataId&#39;) &gt;(jq -r &#39;.nextToken&#39;) &gt; /dev/null)\r\n```\r\n",
                "title": "Redirect tee output to the variable instead of file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708446486,
        "creation_date": 1708444314,
        "last_edit_date": 1708446486,
        "question_id": 78028685,
        "body_markdown": "I&#39;m trying to do the loop where output of each curl command which is returning json data is allocated to the variable/array. I&#39;m using tee command to get my wanted value plus next token for next json piece of data. When I save data to file everything works fine but instead of saving data to file I would like to keep it in array/variable. \r\n\r\nThis works: \r\n\r\n```\r\nwhile  [[ &quot;$next_token&quot; != &quot;null&quot; ]]\r\n\r\ndo\r\n\r\ncurl -u &quot;$user:$password&quot; &quot;https://mylink.dot&quot; \\\r\n    | tee &gt;(jq -r &#39;.dataSummaries[] | .dataId&#39; &gt;&gt; my_data_file.txt ) \\\r\n    &gt;(jq -r &#39;.nextToken&#39;&gt;next_token_file.txt) &gt; /dev/null\r\n\r\nnext_token=$(cat next_token_file.txt)\r\n\r\ndone\r\n```\r\n\r\nI tried this:\r\n\r\n```\r\nwhile  [[ &quot;$next_token&quot; != &quot;null&quot; ]]\r\n\r\ndo\r\nindex=$((index+1))\r\n\r\ncurl -u &quot;$user:$password&quot; &quot;https://mylink.dot&quot; | tee &gt;(jq -r &#39;.dataSummaries[] | .dataId&#39; | read my_array[index] ) &gt;(jq -r &#39;.nextToken&#39;&gt;next_token_file.txt) &gt; /dev/null\r\n\r\nnext_token=$(cat next_token_file.txt)\r\n\r\ndone\r\n```\r\n\r\nWhen I use ``` |read var ``` my variable is empty. \r\n\r\nHow in this case can I store json data (and next token) in variable, not file. \r\n",
        "link": "https://stackoverflow.com/questions/78028685/redirect-tee-output-to-the-variable-instead-of-file",
        "title": "Redirect tee output to the variable instead of file"
    },
    {
        "tags": [
            "arrays",
            "dictionary",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708479817,
                "post_id": 78031134,
                "comment_id": 137564353,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14411192,
                    "reputation": 13,
                    "user_id": 23135452,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocIHc_kol5FlUL8ETNlxA9v07R703EV3WDPk8bhOeE0k=k-s256",
                    "display_name": "esefe sgrgrz",
                    "link": "https://stackoverflow.com/users/23135452/esefe-sgrgrz"
                },
                "reply_to_user": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708515156,
                "post_id": 78031134,
                "comment_id": 137568605,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 91548,
                    "reputation": 255795,
                    "user_id": 251311,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/b6b0ca5d4ef200ec8e3cd1fa2aefd836?s=256&d=identicon&r=PG",
                    "display_name": "zerkms",
                    "link": "https://stackoverflow.com/users/251311/zerkms"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1708550974,
                "post_id": 78031134,
                "comment_id": 137574709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1708481550,
                "creation_date": 1708481550,
                "answer_id": 78031226,
                "question_id": 78031134,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Without more sample data, it&#39;s hard to test, but something like this should fit your needs:\r\n```sh\r\ncurl … | jq -r &#39;.res.out[].server | .host, .description&#39; |\r\nwhile read -r host; read -r desc; do\r\n  printf &#39;HOST: %s\\nDescription: %s\\n&#39; &quot;$host&quot; &quot;$desc&quot;\r\n  curl … | jq …\r\ndone\r\n```",
                "title": "jq curl contain output of two curl"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1708508028,
        "creation_date": 1708479395,
        "last_edit_date": 1708508028,
        "question_id": 78031134,
        "body_markdown": "I use curl to have this answer :\r\n```\r\ncurl -sX https://xx.com | jq -r &#39;.res.out[].server // empty | {host: .host, description: .description}&#39;\r\n```\r\n\r\n```\r\n{ &quot;host&quot;: &quot;server1&quot;,\r\n  &quot;description&quot;: &quot;server 1&quot;\r\n}\r\n{ &quot;host&quot;: &quot;server2&quot;,\r\n  &quot;description&quot;: &quot;server 2&quot;\r\n}\r\n{ &quot;host&quot;: &quot;server3&quot;,\r\n  &quot;description&quot;: &quot;server 3&quot;\r\n}\r\n```\r\n\r\nAnd I use a second curl to get the state of serveur if it is running or not. on second curl I need the name of host to get the state of server which I get on first curl, and I want to add also the description of server.\r\n\r\nSo, I would like to store the list of host and description on a map, to use on second curl\r\n\r\n```\r\nfor host in ${array_host[@]}; do \r\n  echo &quot;HOST: $host&quot;;\r\n  echo &quot;Description: $description&quot;\r\n  curl -sX https://xx.com/servers/$host | jq -r &#39;.specInfo.resul.out[].server.operationalStatus //empty&#39;;\r\ndone\r\n```\r\n\r\nbecause on second curl, I have to loop on all server to get the state, for instance :\r\n\r\n    curl -sX https://xx.com/servers/server1 | jq -r &#39;.specInfo.resul.out[].server.operationalStatus //empty&#39;;\r\n    RUNNING\r\n    curl -sX https://xx.com/servers/server2 | jq -r &#39;.specInfo.resul.out[].server.operationalStatus //empty&#39;;\r\n    RUNNING\r\n    curl -sX https://xx.com/servers/server3 | jq -r &#39;.specInfo.resul.out[].server.operationalStatus //empty&#39;;\r\n    NOT RUNNING\r\n\r\n\r\nI expect somethink like that\r\n\r\n    HOST: Server1\r\n    Description: Server 1\r\n    RUNNING\r\n    HOST: Server2\r\n    Description: Server 2\r\n    RUNNING\r\n    HOST: Server3\r\n    Description: Server 3\r\n    NOT RUNNING",
        "link": "https://stackoverflow.com/questions/78031134/jq-curl-contain-output-of-two-curl",
        "title": "jq curl contain output of two curl"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "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": 1708550585,
                "post_id": 78035762,
                "comment_id": 137574674,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708534805,
                "creation_date": 1708534805,
                "answer_id": 78035792,
                "question_id": 78035762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over all items using [`.[]`](https://jqlang.github.io/jq/manual/#array-object-value-iterator), and use [`select`](https://jqlang.github.io/jq/manual/#select) and [`has`](https://jqlang.github.io/jq/manual/#has) to filter for the right ones:\r\n```sh\r\njq &#39;(.zoo[] | select(has(&quot;x&quot;))).x.guesst = (.zoo[] | select(has(&quot;y&quot;))).y.guesst&#39;\r\n```\r\n[Demo](https://jqplay.org/s/WxWQA7iFCfR)",
                "title": "How to copy from object with out using the table index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1708564505,
        "creation_date": 1708534571,
        "last_edit_date": 1708564505,
        "question_id": 78035762,
        "body_markdown": "The input is\r\n\r\n    {\r\n    &quot;zoo&quot;: [\r\n       { &quot;x&quot;: { &quot;guesst&quot;: &quot;&quot; } },\r\n       { &quot;y&quot;: { &quot;guesst&quot;: &quot;zebra&quot; } }\r\n      ]\r\n    }\r\n\r\nAnd i need the output like\r\n\r\n    {\r\n    &quot;zoo&quot;: [\r\n       { &quot;x&quot;: { &quot;guesst&quot;: &quot;zebra&quot; } },\r\n       { &quot;y&quot;: { &quot;guesst&quot;: &quot;zebra&quot; } }\r\n      ]\r\n    }\r\n\r\nI did: \r\n\r\n    jq &#39;.zoo[0].x.guesst = .zoo[1].y.guesst&#39;\r\n\r\nBut, what if i do not know the order of the objects in the array?\r\n",
        "link": "https://stackoverflow.com/questions/78035762/how-to-copy-from-object-with-out-using-the-table-index",
        "title": "How to copy from object with out using the table index"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1708596097,
                "creation_date": 1708596097,
                "answer_id": 78040008,
                "question_id": 78039985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Again](https://stackoverflow.com/a/78035792/2158479), iterate over all items using [`.[]`](https://jqlang.github.io/jq/manual/#array-object-value-iterator), and use [`select`](https://jqlang.github.io/jq/manual/#select) to filter for the right ones:\r\n\r\n```sh\r\n(.zoo[].gpu | select(.id == &quot;fish&quot;).sum) =\r\n(.zoo[].gpu | select(.id == &quot;zebra&quot;).sum)\r\n```\r\n[Demo](https://jqplay.org/s/KsfNh1wXpJ6)\r\n\r\n&gt; Actually, I need to do it be the field &quot;name&quot;.\r\n```sh\r\n(.zoo[] | select(.room.name == &quot;x&quot;).gpu.sum) =\r\n(.zoo[] | select(.room.name == &quot;y&quot;).gpu.sum)\r\n```\r\n[Demo](https://jqplay.org/s/2kkIfIklxqW)",
                "title": "How to copy field from nested object inside array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1708598076,
                "creation_date": 1708598076,
                "answer_id": 78040223,
                "question_id": 78039985,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A pedestrian but fairly robust solution would be:\r\n```\r\n(.zoo|first(.[]|select(.room.name==&quot;y&quot;).gpu.sum)//null) as $sum\r\n| if $sum\r\n  then .zoo |= map(if .room.name==&quot;x&quot; then .gpu.sum=$sum else . end)\r\n  else .\r\n  end\r\n```\r\n",
                "title": "How to copy field from nested object inside array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1708598076,
        "creation_date": 1708595892,
        "last_edit_date": 1708596175,
        "question_id": 78039985,
        "body_markdown": "My json input is:\r\n\r\n    {\r\n    &quot;zoo&quot;: [\r\n       { &quot;room&quot;: { &quot;name&quot;: &quot;x&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;fish&quot;,  &quot;sum&quot;: 0 } },\r\n       { &quot;room&quot;: { &quot;name&quot;: &quot;y&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;zebra&quot;, &quot;sum&quot;: 797 } }\r\n      ]\r\n    }\r\n\r\nI need to copy from zebra&#39;s sum into fish&#39;s sum. So, the output will be looked like:\r\n\r\n    {\r\n    &quot;zoo&quot;: [\r\n       { &quot;room&quot;: { &quot;name&quot;: &quot;x&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;fish&quot;,  &quot;sum&quot;: 797 } },\r\n       { &quot;room&quot;: { &quot;name&quot;: &quot;y&quot; }, &quot;gpu&quot;: { &quot;id&quot;: &quot;zebra&quot;, &quot;sum&quot;: 797 } }\r\n      ]\r\n    }\r\n\r\nBut, I could not know the order of the table, so, I could not use the tables index.  Actually, I need to do it be the field &quot;name&quot;.\r\n",
        "link": "https://stackoverflow.com/questions/78039985/how-to-copy-field-from-nested-object-inside-array",
        "title": "How to copy field from nested object inside array"
    }
]