[
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676629927,
                "post_id": 75483011,
                "comment_id": 133180172,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1676631225,
                "creation_date": 1676631225,
                "answer_id": 75483349,
                "question_id": 75483011,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `~/.jq` file contains jq code such as function definitions. It&#39;s not a config file in the classical sense.\r\n\r\nMost shells support aliases and you could set one yourself, e.g. in `~/.profile` or `~/.bashrc`/`~/.bash_aliases` with:\r\n\r\n```\r\nalias jq=&#39;jq --indent 4&#39;\r\n```\r\n\r\nWhen invoked in an interactive shell, the alias will be resolved to the command including the option. Note however that aliases are ignored in shell scripts (i.e. non-interactive mode) by default.",
                "title": "How to specify indent in jq config file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1676631225,
        "creation_date": 1676629472,
        "question_id": 75483011,
        "body_markdown": "Instead of always giving the `--indent n` flag on the command line, I would like to specify this in a config file (or library or module file – I&#39;m not sure what the correct terminology is).\r\n\r\nI tried putting various things in `~/.jq`, such as `indent: 4` or `--indent 4`, but they always gave me a compile error when I invoked `jq`.  I looked at the manual but couldn&#39;t see any information on how to do this, nor find anything in the issues on GitHub.\r\n\r\nIs it possible?",
        "link": "https://stackoverflow.com/questions/75483011/how-to-specify-indent-in-jq-config-file",
        "title": "How to specify indent in jq config file?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676646847,
                "post_id": 75486047,
                "comment_id": 133185078,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1031173,
                    "reputation": 1777,
                    "user_id": 1039462,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/e900d325da026737779c7e4fd790d3ab?s=256&d=identicon&r=PG",
                    "display_name": "mat",
                    "link": "https://stackoverflow.com/users/1039462/mat"
                },
                "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": 1676647761,
                "post_id": 75486047,
                "comment_id": 133185347,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1676648174,
                "creation_date": 1676648174,
                "answer_id": 75486311,
                "question_id": 75486047,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can&#39;t find a valid duplicate, so posting this as an answer.\r\n\r\n\r\n----------\r\n\r\nIf you use `-s` (slurp), you can use `object1 - object2` to get the difference between them:\r\n```\r\njq -s  &#39;.[0] - .[1]&#39; a b\r\n```\r\n\r\nWill output:\r\n```json\r\n[\r\n  {\r\n    &quot;key1&quot;: &quot;foo&quot;,\r\n    &quot;key2&quot;: &quot;baz&quot;\r\n  },\r\n  {\r\n    &quot;key1&quot;: &quot;bla&quot;,\r\n    &quot;key2&quot;: &quot;blubb&quot;\r\n  }\r\n]\r\n```",
                "title": "Finding all elements in a JSON dictionary which are not part of another dictionary with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1676648174,
        "creation_date": 1676646770,
        "last_edit_date": 1676647824,
        "question_id": 75486047,
        "body_markdown": "I have to JSON files.\r\n\r\n`a.json`:\r\n\r\n```json\r\n[ \r\n  { key1: &quot;foo&quot;, key2: &quot;bar&quot;},\r\n  { key1: &quot;foo&quot;, key2: &quot;baz&quot;},\r\n  { key1: &quot;bla&quot;, key2: &quot;blubb&quot;},\r\n]\r\n```\r\n\r\n`b.json`:\r\n\r\n```json\r\n[ \r\n  { key1: &quot;foo&quot;, key2: &quot;bar&quot;},\r\n  { key1: &quot;foo&quot;, key2: &quot;oof&quot;},\r\n  { key1: &quot;bla&quot;, key2: &quot;bla&quot;},\r\n]\r\n```\r\n\r\nMy desired result is an array containing all the entrise of the first dictionary which are not part of the second one (equivalent to what the DISTINCT operator would do in SQL). So the expected output would be:\r\n\r\n```json\r\n[ \r\n  { key1: &quot;foo&quot;, key2: &quot;baz&quot;},\r\n  { key1: &quot;bla&quot;, key2: &quot;blubb&quot;},\r\n]\r\n```\r\n\r\nHow can I achieve this using `jq`?",
        "link": "https://stackoverflow.com/questions/75486047/finding-all-elements-in-a-json-dictionary-which-are-not-part-of-another-dictiona",
        "title": "Finding all elements in a JSON dictionary which are not part of another dictionary with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1676649758,
                "last_edit_date": 1676649758,
                "creation_date": 1676649442,
                "answer_id": 75486550,
                "question_id": 75486489,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know the two column names anyway, you could simply extract them directly using `.name` and `.version`:\r\n```sh\r\n&lt;file jq -r &#39;[&quot;name&quot;, &quot;version&quot;], (.[] | [.name, .version]) | @csv&#39;\r\n```\r\nYou can also use your `$cols` variable, so the names only appear once:\r\n```sh\r\n&lt;file jq -r &#39;[&quot;name&quot;, &quot;version&quot;] as $cols | $cols, (.[] | [.[$cols[]]]) | @csv&#39;\r\n```\r\nOr import them dynamically, e.g. using `--args`:\r\n```sh\r\n&lt;file jq -r &#39;$ARGS.positional, (.[] | [.[$ARGS.positional[]]]) | @csv&#39; \\\r\n  --args name version\r\n```\r\n\r\nOutput:\r\n```\r\n&quot;name&quot;,&quot;version&quot;\r\n&quot;foo&quot;,&quot;1.24&quot;\r\n&quot;bar&quot;,&quot;1.21&quot;\r\n&quot;boo&quot;,&quot;1.23&quot;\r\n&quot;far&quot;,&quot;1.24&quot;\r\n```",
                "title": "How can I use jq to filter only certain fields of the original JSON into an CSV?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1676649758,
        "creation_date": 1676649094,
        "question_id": 75486489,
        "body_markdown": "I say [this stack overflow anser with a simple jq command to convert a JSON to a csv file](https://stackoverflow.com/a/32965227), but I need to improve it further.\r\n\r\nSay I have the following JSON:\r\n\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;foo&quot;,\r\n            &quot;env&quot;: &quot;dev&quot;,\r\n            &quot;version&quot;: &quot;1.24&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;bar&quot;,\r\n            &quot;env&quot;: &quot;staging&quot;,\r\n            &quot;version&quot;: &quot;1.21&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;boo&quot;,\r\n            &quot;env&quot;: &quot;prod&quot;,\r\n            &quot;version&quot;: &quot;1.23&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;far&quot;,\r\n            &quot;env&quot;: &quot;prod&quot;,\r\n            &quot;version&quot;: &quot;1.24&quot;\r\n        }\r\n    ]\r\n\r\nHow does one create the CSV with only the &quot;name&quot; and &quot;version&quot; fields?\r\n\r\nMy current command is:\r\n\r\n    jq -r &#39;(map(keys) | add | unique) as $cols | map(.[] | {name, version} as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39;\r\n\r\nThis is not working. Can anyone provide some help?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/75486489/how-can-i-use-jq-to-filter-only-certain-fields-of-the-original-json-into-an-csv",
        "title": "How can I use jq to filter only certain fields of the original JSON into an CSV?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1526413,
                    "reputation": 13993,
                    "user_id": 1424739,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/19d3c927744b5ad3b94afbf88e1c3844?s=256&d=identicon&r=PG",
                    "display_name": "user1424739",
                    "link": "https://stackoverflow.com/users/1424739/user1424739"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1676692843,
                "post_id": 75491000,
                "comment_id": 133193931,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1676693519,
                "post_id": 75491000,
                "comment_id": 133193977,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676693673,
                "creation_date": 1676693673,
                "answer_id": 75491145,
                "question_id": 75491000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming pairwise occurrences, and that &quot;between&quot; means excluding the border items, you could query the `indices` of the border items, and fetch everything in between.\r\n\r\nGiven the following sample, the following filter will produce the following output:\r\n```json\r\n[\r\n  [&quot;A&quot;], [&quot;B&quot;], [&quot;X&quot;], [&quot;C&quot;], [&quot;D&quot;], [&quot;Y&quot;], [&quot;E&quot;], [&quot;F&quot;],\r\n  [&quot;G&quot;], [&quot;H&quot;], [&quot;X&quot;], [&quot;I&quot;], [&quot;J&quot;], [&quot;Y&quot;], [&quot;K&quot;], [&quot;L&quot;]\r\n]\r\n```\r\n```sh\r\n[\r\n  (\r\n    [[indices([[&quot;X&quot;]]), indices([[&quot;Y&quot;]])] | 0, transpose[][], infinite]\r\n    | _nwise(2)\r\n  )\r\n  as [$a, $b] | .[$a:$b+1][]\r\n]\r\n```\r\n```json\r\n[[&quot;A&quot;],[&quot;B&quot;],[&quot;X&quot;],[&quot;Y&quot;],[&quot;E&quot;],[&quot;F&quot;],[&quot;G&quot;],[&quot;H&quot;],[&quot;X&quot;],[&quot;Y&quot;],[&quot;K&quot;],[&quot;L&quot;]]\r\n```\r\n\r\n---\r\n\r\nIf the border items may occur in any order, and not necessarily in equal amounts, before transposing the two lists of indices they would need to be filtered first to only contain mutually successive positions.",
                "title": "How to remove seq of array elments matching a pattern at the beginning and the end?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676910503,
                "last_edit_date": 1676910503,
                "creation_date": 1676782709,
                "answer_id": 75498100,
                "question_id": 75491000,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question seems to have two components:\r\n\r\n(1) Given an array, how can I delete all segments that are &quot;bookended&quot; by two values?\r\n\r\n(2) Given a single JSON entity (aka document), how can I perform the above-mentioned deletion operation on all arrays, no matter where they occur within the document?\r\n\r\nHere, I will offer an alternative to @pmf&#39;s solution for (1) and show how to apply it to an entire JSON entity.\r\n\r\nHere&#39;s the alternative, which has the possible advantage that it doesn&#39;t make any strong assumptions about the occurrence of the $x and $y values, and allows for both interpretations regarding the removal of the bookends themselves:\r\n```\r\n# Input: an array\r\n# Remove all stretches from $x to the next $y,\r\n# removing both bookends too if and only if $bookends.\r\n# Both bookends must be present for a stretch to be removed.\r\ndef remove_all_xy($x; $y; $bookends):\r\n  # The helper function removes a single stretch from $x to $y, if any\r\n  def r:\r\n    index($x) as $ix\r\n    | if $ix then .[$ix+1:] as $tail\r\n      | ($tail | index($y)) as $iy\r\n      | if $iy  \r\n        then (if $bookends then 0 else 1 end) as $adjust\r\n        | .[:$ix + $adjust] + ($tail | .[1+$iy - $adjust:] | r)\r\n        else . end\r\n      else . end;\r\n  r;\r\n```\r\n\r\nNow let&#39;s say you decide on some function, `foo($x;$y;$bookends)`, for performing the per-array operation.  To apply it to the whole document,\r\nyou could write:\r\n\r\n    walk(if type == &quot;array&quot; then foo($x;$y;$bookends) else . end)\r\n\r\n\r\nThis might not be as efficient as possible, but in practice it should suffice.  (If not, then simply adapt the standard `walk`.)\r\n\r\n  ",
                "title": "How to remove seq of array elments matching a pattern at the beginning and the end?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1676910503,
        "creation_date": 1676691018,
        "last_edit_date": 1676692883,
        "question_id": 75491000,
        "body_markdown": "Suppose that I have a json file, in which the following pattern appears many times.\r\n\r\n```\r\n... [ ... [&quot;X&quot;], ... ,[&quot;Y&quot;] ... ] ...\r\n```\r\n\r\nI want to remove everything between each pair of `[&quot;X&quot;]` and `[&quot;Y&quot;]`. How can I do it?",
        "link": "https://stackoverflow.com/questions/75491000/how-to-remove-seq-of-array-elments-matching-a-pattern-at-the-beginning-and-the-e",
        "title": "How to remove seq of array elments matching a pattern at the beginning and the end?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "unique",
            "distinct"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676739555,
                "last_edit_date": 1676739555,
                "creation_date": 1676738776,
                "answer_id": 75494828,
                "question_id": 75494790,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Collect the items to be filtered into an array, and use either `unique` alone to compare the whole objects, or `unique_by` on any filter combination, e.g. `.DN`):\r\n\r\n```sh\r\njq -r &#39;map(.SIR[].PMD[].MMA[]) | unique[] | [.DN, .SA] | @csv&#39;\r\n```\r\n```sh\r\njq -r &#39;map(.SIR[].PMD[].MMA[]) | unique_by(.DN)[] | [.DN, .SA] | @csv&#39;\r\n```\r\n---\r\nNote that the output will be sorted, in the first case by the whole object, in the latter by the filter provided. To achieve the numeric ordering of your sample output, use `unique_by` on either just `(.SA|tonumber)`, or first `(.SA|tonumber)` then `.DN`. The conversion to numbers only affects the sorting, not the output:\r\n```sh\r\njq -r &#39;map(.SIR[].PMD[].MMA[]) | unique_by(.SA|tonumber)[] | [.DN, .SA] | @csv&#39;\r\n```\r\n```sh\r\njq -r &#39;map(.SIR[].PMD[].MMA[]) | unique_by([(.SA|tonumber), .DN])[] | [.DN, .SA] | @csv&#39;\r\n```\r\n```\r\n&quot;One&quot;,&quot;1&quot;\r\n&quot;Two&quot;,&quot;2&quot;\r\n&quot;Three&quot;,&quot;3&quot;\r\n&quot;Four&quot;,&quot;4&quot;\r\n&quot;Five&quot;,&quot;5&quot;\r\n```",
                "title": "JQ Group_by or Unique not working for nested arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1676739555,
        "creation_date": 1676738227,
        "question_id": 75494790,
        "body_markdown": "Trying to get unique entries from nested JSON arrays.  \r\n\r\nJSON Source\r\n\r\n    [\r\n    {&quot;SIR&quot;:[{&quot;PMD&quot;:[{&quot;MMA&quot;:[{&quot;DN&quot;:&quot;One&quot;,&quot;SA&quot;:&quot;1&quot;},{&quot;DN&quot;:&quot;Two&quot;,&quot;SA&quot;:&quot;2&quot;}]}]}]},\r\n    {&quot;SIR&quot;:[{&quot;PMD&quot;:[{&quot;MMA&quot;:[{&quot;DN&quot;:&quot;Two&quot;,&quot;SA&quot;:&quot;2&quot;},{&quot;DN&quot;:&quot;Four&quot;,&quot;SA&quot;:&quot;4&quot;}]}]}]},\r\n    {&quot;SIR&quot;:[{&quot;PMD&quot;:[{&quot;MMA&quot;:[{&quot;DN&quot;:&quot;Three&quot;,&quot;SA&quot;:&quot;3&quot;},{&quot;DN&quot;:&quot;Five&quot;,&quot;SA&quot;:&quot;5&quot;}]}]}]}\r\n    ]\r\n\r\nFilter producing non-unique results:\r\n\r\n    &#39;.[].SIR.PMD.MMA \r\n        | [.DN, .SA]\r\n        | @csv&#39;\r\n\r\nCurrent Output (CSV\r\n\r\n    One,1\r\n    Two,2\r\n    Two,2\r\n    Three,3\r\n    Four,4\r\n    Five,5\r\n\r\nDesired Output (CSV)\r\n\r\n    One,1\r\n    Two,2\r\n    Three,3\r\n    Four,4\r\n    Five,5\r\n",
        "link": "https://stackoverflow.com/questions/75494790/jq-group-by-or-unique-not-working-for-nested-arrays",
        "title": "JQ Group_by or Unique not working for nested arrays"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1676742405,
                "creation_date": 1676742405,
                "answer_id": 75495235,
                "question_id": 75495172,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "reduce the oouter object to your field using `{field1}`, then map this field to an array containing only the `first` item:\r\n```sh\r\njq &#39;{field1} | map_values([first])&#39;\r\n```\r\n```json\r\n{\r\n  &quot;field1&quot;: [\r\n    {\r\n      &quot;a&quot;: &quot;F1A1&quot;,\r\n      &quot;b&quot;: &quot;F1B1&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n---\r\nTo filter for certain items use `select`:\r\n```sh\r\njq &#39;{field1} | map_values(map(select(.a == &quot;F1A1&quot; or .a == &quot;F1A4&quot;)))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;field1&quot;: [\r\n    {\r\n      &quot;a&quot;: &quot;F1A1&quot;,\r\n      &quot;b&quot;: &quot;F1B1&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;F1A4&quot;,\r\n      &quot;b&quot;: &quot;F1B4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n---\r\nAs you can see, `select` does something different. It passes on its input if the argument evaluates to `true`. Therefore its output is either all or nothing, never just a filtered part. (Of course, you can use `select` to achieve specific filtering, as shown above.)",
                "title": "select few elements of an inner array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676742405,
        "creation_date": 1676741840,
        "question_id": 75495172,
        "body_markdown": "I want create a more simple json with the same original structure but with one a small sample.\r\n\r\nAs example, If I have this json:\r\n```json\r\n{\r\n    &quot;field1&quot;: [\r\n        {\r\n            &quot;a&quot;: &quot;F1A1&quot;,\r\n            &quot;b&quot;: &quot;F1B1&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F1A2&quot;,\r\n            &quot;b&quot;: &quot;F1B2&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F1A3&quot;,\r\n            &quot;b&quot;: &quot;F1B3&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F1A4&quot;,\r\n            &quot;b&quot;: &quot;F1B4&quot;\r\n        }\r\n    ],\r\n    &quot;field2&quot;: [\r\n        {\r\n            &quot;a&quot;: &quot;F2A1&quot;,\r\n            &quot;b&quot;: &quot;F2B1&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F2A2&quot;,\r\n            &quot;b&quot;: &quot;F2B2&quot;\r\n        }\r\n    ],\r\n    &quot;field3&quot;: [\r\n        {\r\n            &quot;a&quot;: &quot;F3A1&quot;,\r\n            &quot;b&quot;: &quot;F3B1&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F3A2&quot;,\r\n            &quot;b&quot;: &quot;F3B2&quot;\r\n        }\r\n    ]\r\n\r\n}\r\n```\r\n\r\nI want to get the first array element from the first field. So I was expecting this:\r\n```json\r\n{\r\n    &quot;field1&quot;: [\r\n        {\r\n            &quot;a&quot;: &quot;F1A1&quot;,\r\n            &quot;b&quot;: &quot;F1B1&quot;\r\n        }\r\n    ],\r\n\r\n}\r\n```\r\n\r\nI executed `jq &quot;select(.field1[0])&quot; tmp.json` but it returns the original json.\r\n\r\nBonus:\r\nAs bonus, how to do the same but extracting let&#39;s say `field1` and elements in the array with `a==&quot;F1A1&quot;` and `a==&quot;F1A4&quot;`, so will expect?:\r\n```json\r\n{\r\n    &quot;field1&quot;: [\r\n        {\r\n            &quot;a&quot;: &quot;F1A1&quot;,\r\n            &quot;b&quot;: &quot;F1B1&quot;\r\n        },\r\n        {\r\n            &quot;a&quot;: &quot;F1A4&quot;,\r\n            &quot;b&quot;: &quot;F1B4&quot;\r\n        }\r\n    ]\r\n\r\n}\r\n```\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75495172/select-few-elements-of-an-inner-array-using-jq",
        "title": "select few elements of an inner array using jq"
    },
    {
        "tags": [
            "json",
            "sed",
            "schema",
            "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": 1676824647,
                "post_id": 75501520,
                "comment_id": 133210764,
                "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": 1677119546,
                "post_id": 75501520,
                "comment_id": 133276738,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1676824736,
                "last_edit_date": 1676824736,
                "creation_date": 1676824102,
                "answer_id": 75501621,
                "question_id": 75501520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq module schema.jq at https://gist.github.com/pkoppstein/a5abb4ebef3b0f72a6ed\r\nWas designed to produce the kind of structural schema you describe.  \r\n\r\nFor very large inputs, it might be very slow, so if the JSON is sufficiently regular, it might be possible to use a hybrid strategy - profiling enough of the data to come up with a comprehensive structural schema, and then checking that it does apply.\r\n\r\nFor conformance testing of structural schemas such as produced by schema.jq, see https://github.com/pkoppstein/JESS",
                "title": "jq to recursively profile JSON object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676854620,
                "last_edit_date": 1676854620,
                "creation_date": 1676836805,
                "answer_id": 75503071,
                "question_id": 75501520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your input.json, here is a solution :\r\n\r\n```\r\njq &#39;\r\ndef schema:\r\n    if   type == &quot;object&quot; then .[] |= schema\r\n    elif type == &quot;array&quot;  then map(schema)|unique\r\n         | if (first | type) == &quot;object&quot; then [add] else . end\r\n    else type\r\n    end;\r\nschema\r\n&#39; input.json\r\n```",
                "title": "jq to recursively profile JSON object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676876153,
                "last_edit_date": 1676876153,
                "creation_date": 1676859987,
                "answer_id": 75504749,
                "question_id": 75501520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a variant of @Philippe&#39;s solution: it coalesces objects in `map(schema)` for arrays in a principled though lossy way.  (All these half-solutions trade speed for loss of precision.)\r\n\r\nNote that `keys_unsorted` is used below; if using gojq, then either this would have to be changed to `keys`, or a def of keys_unsorted provided.\r\n\r\n\r\n```\r\n# Use &quot;JSON&quot; as the union of two distinct types\r\n# except combine([]; [ $x ]) =&gt; [ $x ]\r\ndef combine($a;$b):\r\n  if $a == $b then $a elif $a == null then $b elif $b == null then $a\r\n  elif ($a == []) and ($b|type) == &quot;array&quot; then $b\r\n  elif ($b == []) and ($a|type) == &quot;array&quot; then $a\r\n  else &quot;JSON&quot;\r\n  end;\r\n\r\n# Profile an array by calling mergeTypes(.[] | schema)\r\n# in order to coalesce objects\r\ndef mergeTypes(s):\r\n    reduce s as $t (null;\r\n       if ($t|type) != &quot;object&quot; then .types = (.types + [$t] | unique)\r\n       else .object as $o\r\n       | .object = reduce ($t | keys_unsorted[]) as $k ($o;\r\n                    .[$k] = combine( $t[$k]; $o[$k] ) \r\n\t\t  )\r\n       end)\r\n       | (if .object then [.object] else null end ) + .types ;\r\n\r\ndef schema:\r\n    if   type == &quot;object&quot; then .[] |= schema\r\n    elif type == &quot;array&quot;\r\n    then if . == [] then [] else mergeTypes(.[] | schema) end\r\n    else type\r\n    end;\r\nschema\r\n```\r\n---\r\n\r\nExample:\r\nInput:\r\n```\r\n{&quot;a&quot;: [{&quot;b&quot;:[1]}, {&quot;c&quot;:[2]}, {&quot;c&quot;: []}] }\r\n```\r\nOutput:\r\n```\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;b&quot;: [\r\n        &quot;number&quot;\r\n      ],\r\n      &quot;c&quot;: [\r\n        &quot;number&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "jq to recursively profile JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1676876153,
        "creation_date": 1676823111,
        "last_edit_date": 1676857096,
        "question_id": 75501520,
        "body_markdown": "I have some huge JSON files I need to profile so I can transform them into some tables. I found `jq` to be really useful in inspecting them, but there are going to be hundreds of these, and I&#39;m pretty new to `jq`.\r\n\r\nI already have some really handy functions in my `~/.jq` (big thank you to [@mikehwang](https://gist.github.com/mikehwang/6ed95480579ac0b9fd72bff340d99a18))\r\n```\r\ndef profile_object:\r\n    to_entries | def parse_entry: {&quot;key&quot;: .key, &quot;value&quot;: .value | type}; map(parse_entry)\r\n        | sort_by(.key) | from_entries;\r\n\r\ndef profile_array_objects:\r\n    map(profile_object) | map(to_entries) | reduce .[] as $item ([]; . + $item) | sort_by(.key) | from_entries;\r\n```\r\n\r\nI&#39;m sure I&#39;ll have to modify them after I describe my question.\r\n\r\nI&#39;d like a `jq` line to profile a single object. If a key maps to an array of objects then collect the unique keys across the objects and keep profiling down if there are nested arrays of objects there. If a value is an object, profile that object.\r\n\r\nSorry for the long example, but imagine several GBs of this:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;XYZ Company&quot;,\r\n    &quot;type&quot;: &quot;Contractors&quot;,\r\n    &quot;reporting&quot;: [\r\n        {\r\n            &quot;group_id&quot;: &quot;660&quot;,\r\n            &quot;groups&quot;: [\r\n                {\r\n                    &quot;ids&quot;: [\r\n                        987654321,\r\n                        987654321,\r\n                        987654321\r\n                    ],   \r\n                    &quot;market&quot;: {\r\n                        &quot;name&quot;: &quot;Austin, TX&quot;,\r\n                        &quot;value&quot;: &quot;873275&quot;\r\n                    }\r\n                },\r\n                {\r\n                    &quot;ids&quot;: [\r\n                        987654321,\r\n                        987654321,\r\n                        987654321\r\n                    ],   \r\n                    &quot;market&quot;: {\r\n                        &quot;name&quot;: &quot;Nashville, TN&quot;,\r\n                        &quot;value&quot;: &quot;2393287&quot;\r\n                    }\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    &quot;product_agreements&quot;: [\r\n        {\r\n            &quot;negotiation_arrangement&quot;: &quot;FFVII&quot;,\r\n            &quot;code&quot;: &quot;84144&quot;,\r\n            &quot;type&quot;: &quot;DJ&quot;,\r\n            &quot;type_version&quot;: &quot;V10&quot;,\r\n            &quot;description&quot;: &quot;DJ in a mask&quot;,\r\n            &quot;name&quot;: &quot;Claptone&quot;,\r\n            &quot;negotiated_rates&quot;: [\r\n                {\r\n                    &quot;company_references&quot;: [\r\n                        1,\r\n                        5,\r\n                        458\r\n                    ],\r\n                    &quot;negotiated_prices&quot;: [\r\n                        {\r\n                            &quot;type&quot;: &quot;negotiated&quot;,\r\n                            &quot;rate&quot;: 17.73,\r\n                            &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n                            &quot;code&quot;: [\r\n                                &quot;11&quot;\r\n                            ],\r\n                            &quot;billing_modifier_code&quot;: [\r\n                                &quot;124&quot;\r\n                            ],\r\n                            &quot;billing_class&quot;: &quot;professional&quot;\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;company_references&quot;: [\r\n                        747\r\n                    ],\r\n                    &quot;negotiated_prices&quot;: [\r\n                        {\r\n                            &quot;type&quot;: &quot;fee&quot;,\r\n                            &quot;rate&quot;: 28.42,\r\n                            &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n                            &quot;code&quot;: [\r\n                                &quot;11&quot;\r\n                            ],\r\n                            &quot;billing_class&quot;: &quot;professional&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;negotiation_arrangement&quot;: &quot;MGS3&quot;,\r\n            &quot;name&quot;: &quot;David Byrne&quot;,\r\n            &quot;type&quot;: &quot;Producer&quot;,\r\n            &quot;type_version&quot;: &quot;V10&quot;,\r\n            &quot;code&quot;: &quot;654321&quot;,\r\n            &quot;description&quot;: &quot;Frontman from Talking Heads&quot;,\r\n            &quot;negotiated_rates&quot;: [\r\n                {\r\n                    &quot;company_references&quot;: [\r\n                        1,\r\n                        9,\r\n                        2344,\r\n                        8456\r\n                    ],\r\n                    &quot;negotiated_prices&quot;: [\r\n                        {\r\n                            &quot;type&quot;: &quot;negotiated&quot;,\r\n                            &quot;rate&quot;: 68.73,\r\n                            &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n                            &quot;code&quot;: [\r\n                                &quot;11&quot;\r\n                            ],\r\n                            &quot;billing_class&quot;: &quot;professional&quot;\r\n                        }\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;company_references&quot;: [\r\n                        679\r\n                    ],\r\n                    &quot;negotiated_prices&quot;: [\r\n                        {\r\n                            &quot;type&quot;: &quot;fee&quot;,\r\n                            &quot;rate&quot;: 89.25,\r\n                            &quot;expiration_date&quot;: &quot;9999-12-31&quot;,\r\n                            &quot;code&quot;: [\r\n                                &quot;11&quot;\r\n                            ],\r\n                            &quot;billing_class&quot;: &quot;professional&quot;\r\n                        }\r\n                    ]\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    &quot;version&quot;: &quot;1.3.1&quot;,\r\n    &quot;last_updated_on&quot;: &quot;2023-02-01&quot;\r\n}\r\n```\r\n\r\nDesired output:\r\n```\r\n{\r\n    &quot;name&quot;: &quot;string&quot;,\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;reporting&quot;: [\r\n      {\r\n        &quot;group_id&quot;: &quot;number&quot;,\r\n        &quot;groups&quot;: [\r\n            {\r\n                &quot;ids&quot;: [\r\n                    &quot;number&quot;\r\n                ],\r\n                &quot;market&quot;: {\r\n                    &quot;type&quot;: &quot;string&quot;,\r\n                    &quot;value&quot;: &quot;string&quot;\r\n                }\r\n            }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;product_agreements&quot;: [\r\n      {\r\n        &quot;negotiation_arrangement&quot;: &quot;string&quot;,\r\n        &quot;code&quot;: &quot;string&quot;,\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;type_version&quot;: &quot;string&quot;,\r\n        &quot;description&quot;: &quot;string&quot;,\r\n        &quot;name&quot;: &quot;string&quot;,\r\n        &quot;negotiated_rates&quot;: [\r\n          {\r\n            &quot;company_references&quot;: [\r\n                &quot;number&quot;\r\n            ],\r\n            &quot;negotiated_prices&quot;: [\r\n              {\r\n                &quot;type&quot;: &quot;string&quot;,\r\n                &quot;rate&quot;: &quot;number&quot;,\r\n                &quot;expiration_date&quot;: &quot;string&quot;,\r\n                &quot;code&quot;: [\r\n                  &quot;string&quot;\r\n                ],\r\n                &quot;billing_modifier_code&quot;: [\r\n                  &quot;string&quot;\r\n                ],\r\n                &quot;billing_class&quot;: &quot;string&quot;\r\n              }\r\n            ]\r\n          }\r\n        ]        \r\n      }\r\n    ],\r\n    &quot;version&quot;: &quot;string&quot;,\r\n    &quot;last_updated_on&quot;: &quot;string&quot;\r\n}\r\n```\r\n\r\nReally sorry if there&#39;s any errors in that, but I tried to make it all consistent and about as simple as I could. \r\n\r\nTo restate the need, recursively profile each key in a JSON object if a value is an object or array. Solution needs to be key name independent. Happily to clarify further if needed.",
        "link": "https://stackoverflow.com/questions/75501520/jq-to-recursively-profile-json-object",
        "title": "jq to recursively profile JSON object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676893444,
                "last_edit_date": 1676893444,
                "creation_date": 1676892136,
                "answer_id": 75508629,
                "question_id": 75508541,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**A simple solution** could be to get the first `4` chars from your `DateTime`, convert that [`tonumber`][1] and use that as your `$year`\r\n\r\nThen [`select()`][2] all those where `$year &gt; 2022 and $year &lt; 2030`:\r\n```\r\nmap((.DateTime[0:4] | tonumber) as $year | select($year &gt; 2022 and $year &lt; 2030))\r\n```\r\n#### [Try it online](https://jqplay.org/s/wujHZRgAXDa)\r\n\r\n----------\r\n\r\n**A more complex solution**, where we *correctly* parse the date:\r\n```\r\nmap(.DateTime | (sub(&quot;(?&lt;time&gt;.*)\\\\.[\\\\d]{3}(?&lt;tz&gt;.*)&quot;; &quot;\\(.time)\\(.tz)&quot;) | fromdateiso8601 |  strftime(&quot;%Y&quot;) | tonumber) as $year | select($year &gt; 2022 and $year &lt; 2030)) \r\n```\r\n\r\nThis uses the [`sub`][3] from this [Github Issue][4] to remove the milliseconds part of your date so [`fromdateiso8601`][5] understands it and we can use [`strftime`][5] to format it to a year\r\n\r\n#### [Try it online][6]\r\n\r\n----------\r\nOutput\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;DateTime&quot;: &quot;2023-12-09T16:00:00.000Z&quot;,\r\n    &quot;Name&quot;: &quot;name2&quot;\r\n  },\r\n  {\r\n    &quot;DateTime&quot;: &quot;2028-12-09T16:00:00.000Z&quot;,\r\n    &quot;Name&quot;: &quot;name3&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#tonumber\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [3]: https://stedolan.github.io/jq/manual/#sub(regex;tostring)sub(regex;string;flags)\r\n  [4]: https://github.com/stedolan/jq/issues/1409\r\n  [5]: https://stedolan.github.io/jq/manual/#Dates\r\n  [6]: https://jqplay.org/s/as4Wv01yc3G",
                "title": "Filter out JSON data using JQ based on dates"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676893444,
        "creation_date": 1676891669,
        "last_edit_date": 1676892534,
        "question_id": 75508541,
        "body_markdown": "JSON Data\r\n\r\n```\r\n{\r\n  &quot;DateTime&quot;: &quot;2022-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name1&quot;\r\n}\r\n{\r\n  &quot;DateTime&quot;: &quot;2023-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name2&quot;\r\n}\r\n{\r\n  &quot;DateTime&quot;: &quot;2028-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name3&quot;\r\n}\r\n{\r\n  &quot;DateTime&quot;: &quot;2030-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name4&quot;\r\n}\r\n```\r\nRequired result: Need to filter only those rows which is between year 2022 and 2030\r\n\r\nRequired output\r\n```\r\n{\r\n  &quot;DateTime&quot;: &quot;2023-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name2&quot;\r\n}\r\n{\r\n  &quot;DateTime&quot;: &quot;2028-12-09T16:00:00.000Z&quot;,\r\n  &quot;Name&quot;: &quot;name3&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75508541/filter-out-json-data-using-jq-based-on-dates",
        "title": "Filter out JSON data using JQ based on dates"
    },
    {
        "tags": [
            "jq",
            "openapi"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676914732,
                "post_id": 75512403,
                "comment_id": 133229132,
                "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": 1676967016,
                "post_id": 75512403,
                "comment_id": 133238285,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1676982333,
        "creation_date": 1676913873,
        "last_edit_date": 1676982333,
        "question_id": 75512403,
        "body_markdown": "So I have the following OpenAPI 3.0 file (this is NOT a full file, just grab the full one from the open api pet store sample demo):\r\n\r\n\r\n```\r\n{\r\n  &quot;openapi&quot;: &quot;3.0.0&quot;,\r\n  &quot;servers&quot;: [\r\n    {\r\n      &quot;url&quot;: &quot;//petstore.swagger.io/v2&quot;,\r\n      &quot;description&quot;: &quot;Default server&quot;\r\n    },\r\n    {\r\n      &quot;url&quot;: &quot;//petstore.swagger.io/sandbox&quot;,\r\n      &quot;description&quot;: &quot;Sandbox server&quot;\r\n    }\r\n  ],\r\n  &quot;info&quot;: {\r\n    \r\n    &quot;version&quot;: &quot;1.0.0&quot;,\r\n    &quot;title&quot;: &quot;Swagger Petstore&quot;,\r\n    &quot;termsOfService&quot;: &quot;http://swagger.io/terms/&quot;,\r\n    &quot;contact&quot;: {\r\n      &quot;name&quot;: &quot;API Support&quot;,\r\n      &quot;email&quot;: &quot;apiteam@swagger.io&quot;,\r\n      &quot;url&quot;: &quot;https://github.com/Redocly/redoc&quot;\r\n    },\r\n    &quot;x-logo&quot;: {\r\n      &quot;url&quot;: &quot;https://redocly.github.io/redoc/petstore-logo.png&quot;,\r\n      &quot;altText&quot;: &quot;Petstore logo&quot;\r\n    },\r\n    &quot;license&quot;: {\r\n      &quot;name&quot;: &quot;Apache 2.0&quot;,\r\n      &quot;url&quot;: &quot;http://www.apache.org/licenses/LICENSE-2.0.html&quot;\r\n    }\r\n  },\r\n  &quot;externalDocs&quot;: {\r\n    &quot;description&quot;: &quot;Find out how to create Github repo for your OpenAPI spec.&quot;,\r\n    &quot;url&quot;: &quot;https://github.com/Rebilly/generator-openapi-repo&quot;\r\n  },\r\n  &quot;tags&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;pet&quot;,\r\n      &quot;description&quot;: &quot;Everything about your Pets&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;store&quot;,\r\n      &quot;description&quot;: &quot;Access to Petstore orders&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;user&quot;,\r\n      &quot;description&quot;: &quot;Operations about user&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;pet_model&quot;,\r\n      &quot;x-displayName&quot;: &quot;The Pet Model&quot;,\r\n      &quot;description&quot;: &quot;&lt;SchemaDefinition schemaRef=\\&quot;#/components/schemas/Pet\\&quot; /&gt;\\n&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;store_model&quot;,\r\n      &quot;x-displayName&quot;: &quot;The Order Model&quot;,\r\n      &quot;description&quot;: &quot;&lt;SchemaDefinition schemaRef=\\&quot;#/components/schemas/Order\\&quot; exampleRef=\\&quot;#/components/examples/Order\\&quot; showReadOnly={true} showWriteOnly={true} /&gt;\\n&quot;\r\n    }\r\n  ],\r\n  &quot;x-tagGroups&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;General&quot;,\r\n      &quot;tags&quot;: [\r\n        &quot;pet&quot;,\r\n        &quot;store&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;User Management&quot;,\r\n      &quot;tags&quot;: [\r\n        &quot;user&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Models&quot;,\r\n      &quot;tags&quot;: [\r\n        &quot;pet_model&quot;,\r\n        &quot;store_model&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/pet&quot;: {\r\n      &quot;parameters&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Accept-Language&quot;,\r\n          &quot;in&quot;: &quot;header&quot;,\r\n          &quot;description&quot;: &quot;The language you prefer for messages. Supported values are en-AU, en-CA, en-GB, en-US&quot;,\r\n          &quot;example&quot;: &quot;en-US&quot;,\r\n          &quot;required&quot;: false,\r\n          &quot;schema&quot;: {\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;default&quot;: &quot;en-AU&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;cookieParam&quot;,\r\n          &quot;in&quot;: &quot;cookie&quot;,\r\n          &quot;description&quot;: &quot;Some cookie&quot;,\r\n          &quot;required&quot;: true,\r\n          &quot;schema&quot;: {\r\n            &quot;type&quot;: &quot;integer&quot;,\r\n            &quot;format&quot;: &quot;int64&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Add a new pet to the store&quot;,\r\n        &quot;description&quot;: &quot;Add new pet to the store inventory.&quot;,\r\n        &quot;operationId&quot;: &quot;addPet&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;405&quot;: {\r\n            &quot;description&quot;: &quot;Invalid input&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;x-codeSamples&quot;: [\r\n          {\r\n            &quot;lang&quot;: &quot;C#&quot;,\r\n            &quot;source&quot;: &quot;PetStore.v1.Pet pet = new PetStore.v1.Pet();\\npet.setApiKey(\\&quot;your api key\\&quot;);\\npet.petType = PetStore.v1.Pet.TYPE_DOG;\\npet.name = \\&quot;Rex\\&quot;;\\n// set other fields\\nPetStoreResponse response = pet.create();\\nif (response.statusCode == HttpStatusCode.Created)\\n{\\n  // Successfully created\\n}\\nelse\\n{\\n  // Something wrong -- check response for errors\\n  Console.WriteLine(response.getRawResponse());\\n}\\n&quot;\r\n          },\r\n          {\r\n            &quot;lang&quot;: &quot;PHP&quot;,\r\n            &quot;source&quot;: &quot;$form = new \\\\PetStore\\\\Entities\\\\Pet();\\n$form-&gt;setPetType(\\&quot;Dog\\&quot;);\\n$form-&gt;setName(\\&quot;Rex\\&quot;);\\n// set other fields\\ntry {\\n    $pet = $client-&gt;pets()-&gt;create($form);\\n} catch (UnprocessableEntityException $e) {\\n    var_dump($e-&gt;getErrors());\\n}\\n&quot;\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;$ref&quot;: &quot;#/components/requestBodies/Pet&quot;\r\n        }\r\n      },\r\n      &quot;put&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Update an existing pet&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;operationId&quot;: &quot;updatePet&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid ID supplied&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;Pet not found&quot;\r\n          },\r\n          &quot;405&quot;: {\r\n            &quot;description&quot;: &quot;Validation exception&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;x-codeSamples&quot;: [\r\n          {\r\n            &quot;lang&quot;: &quot;PHP&quot;,\r\n            &quot;source&quot;: &quot;$form = new \\\\PetStore\\\\Entities\\\\Pet();\\n$form-&gt;setPetId(1);\\n$form-&gt;setPetType(\\&quot;Dog\\&quot;);\\n$form-&gt;setName(\\&quot;Rex\\&quot;);\\n// set other fields\\ntry {\\n    $pet = $client-&gt;pets()-&gt;update($form);\\n} catch (UnprocessableEntityException $e) {\\n    var_dump($e-&gt;getErrors());\\n}\\n&quot;\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;$ref&quot;: &quot;#/components/requestBodies/Pet&quot;\r\n        }\r\n      }\r\n    },\r\n    &quot;/pet/{petId}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Find pet by ID&quot;,\r\n        &quot;description&quot;: &quot;Returns a single pet&quot;,\r\n        &quot;operationId&quot;: &quot;getPetById&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;petId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ID of pet to return&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;deprecated&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;integer&quot;,\r\n              &quot;format&quot;: &quot;int64&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                }\r\n              },\r\n              &quot;application/xml&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid ID supplied&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;Pet not found&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;api_key&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Updates a pet in the store with form data&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;operationId&quot;: &quot;updatePetWithForm&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;petId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ID of pet that needs to be updated&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;integer&quot;,\r\n              &quot;format&quot;: &quot;int64&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;405&quot;: {\r\n            &quot;description&quot;: &quot;Invalid input&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/x-www-form-urlencoded&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;,\r\n                &quot;properties&quot;: {\r\n                  &quot;name&quot;: {\r\n                    &quot;description&quot;: &quot;Updated name of the pet&quot;,\r\n                    &quot;type&quot;: &quot;string&quot;\r\n                  },\r\n                  &quot;status&quot;: {\r\n                    &quot;description&quot;: &quot;Updated status of the pet&quot;,\r\n                    &quot;type&quot;: &quot;string&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Deletes a pet&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;operationId&quot;: &quot;deletePet&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;api_key&quot;,\r\n            &quot;in&quot;: &quot;header&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;\r\n            },\r\n            &quot;example&quot;: &quot;Bearer &lt;TOKEN&gt;&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;petId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Pet id to delete&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;integer&quot;,\r\n              &quot;format&quot;: &quot;int64&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid pet value&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/pet/{petId}/uploadImage&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;uploads an image&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;operationId&quot;: &quot;uploadFile&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;petId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ID of pet to update&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;integer&quot;,\r\n              &quot;format&quot;: &quot;int64&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/ApiResponse&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/octet-stream&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;,\r\n                &quot;format&quot;: &quot;binary&quot;\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/pet/findByStatus&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Finds Pets by status&quot;,\r\n        &quot;description&quot;: &quot;Multiple status values can be provided with comma separated strings&quot;,\r\n        &quot;operationId&quot;: &quot;findPetsByStatus&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;status&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;Status values that need to be considered for filter&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;style&quot;: &quot;form&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;,\r\n              &quot;minItems&quot;: 1,\r\n              &quot;maxItems&quot;: 3,\r\n              &quot;items&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;,\r\n                &quot;enum&quot;: [\r\n                  &quot;available&quot;,\r\n                  &quot;pending&quot;,\r\n                  &quot;sold&quot;\r\n                ],\r\n                &quot;default&quot;: &quot;available&quot;\r\n              }\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                  }\r\n                }\r\n              },\r\n              &quot;application/xml&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid status value&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/pet/findByTags&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;pet&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Finds Pets by tags&quot;,\r\n        &quot;description&quot;: &quot;Multiple tags can be provided with comma separated strings. Use tag1, tag2, tag3 for testing.&quot;,\r\n        &quot;operationId&quot;: &quot;findPetsByTags&quot;,\r\n        &quot;deprecated&quot;: true,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;tags&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;Tags to filter by&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;style&quot;: &quot;form&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;array&quot;,\r\n              &quot;items&quot;: {\r\n                &quot;type&quot;: &quot;string&quot;\r\n              }\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;items&quot;: {\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                  }\r\n                }\r\n              },\r\n              &quot;application/xml&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;array&quot;,\r\n                  &quot;maxItems&quot;: 999,\r\n                  &quot;items&quot;: {\r\n                    &quot;maxItems&quot;: 111,\r\n                    &quot;$ref&quot;: &quot;#/components/schemas/Pet&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid tag value&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;petstore_auth&quot;: [\r\n              &quot;write:pets&quot;,\r\n              &quot;read:pets&quot;\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/store/inventory&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;store&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Returns pet inventories by status&quot;,\r\n        &quot;description&quot;: &quot;Returns a map of status codes to quantities&quot;,\r\n        &quot;operationId&quot;: &quot;getInventory&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;,\r\n                  &quot;minProperties&quot;: 2,\r\n                  &quot;additionalProperties&quot;: {\r\n                    &quot;type&quot;: &quot;integer&quot;,\r\n                    &quot;format&quot;: &quot;int32&quot;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;api_key&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/store/order&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;store&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Place an order for a pet&quot;,\r\n        &quot;description&quot;: &quot;&quot;,\r\n        &quot;operationId&quot;: &quot;placeOrder&quot;,\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Order&quot;\r\n                }\r\n              },\r\n              &quot;application/xml&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Order&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid Order&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;example&quot;: {\r\n                  &quot;status&quot;: 400,\r\n                  &quot;message&quot;: &quot;Invalid Order&quot;\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/json&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;$ref&quot;: &quot;#/components/schemas/Order&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;description&quot;: &quot;order placed for purchasing the pet&quot;,\r\n          &quot;required&quot;: true\r\n        }\r\n      }\r\n    },\r\n    &quot;/store/order/{orderId}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;store&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Find purchase order by ID&quot;,\r\n        &quot;description&quot;: &quot;For valid response try integer IDs with value &lt;= 5 or &gt; 10. Other values will generated exceptions&quot;,\r\n        &quot;operationId&quot;: &quot;getOrderById&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;orderId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ID of pet that needs to be fetched&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;integer&quot;,\r\n              &quot;format&quot;: &quot;int64&quot;,\r\n              &quot;minimum&quot;: 1,\r\n              &quot;maximum&quot;: 5\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Order&quot;\r\n                }\r\n              },\r\n              &quot;application/xml&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;$ref&quot;: &quot;#/components/schemas/Order&quot;\r\n                }\r\n              }\r\n            }\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid ID supplied&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;Order not found&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;store&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Delete purchase order by ID&quot;,\r\n        &quot;description&quot;: &quot;For valid response try integer IDs with value &lt; 1000. Anything above 1000 or nonintegers will generate API errors&quot;,\r\n        &quot;operationId&quot;: &quot;deleteOrder&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;orderId&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;ID of the order that needs to be deleted&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;minimum&quot;: 1\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;Invalid ID supplied&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;Order not found&quot;\r\n          }\r\n        }\r\n      }\r\n    },\r\n    &quot;/store/subscribe&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;store&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Subscribe to the Store events&quot;,\r\n        &quot;description&quot;: &quot;Add subscription for a store events&quot;,\r\n        &quot;requestBody&quot;: {\r\n          &quot;content&quot;: {\r\n            &quot;application/json&quot;: {\r\n              &quot;schema&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;,\r\n                &quot;properties&quot;: {\r\n                  &quot;callbackUrl&quot;: {\r\n                    &quot;type&quot;: &quot;string&quot;,\r\n                    &quot;format&quot;: &quot;uri&quot;,\r\n                    &quot;description&quot;: &quot;This URL will be called by the server when the desired event will occur&quot;,\r\n                    &quot;example&quot;: &quot;https://myserver.com/send/callback/here&quot;\r\n                  },\r\n                  &quot;eventName&quot;: {\r\n                    &quot;type&quot;: &quot;string&quot;,\r\n                    &quot;description&quot;: &quot;Event name for the subscription&quot;,\r\n                    &quot;enum&quot;: [\r\n                      &quot;orderInProgress&quot;,\r\n                      &quot;orderShipped&quot;,\r\n                      &quot;orderDelivered&quot;\r\n                    ],\r\n                    &quot;example&quot;: &quot;orderInProgress&quot;\r\n                  }\r\n                },\r\n                &quot;required&quot;: [\r\n                  &quot;callbackUrl&quot;,\r\n                  &quot;eventName&quot;\r\n                ]\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;responses&quot;: {\r\n          &quot;201&quot;: {\r\n            &quot;description&quot;: &quot;Subscription added&quot;,\r\n            &quot;content&quot;: {\r\n              &quot;application/json&quot;: {\r\n                &quot;schema&quot;: {\r\n                  &quot;type&quot;: &quot;object&quot;,\r\n                  &quot;properties&quot;: {\r\n                    &quot;subscriptionId&quot;: {\r\n                      &quot;type&quot;: &quot;string&quot;,\r\n                      &quot;example&quot;: &quot;AAA-123-BBB-456&quot;\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        },\r\n        &quot;callbacks&quot;: {\r\n          &quot;orderInProgress&quot;: {\r\n            &quot;{$request.body#/callbackUrl}?event={$request.body#/eventName}&quot;: {\r\n              &quot;servers&quot;: [\r\n                {\r\n                  &quot;url&quot;: &quot;//callback-url.path-level/v1&quot;,\r\n                  &quot;description&quot;: &quot;Path level server 1&quot;\r\n                },\r\n                {\r\n                  &quot;url&quot;: &quot;//callback-url.path-level/v2&quot;,\r\n                  &quot;description&quot;: &quot;Path level server 2&quot;\r\n                }\r\n              ],\r\n              &quot;post&quot;: {\r\n                &quot;summary&quot;: &quot;Order in Progress (Summary)&quot;,\r\n                &quot;description&quot;: &quot;A callback triggered every time an Order is updated status to \\&quot;inProgress\\&quot; (Description)&quot;,\r\n                &quot;externalDocs&quot;: {\r\n                  &quot;description&quot;: &quot;Find out more&quot;,\r\n                  &quot;url&quot;: &quot;https://more-details.com/demo&quot;\r\n                },\r\n                &quot;requestBody&quot;: {\r\n                  &quot;content&quot;: {\r\n                    &quot;application/json&quot;: {\r\n                      &quot;schema&quot;: {\r\n                        &quot;type&quot;: &quot;object&quot;,\r\n                        &quot;properties&quot;: {\r\n                          &quot;orderId&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;123&quot;\r\n                          },\r\n                          &quot;timestamp&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;format&quot;: &quot;date-time&quot;,\r\n                            &quot;example&quot;: &quot;2018-10-19T16:46:45Z&quot;\r\n                          },\r\n                          &quot;status&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;inProgress&quot;\r\n                          }\r\n                        }\r\n                      }\r\n                    },\r\n                    &quot;application/xml&quot;: {\r\n                      &quot;schema&quot;: {\r\n                        &quot;type&quot;: &quot;object&quot;,\r\n                        &quot;properties&quot;: {\r\n                          &quot;orderId&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;123&quot;\r\n                          }\r\n                        }\r\n                      },\r\n                      &quot;example&quot;: &quot;&lt;?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?&gt;\\n&lt;root&gt;\\n  &lt;orderId&gt;123&lt;/orderId&gt;\\n  &lt;status&gt;inProgress&lt;/status&gt;\\n  &lt;timestamp&gt;2018-10-19T16:46:45Z&lt;/timestamp&gt;\\n&lt;/root&gt;\\n&quot;\r\n                    }\r\n                  }\r\n                },\r\n                &quot;responses&quot;: {\r\n                  &quot;200&quot;: {\r\n                    &quot;description&quot;: &quot;Callback successfully processed and no retries will be performed&quot;,\r\n                    &quot;content&quot;: {\r\n                      &quot;application/json&quot;: {\r\n                        &quot;schema&quot;: {\r\n                          &quot;type&quot;: &quot;object&quot;,\r\n                          &quot;properties&quot;: {\r\n                            &quot;someProp&quot;: {\r\n                              &quot;type&quot;: &quot;string&quot;,\r\n                              &quot;example&quot;: &quot;123&quot;\r\n                            }\r\n                          }\r\n                        }\r\n                      }\r\n                    }\r\n                  },\r\n                  &quot;299&quot;: {\r\n                    &quot;description&quot;: &quot;Response for cancelling subscription&quot;\r\n                  },\r\n                  &quot;500&quot;: {\r\n                    &quot;description&quot;: &quot;Callback processing failed and retries will be performed&quot;\r\n                  }\r\n                },\r\n                &quot;x-codeSamples&quot;: [\r\n                  {\r\n                    &quot;lang&quot;: &quot;C#&quot;,\r\n                    &quot;source&quot;: &quot;PetStore.v1.Pet pet = new PetStore.v1.Pet();\\npet.setApiKey(\\&quot;your api key\\&quot;);\\npet.petType = PetStore.v1.Pet.TYPE_DOG;\\npet.name = \\&quot;Rex\\&quot;;\\n// set other fields\\nPetStoreResponse response = pet.create();\\nif (response.statusCode == HttpStatusCode.Created)\\n{\\n  // Successfully created\\n}\\nelse\\n{\\n  // Something wrong -- check response for errors\\n  Console.WriteLine(response.getRawResponse());\\n}\\n&quot;\r\n                  },\r\n                  {\r\n                    &quot;lang&quot;: &quot;PHP&quot;,\r\n                    &quot;source&quot;: &quot;$form = new \\\\PetStore\\\\Entities\\\\Pet();\\n$form-&gt;setPetType(\\&quot;Dog\\&quot;);\\n$form-&gt;setName(\\&quot;Rex\\&quot;);\\n// set other fields\\ntry {\\n    $pet = $client-&gt;pets()-&gt;create($form);\\n} catch (UnprocessableEntityException $e) {\\n    var_dump($e-&gt;getErrors());\\n}\\n&quot;\r\n                  }\r\n                ]\r\n              },\r\n              &quot;put&quot;: {\r\n                &quot;description&quot;: &quot;Order in Progress (Only Description)&quot;,\r\n                &quot;servers&quot;: [\r\n                  {\r\n                    &quot;url&quot;: &quot;//callback-url.operation-level/v1&quot;,\r\n                    &quot;description&quot;: &quot;Operation level server 1 (Operation override)&quot;\r\n                  },\r\n                  {\r\n                    &quot;url&quot;: &quot;//callback-url.operation-level/v2&quot;,\r\n                    &quot;description&quot;: &quot;Operation level server 2 (Operation override)&quot;\r\n                  }\r\n                ],\r\n                &quot;requestBody&quot;: {\r\n                  &quot;content&quot;: {\r\n                    &quot;application/json&quot;: {\r\n                      &quot;schema&quot;: {\r\n                        &quot;type&quot;: &quot;object&quot;,\r\n                        &quot;properties&quot;: {\r\n                          &quot;orderId&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;123&quot;\r\n                          },\r\n                          &quot;timestamp&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;format&quot;: &quot;date-time&quot;,\r\n                            &quot;example&quot;: &quot;2018-10-19T16:46:45Z&quot;\r\n                          },\r\n                          &quot;status&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;inProgress&quot;\r\n                          }\r\n                        }\r\n                      }\r\n                    },\r\n                    &quot;application/xml&quot;: {\r\n                      &quot;schema&quot;: {\r\n                        &quot;type&quot;: &quot;object&quot;,\r\n                        &quot;properties&quot;: {\r\n                          &quot;orderId&quot;: {\r\n                            &quot;type&quot;: &quot;string&quot;,\r\n                            &quot;example&quot;: &quot;123&quot;\r\n                          }\r\n                        }\r\n                      },\r\n                      &quot;example&quot;: &quot;&lt;?xml version=\\&quot;1.0\\&quot; encoding=\\&quot;UTF-8\\&quot;?&gt;\\n&lt;root&gt;\\n  &lt;orderId&gt;123&lt;/orderId&gt;\\n  &lt;status&gt;inProgress&lt;/status&gt;\\n  &lt;timestamp&gt;2018-10-19T16:46:45Z&lt;/timestamp&gt;\\n&lt;/root&gt;\\n&quot;\r\n                    }\r\n                  }\r\n                },\r\n                &quot;responses&quot;: {\r\n                  &quot;200&quot;: {\r\n                    &quot;description&quot;: &quot;Callback successfully processed and no retries will be performed&quot;,\r\n                    &quot;content&quot;: {\r\n                      &quot;application/json&quot;: {\r\n                        &quot;schema&quot;: {\r\n                          &quot;type&quot;: &quot;object&quot;,\r\n                          &quot;properties&quot;: {\r\n                            &quot;someProp&quot;: {\r\n                              &quot;type&quot;: &quot;string&quot;,\r\n                              &quot;example&quot;: &quot;123&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  }\r\n}\r\n```\r\n\r\nWhat needs to be done is that the operationId of each endpoint needs to be appended to each description. But please don&#39;t just do .description + operationId, because I am trying to do something more complex. What eventually will happen is that there is another json file where keys are operationIds. So in the current file, I will need to append content to the descriptions from that third file based on operationId. Something like this:\r\n\r\n\r\n```\r\n| .[&quot;endpoint_descriptions&quot;] as $endpoint_descriptions\r\n| .paths[][] as $paths | .description |= . + $endpoint_descriptions[$endpoint_descriptions].description\r\n```\r\n\r\n\r\nSo, please account for that when offering a solution. Thanks.\r\n\r\n\r\n\r\nI tried\r\n\r\n```\r\n| .[&quot;endpoint_descriptions&quot;] as $endpoint_descriptions\r\n| .paths[][] as $paths | .description |= . + $endpoint_descriptions[$endpoint_descriptions].description\r\n```",
        "link": "https://stackoverflow.com/questions/75512403/append-to-the-description-of-openapi-3-0-file-using-jq",
        "title": "Append to the description of OpenAPI 3.0 file using jq"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "amazon-iam"
        ],
        "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": 1676915416,
                "post_id": 75512573,
                "comment_id": 133229327,
                "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": 1676967065,
                "post_id": 75512573,
                "comment_id": 133238295,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1676915857,
                "creation_date": 1676915857,
                "answer_id": 75512678,
                "question_id": 75512573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know how AWS works and what it provides, but based on your current approach you may be looking for an array of unique group names, put into an object alongside with a static string as user name.\r\n```sh\r\n… | jq &#39;{name: &quot;User1&quot;, groups: (.Groups | map(.GroupName) | unique)}&#39;\r\n```\r\nIf you wanted to parametrize the string, use `--arg`\r\n```sh\r\n… | jq --arg name &quot;User1&quot; &#39;{$name, groups: (.Groups | map(.GroupName) | unique)}&#39;\r\n```",
                "title": "Combining two objects into one using JQ where they share the same attribute"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676963076,
                "last_edit_date": 1676963076,
                "creation_date": 1676923897,
                "answer_id": 75513728,
                "question_id": 75512573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Example output of `aws iam list-groups-for-user --user-name Bob` looks like [(docs)](https://docs.aws.amazon.com/cli/latest/reference/iam/list-groups-for-user.html):\r\n\r\n```json\r\n{\r\n    &quot;Groups&quot;: [\r\n        {\r\n            &quot;Path&quot;: &quot;/&quot;,\r\n            &quot;CreateDate&quot;: &quot;2013-05-06T01:18:08Z&quot;,\r\n            &quot;GroupId&quot;: &quot;AKIAIOSFODNN7EXAMPLE&quot;,\r\n            &quot;Arn&quot;: &quot;arn:aws:iam::123456789012:group/Admin&quot;,\r\n            &quot;GroupName&quot;: &quot;Admin&quot;\r\n        },\r\n        {\r\n            &quot;Path&quot;: &quot;/&quot;,\r\n            &quot;CreateDate&quot;: &quot;2013-05-06T01:37:28Z&quot;,\r\n            &quot;GroupId&quot;: &quot;AKIAI44QH8DHBEXAMPLE&quot;,\r\n            &quot;Arn&quot;: &quot;arn:aws:iam::123456789012:group/s3-Users&quot;,\r\n            &quot;GroupName&quot;: &quot;s3-Users&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nIf all you want to do is create an object with a made-up username and a list of group names, then construct a new object with the required properties and use `map` to transform the existing list:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: .Groups | map(.GroupName)\r\n}\r\n```\r\n\r\nOr a stream &amp; collect approach (this is how `map` is implemented):\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: [.Groups[].GroupName]\r\n}\r\n```\r\n\r\nOutput generated when feeding the sample from the official docs:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: [\r\n    &quot;Admin&quot;,\r\n    &quot;s3-Users&quot;\r\n  ]\r\n}\r\n```",
                "title": "Combining two objects into one using JQ where they share the same attribute"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1676963076,
        "creation_date": 1676915090,
        "question_id": 75512573,
        "body_markdown": "I am running an AWS cli command to retrieve all the groups that a user belongs to. \r\nThe result from a `iam list-groups-for-user --user-name &quot;User1&quot; | jq &#39;.Groups[] | . += {name: &quot;User1&quot;, groups: [.GroupName]} | {name, groups}&#39;` provides the following result: \r\n```\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: [\r\n    &quot;group1&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: [\r\n    &quot;group2&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhat I want to achieve is a more concise result where the group names are all added to a single array owned by a shared attribute, the `name`, for example:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;User1&quot;,\r\n  &quot;groups&quot;: [\r\n    &quot;group1&quot;,\r\n    &quot;group2&quot;\r\n  ]\r\n}\r\n```\r\n\r\nHow can I achieve this using `jq`?",
        "link": "https://stackoverflow.com/questions/75512573/combining-two-objects-into-one-using-jq-where-they-share-the-same-attribute",
        "title": "Combining two objects into one using JQ where they share the same attribute"
    },
    {
        "tags": [
            "json",
            "database",
            "header",
            "jq",
            "export-to-csv"
        ],
        "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": 1676921131,
                "post_id": 75513381,
                "comment_id": 133230747,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25265460,
                    "reputation": 11,
                    "user_id": 19095722,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/383d2f66a0b7da8770b9ea4efeb2b5c7?s=256&d=identicon&r=PG",
                    "display_name": "Jatin Kolluru",
                    "link": "https://stackoverflow.com/users/19095722/jatin-kolluru"
                },
                "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": 1676921382,
                "post_id": 75513381,
                "comment_id": 133230818,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 370138,
                    "reputation": 61314,
                    "user_id": 1264804,
                    "user_type": "registered",
                    "accept_rate": 61,
                    "profile_image": "https://i.sstatic.net/PIsfn.jpg?s=256",
                    "display_name": "isherwood",
                    "link": "https://stackoverflow.com/users/1264804/isherwood"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676922260,
                "post_id": 75513381,
                "comment_id": 133231028,
                "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": 1676922580,
                "post_id": 75513381,
                "comment_id": 133231109,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1676923732,
                "creation_date": 1676923732,
                "answer_id": 75513710,
                "question_id": 75513381,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are fine with the three-part header shown in the Q, then you could use the following:\r\n```\r\n  [&quot;resource_name&quot;,&quot;asset_type&quot;, &quot;labels&quot;],\r\n  \r\n  [.name,.asset_type, \r\n   ( .resource.data.labels // empty | to_entries[] | &quot;\\(.key):\\(.value)&quot;) ]\r\n  | @csv\r\n```\r\n\r\nA similar option would be to compact all the `label:value` components into a single CSV field so that the file is indeed in a standard (rectangular) CSV format.  \r\n\r\nOn the other hand, if you want the headers to reflect the labels in some manner, you will have to specify your requirements in more detail.\r\n",
                "title": "How do I include key and value pairs in jq CSV output from a nested NDJSON?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676991434,
        "creation_date": 1676920972,
        "last_edit_date": 1676991434,
        "question_id": 75513381,
        "body_markdown": "I want to export my NDJSON data into a CSV format with headers and key-value pairs. \r\n\r\nSample Data: \r\n```\r\n{&quot;name&quot;:&quot;//storage.googleapis.com/testing-list-api&quot;,&quot;asset_type&quot;:&quot;storage.googleapis.com/Bucket&quot;,&quot;resource&quot;:{&quot;version&quot;:&quot;v1&quot;,&quot;discovery_document_uri&quot;:&quot;https://www.googleapis.com/discovery/v1/apis/storage/v1/rest&quot;,&quot;discovery_name&quot;:&quot;Bucket&quot;,&quot;parent&quot;:&quot;//cloudresourcemanager.googleapis.com/projects/503672515986&quot;,&quot;data&quot;:{&quot;acl&quot;:[],&quot;autoclass&quot;:{},&quot;billing&quot;:{},&quot;cors&quot;:[],&quot;defaultObjectAcl&quot;:[],&quot;encryption&quot;:{},&quot;etag&quot;:&quot;CAE=&quot;,&quot;iamConfiguration&quot;:{&quot;bucketPolicyOnly&quot;:{&quot;enabled&quot;:true,&quot;lockedTime&quot;:&quot;2023-05-10T15:38:33.688Z&quot;},&quot;publicAccessPrevention&quot;:&quot;enforced&quot;,&quot;uniformBucketLevelAccess&quot;:{&quot;enabled&quot;:true,&quot;lockedTime&quot;:&quot;2023-05-10T15:38:33.688Z&quot;}},&quot;id&quot;:&quot;testing-list-api&quot;,&quot;kind&quot;:&quot;storage#bucket&quot;,&quot;labels&quot;:{&quot;application&quot;:&quot;gcs-bucket&quot;,&quot;testing&quot;:&quot;api&quot;},&quot;lifecycle&quot;:{&quot;rule&quot;:[]},&quot;location&quot;:&quot;US&quot;,&quot;locationType&quot;:&quot;multi-region&quot;,&quot;logging&quot;:{},&quot;metageneration&quot;:1,&quot;name&quot;:&quot;testing-list-api&quot;,&quot;owner&quot;:{},&quot;projectNumber&quot;:503672515986,&quot;retentionPolicy&quot;:{},&quot;selfLink&quot;:&quot;https://www.googleapis.com/storage/v1/b/testing-list-api&quot;,&quot;storageClass&quot;:&quot;STANDARD&quot;,&quot;timeCreated&quot;:&quot;2023-02-09T15:38:33.688Z&quot;,&quot;updated&quot;:&quot;2023-02-09T15:38:33.688Z&quot;,&quot;versioning&quot;:{},&quot;website&quot;:{}},&quot;location&quot;:&quot;us&quot;},&quot;ancestors&quot;:[&quot;projects/503672515986&quot;],&quot;update_time&quot;:&quot;2023-02-09T15:38:33.688Z&quot;}\r\n```\r\n\r\n\r\nCurrently, here is the command I am running - \r\n```\r\ncat gcp_resources.ndjson | jq -r &#39;[.name,.asset_type,.resource.data.labels[]//&quot;null&quot;]|@csv&#39; &gt;&gt; filtered_data.txt\r\n```\r\n\r\nAnd here is the output I am seeing - \r\n```\r\n&quot;//storage.googleapis.com/testing-list-api&quot;,&quot;storage.googleapis.com/Bucket&quot;,&quot;gcs-bucket&quot;,&quot;api&quot;\r\n```\r\n\r\nHowever, I want to include the label keys along with their values and I want to print the headers on the first row, something like resource_name, asset_type, labels. So expected output would look like -\r\n```\r\nresource_name   asset_type    labels\r\n\r\n&quot;//storage.googleapis.com/testing-list-api&quot;,&quot;storage.googleapis.com/Bucket&quot;,&quot;application:gcs-bucket&quot;,&quot;testing:api&quot;\r\n```\r\n\r\nAny suggestions on how would I be able to do this?",
        "link": "https://stackoverflow.com/questions/75513381/how-do-i-include-key-and-value-pairs-in-jq-csv-output-from-a-nested-ndjson",
        "title": "How do I include key and value pairs in jq CSV output from a nested NDJSON?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq",
            "yq"
        ],
        "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": 1676929691,
                "post_id": 75514391,
                "comment_id": 133232665,
                "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": 1676929796,
                "post_id": 75514391,
                "comment_id": 133232701,
                "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": 1676929800,
                "post_id": 75514391,
                "comment_id": 133232703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1843562,
                    "reputation": 285,
                    "user_id": 1672461,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/f029619c4f701561c6c9416cb09d3407?s=256&d=identicon&r=PG",
                    "display_name": "Vetal",
                    "link": "https://stackoverflow.com/users/1672461/vetal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1676931453,
                "post_id": 75514391,
                "comment_id": 133233035,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1676930586,
                "last_edit_date": 1676930586,
                "creation_date": 1676930111,
                "answer_id": 75514501,
                "question_id": 75514391,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problems here go well beyond conversion to YAML: The original input JSON document is itself broken.\r\n\r\nIf you fix that, you&#39;ll be able to use it directly, without needing any conversion at all, because all valid JSON is also valid YAML; and you&#39;ll _also_ ensure that the output of any conversion to conventionally-formatted YAML is identical in meaning (if not choice of syntax) to the document you actually want.\r\n\r\n- When you double up single quotes in bash (in either an unquoted context or a single-quoted context), they cancel each other out; `&#39;&#39;foo&#39;&#39;` in bash is exactly the same as `foo`.\r\n- When you put single quotes at the front and end of your argument passed as `-c`, you&#39;re specifying to the shell that the entire command is one word (aka the name of an executable). That&#39;s clearly not true, and it&#39;s going to cause a `command not found` error.\r\n- When you expand `$tokens_file` without _syntactic_ quotes around the expansion (to be syntactic, the quotes need to be in the shell-language source code, **not in the variable&#39;s value!**), that variable is word-split into separate values.\r\n- Your environment variable has _literal_ quotes in the value of your .kube token, but only _syntactic_ quotes are appropriate there. When you add literal quotes, the software is looking for a filename with `&quot;` characters **in the name itself**.\r\n\r\nA corrected version of your document might look like:\r\n\r\n```json\r\n{\r\n  &quot;exec&quot;: {\r\n    &quot;apiVersion&quot;: &quot;client.authentication.k8s.io/v1beta1&quot;,\r\n    &quot;args&quot;: [\r\n      &quot;-c&quot;,\r\n      &quot;sops --decrypt \\&quot;${tokens_file}\\&quot; | jq -cM &#39;{\\&quot;kind\\&quot;: \\&quot;ExecCredential\\&quot;, \\&quot;apiVersion\\&quot;: \\&quot;client.authentication.k8s.io/v1beta1\\&quot;, \\&quot;spec\\&quot;: {}, \\&quot;status\\&quot; : {\\&quot;token\\&quot;:.tokens[$ENV.context]}}&#39;&quot;\r\n    ],\r\n    &quot;command&quot;: &quot;bash&quot;,\r\n    &quot;env&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;context&quot;,\r\n        &quot;value&quot;: &quot;utility&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;tokens_file&quot;,\r\n        &quot;value&quot;: &quot;/home/some-user/.kube/tokens with space in name.enc.json&quot;\r\n      }\r\n    ]\r\n  }\r\n}",
                "title": "yq, adding single quotes on json values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1676936958,
        "creation_date": 1676929210,
        "last_edit_date": 1676936958,
        "question_id": 75514391,
        "body_markdown": "I have a shell variable with the following JSON string:\r\n\r\n```shell\r\necho &quot;${user_part}&quot;\r\n\r\n{\r\n  &quot;exec&quot;: {\r\n    &quot;apiVersion&quot;: &quot;client.authentication.k8s.io/v1beta1&quot;,\r\n    &quot;args&quot;: [\r\n      &quot;-c&quot;,\r\n      &quot;&#39;sops --decrypt ${tokens_file} | jq -cM &#39;&#39;{\\&quot;kind\\&quot;: \\&quot;ExecCredential\\&quot;, \\&quot;apiVersion\\&quot;: \\&quot;client.authentication.k8s.io/v1beta1\\&quot;, \\&quot;spec\\&quot;: {}, \\&quot;status\\&quot; : {\\&quot;token\\&quot;:.tokens[$ENV.context]}}&#39;&#39;&#39;&quot;\r\n    ],\r\n    &quot;command&quot;: &quot;bash&quot;,\r\n    &quot;env&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;context&quot;,\r\n        &quot;value&quot;: &quot;utility&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;tokens_file&quot;,\r\n        &quot;value&quot;: &quot;\\&quot;/home/some-user/.kube/tokens with space in name.enc.json\\&quot;&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAfter yq is applied I&#39;ve got this:\r\n\r\n```shell\r\necho &quot;${user_part}&quot; | yq --prettyPrint\r\n\r\nexec:\r\n  apiVersion: client.authentication.k8s.io/v1beta1\r\n  args:\r\n    - -c\r\n    - &#39;&#39;&#39;sops --decrypt ${tokens_file} | jq -cM &#39;&#39;&#39;&#39;{&quot;kind&quot;: &quot;ExecCredential&quot;, &quot;apiVersion&quot;: &quot;client.authentication.k8s.io/v1beta1&quot;, &quot;spec&quot;: {}, &quot;status&quot; : {&quot;token&quot;:.tokens[$ENV.context]}}&#39;&#39;&#39;&#39;&#39;&#39;&#39;\r\n  command: bash\r\n  env:\r\n    - name: context\r\n      value: utility\r\n    - name: tokens_file\r\n      value: &#39;&quot;/home/some-user/.kube/tokens with space in name.enc.json&quot;&#39;\r\n```\r\n\r\nDesired result:\r\n\r\n```yaml\r\nexec:\r\n  apiVersion: client.authentication.k8s.io/v1beta1\r\n  args:\r\n    - -c\r\n    - &#39;sops --decrypt ${tokens_file} | jq -cM &#39;&#39;{&quot;kind&quot;: &quot;ExecCredential&quot;, &quot;apiVersion&quot;: &quot;client.authentication.k8s.io/v1beta1&quot;, &quot;spec&quot;: {}, &quot;status&quot; : {&quot;token&quot;:.tokens[$ENV.context]}}&#39;&#39;&#39;\r\n  command: bash\r\n  env:\r\n    - name: context\r\n      value: utility\r\n    - name: tokens_file\r\n      value: &quot;/home/some-user/.kube/tokens with space in name.enc.json&quot;\r\n\r\n```\r\n\r\nSo, values are passed as is without single quotes added in these:\r\n\r\n - `.exec.args[1]`\r\n - `.exec.env[1].value`\r\n\r\nExactly to content in json.\r\n\r\nHow to switch off this single quote escaping entirely, without specifying custom conversion on specific elements by yq?\r\n\r\nRemoving escaped double quotes in the second case leaving the string completely unquoted by YQ:\r\n\r\n` &quot;value&quot;: &quot;/home/some-user/.kube/tokens with space in name.enc.json&quot;` =&gt; `value: /home/some-user/.kube/tokens with space in name.enc.json` in YAML. Which is not what is needed\r\n\r\n\r\n-------------------------\r\nAdded based on comments:\r\n\r\nThis all is part of &quot;synthetic&quot; kubectl config file.\r\n\r\nI&#39;ve had first version manually crafted:\r\n\r\n```json\r\nusers:\r\n  - name: utility\r\n    user:\r\n      exec:\r\n        apiVersion: client.authentication.k8s.io/v1beta1\r\n        args: [&quot;-c&quot;, &quot;sops --decrypt ${tokens_file} | jq -cM &#39;{\\&quot;kind\\&quot;: \\&quot;ExecCredential\\&quot;, \\&quot;apiVersion\\&quot;: \\&quot;client.authentication.k8s.io/v1beta1\\&quot;, \\&quot;spec\\&quot;: {}, \\&quot;status\\&quot; : {\\&quot;token\\&quot;:.tokens[$ENV.context]}}&#39;&quot;]\r\n        command: bash\r\n        env:\r\n          - name: context\r\n            value: &quot;utility&quot;\r\n          - name: tokens_file\r\n            value: &quot;/home/some-user/.kube/tokens with space in name.enc.json&quot;\r\n```\r\n\r\nWhich worked fine, and so is a fragment in &quot;desired&quot; section\r\n\r\nWhat is in the original, single-quoted example, is kubectl-updated fragment once I changed the context or namespace (Kubernetes). And is what kubectl reprocessed yaml file is\r\n\r\nI presumed this single-quoted version, produced and consumable by kubectl is more appealing, hence no inner json quote escaping in inner single quotes. But as you said, might not be by-the-book\r\n\r\nWhile multi-quoted, &quot;past-yq&quot; errors out:\r\n\r\n```shell \r\nkubectl get namespace\r\nbash: line 1: sops --decrypt ${tokens_file} | jq -cM {&quot;kind&quot;: &quot;ExecCredential&quot;, &quot;apiVersion&quot;: &quot;client.authentication.k8s.io/v1beta1&quot;, &quot;spec&quot;: {}, &quot;status&quot; : {&quot;token&quot;:.tokens[$ENV.context]}}: No such file or directory\r\nUnable to connect to the server: getting credentials: exec: executable bash failed with exit code 127\r\n\r\n```\r\n\r\nRemoving quotes to &quot;desired&quot; state makes it working, so I used it as success criteria",
        "link": "https://stackoverflow.com/questions/75514391/yq-adding-single-quotes-on-json-values",
        "title": "yq, adding single quotes on json values"
    },
    {
        "tags": [
            "json",
            "jq",
            "minify"
        ],
        "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": 2,
                "creation_date": 1677003233,
                "post_id": 75524357,
                "comment_id": 133249825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10129017,
                    "reputation": 9599,
                    "user_id": 7483211,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-cKWRGsZijfQ/AAAAAAAAAAI/AAAAAAAAEKw/CCxhG0ejwDM/s256-rj/photo.jpg",
                    "display_name": "Cornelius Roemer",
                    "link": "https://stackoverflow.com/users/7483211/cornelius-roemer"
                },
                "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": 2,
                "creation_date": 1694116232,
                "post_id": 75524357,
                "comment_id": 135852641,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1721907211,
                "last_edit_date": 1721907211,
                "creation_date": 1677003645,
                "answer_id": 75524443,
                "question_id": 75524357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One workaround is to use another tool, e.g. [`jj`][1], which does the job perfectly, and probably also faster in general, even if `jq` doesn&#39;t error.\r\n\r\n```sh\r\njj -u &lt;input.json &gt;minified.json\r\n```\r\n\r\nBinaries available at: https://github.com/tidwall/jj/releases/latest or via homebrew:\r\n```sh\r\nbrew install tidwall/jj/jj\r\n```\r\n\r\n\r\n  [1]: https://github.com/tidwall/jj",
                "title": "How to increase depth limit of jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677132826,
                "last_edit_date": 1677132826,
                "creation_date": 1677005786,
                "answer_id": 75524782,
                "question_id": 75524357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Regarding the C implementation, you&#39;d have to remake the binary after changing MAX_PARSING_DEPTH in jv_parse.c, in which the relevant line is currently:\r\n\r\n    #define MAX_PARSING_DEPTH (256)\r\n\r\nAs best I can tell, there does not seem to be any downside to increasing the limit to a very large number.\r\n",
                "title": "How to increase depth limit of jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677134813,
                "creation_date": 1677134813,
                "answer_id": 75541414,
                "question_id": 75524357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "gojq (the Go implementation of jq) has a limit on the maximum depth it can handle: it&#39;s greater than 1,024 but less than 10,000.\r\n\r\nI&#39;ve verified that [tag:jj] and my &quot;JSON Machine&quot;-based utility, [jm][1], can both handle a depth of 10,000. The following are equivalent ways of compactifying a JSON document, at least if the limit isn&#39;t breached:\r\n```\r\n   jj -u @this &lt; input.json\r\n   jm input.json\r\n```\r\n\r\n\r\n  [1]: https://github.com/pkoppstein/jm",
                "title": "How to increase depth limit of jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1749556418,
                "last_edit_date": 1749556418,
                "creation_date": 1748608325,
                "answer_id": 79645467,
                "question_id": 75524357,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re on a version lower than 1.8.0, upgrade `jq` to version 1.8.0 or higher (released June 2025).\r\n\r\nVersion 1.8 increased the depth limit from 256 to 10,000 which should work in most cases.",
                "title": "How to increase depth limit of jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 3,
        "last_activity_date": 1749556418,
        "creation_date": 1677003111,
        "question_id": 75524357,
        "body_markdown": "When trying to minify a deeply nested JSON file (~10k deep) using `jq` I got a parse error:\r\n```console\r\n$ jq -c . &lt;input.json &gt;minified.json\r\nparse error: Exceeds depth limit for parsing at line 227263, column 355\r\n```\r\n\r\nHow can I increase the depth limit? Is there a command line option? I couldn&#39;t find anything about this in the man page.",
        "link": "https://stackoverflow.com/questions/75524357/how-to-increase-depth-limit-of-jq",
        "title": "How to increase depth limit of jq?"
    },
    {
        "tags": [
            "yaml",
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1677020577,
                "last_edit_date": 1677020577,
                "creation_date": 1677007390,
                "answer_id": 75525006,
                "question_id": 75524947,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[mikefarah/yq](https://github.com/mikefarah/yq), the Go implementation of yq (which you are using) has its own rules of processing, which sometimes differ from how jq would handle things. If you want vanilla jq experience on YAML files, use [the other implementation](https://stackoverflow.com/tags/yq/info) of yq, [kislyuk/yq](https://github.com/kislyuk/yq), which is just a wrapper on jq, written in Python. Using that, you&#39;d get:\r\n```sh\r\nyq -y &#39;.[] | .name as $n | {&quot;n&quot;: $n}&#39; test.yaml\r\n```\r\n```yaml\r\nn: Cathy\r\n---\r\nn: Bob\r\n```\r\n\r\nIf you want to keep using mikefarah/yq, use parens to explicate the context:\r\n```sh\r\nyq &#39;(.[] | .name) as $n | {&quot;n&quot;: $n}&#39; test.yaml\r\n```\r\n```yaml\r\nn: Cathy\r\nn: Bob\r\n```\r\nAnd if you want to include document separators with mikefarah/yq, append `split_doc`:\r\n```sh\r\nyq &#39;(.[] | .name) as $n | {&quot;n&quot;: $n} | split_doc&#39; test.yaml\r\n```\r\n```yaml\r\nn: Cathy\r\n---\r\nn: Bob\r\n```\r\n\r\nAs you can imagine from seeing the outputs, these are not the only differences between the two implementations. Generally speaking, mikefarah/yq is more versatile as it reaches out to YAML features that are not representable in JSON, and hence kislyuk/yq wouldn&#39;t cover them. On the flipside, this makes coding with mikefarah/yq less succinct than it is with plain jq used by kislyuk/yq.\r\n\r\nHere&#39;s yet another one to try: [itchyny/gojq](https://github.com/itchyny/gojq) is a Go rewrite of jq which can also handle YAML inputs and YAML outputs.\r\n```sh\r\ngojq --yaml-input --yaml-output &#39;.[] | .name as $n | {&quot;n&quot;: $n}&#39; test.yaml\r\n```\r\n```yaml\r\n&quot;n&quot;: Cathy\r\n---\r\n&quot;n&quot;: Bob\r\n```\r\n\r\n---\r\n\r\nEDIT: As it [turned out](https://stackoverflow.com/questions/75524947/using-a-variable-when-traversing-an-array-with-yq-causes-strange-behaviour#comment133252138_75525006), the variable was believed to be necessary to keep reference when loading a file whose path was part of the context, while data from the loaded file&#39;s contents should be merged with other parts of the original context. Specifically, the attempt looked like\r\n```sh\r\n# fails with mikefarah/yq\r\nyq &#39;.[] | load(.path) as $x | {&quot;a&quot;: $x.a, &quot;b&quot;: $x.b, &quot;c&quot;: .c}&#39; test.yaml\r\n```\r\nBut the loading and merging can be achieved by making use of different (nested) context levels, and as such with using no variable bindings at all. While loading and extracting the external file is performed in a parens-enclosed subcontext, by being itself embedded into the original iteration context, the merging can then be achieved by simple addition (if the parts do not collide), or an intermediate array otherwise. In any case, the resulting entity can then be reshaped at will.\r\n```sh\r\n# works with mikefarah/yq\r\nyq &#39;.[] | (load(.path) | {&quot;a&quot;: .a, &quot;b&quot;: .b}) + {&quot;c&quot;: .c}&#39; test.yaml\r\n```\r\n",
                "title": "Using a variable when traversing an array with yq causes strange behaviour"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1677020577,
        "creation_date": 1677006928,
        "last_edit_date": 1677013440,
        "question_id": 75524947,
        "body_markdown": "Consider a file `test.yaml`:\r\n\r\n    - name: Cathy\r\n      has: apples\r\n    - name: Bob\r\n      has: bananas\r\n\r\nand a request:\r\n\r\n    yq &#39;.[] | .name as $n | {&quot;n&quot;: $n}&#39; test.yaml\r\n\r\nthe output is:\r\n\r\n    n: Cathy\r\n    n: Bob\r\n    n: Cathy\r\n    n: Bob\r\n\r\nwhich looks strange, because I expect only two values. Also when I use only a value of the variable with no expression:\r\n\r\n    yq &#39;.[] | .name as $n | $n&#39; test.yaml\r\n    \r\nit works ok:\r\n\r\n    Cathy\r\n    Bob\r\n\r\nAny advice how to use a variable for traversing arrays?\r\n\r\nP. S. In `jq` the command\r\n\r\n    echo &#39;{&quot;list&quot;: [{&quot;name&quot;: &quot;Cathy&quot;, &quot;has&quot;: &quot;apples&quot;}, {&quot;name&quot;: &quot;Bob&quot;, &quot;has&quot;: &quot;bananas&quot;}]}&#39; | jq &#39;.list[] | .name as $n | {&quot;n&quot;: $n}&#39;\r\n\r\nworks as expected",
        "link": "https://stackoverflow.com/questions/75524947/using-a-variable-when-traversing-an-array-with-yq-causes-strange-behaviour",
        "title": "Using a variable when traversing an array with yq causes strange behaviour"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1677051665,
                "post_id": 75529330,
                "comment_id": 133258887,
                "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": 1677051971,
                "post_id": 75529330,
                "comment_id": 133258972,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677062066,
                "last_edit_date": 1677062066,
                "creation_date": 1677052273,
                "answer_id": 75529613,
                "question_id": 75529330,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To go from your given input to the given output, construct a new object with the [`{}` filter](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) defining a single property which has the full input array (via [identity `.`](https://stedolan.github.io/jq/manual/#Identity:.) filter) as value:\r\n\r\n```\r\n{ Objects: . }\r\n```\r\n\r\nIf the key&#39;s name itself is variable, you can define a variable to be used by jq:\r\n\r\n```\r\njq --arg key Objects &#39;{ $key: . }&#39; input.json &gt; output.json\r\n```",
                "title": "Append string to json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1677062066,
        "creation_date": 1677050363,
        "question_id": 75529330,
        "body_markdown": "\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\nHow can i append a string to existing json or re-write to new json.\r\n\r\nHere is my existing json\r\n\r\n```\r\n[\r\n      {\r\n        &quot;Robin&quot;: &quot;id1&quot;\r\n      },\r\n      {\r\n        &quot;John&quot;: &quot;id2&quot;\r\n      },\r\n      {\r\n        &quot;Jane&quot;: &quot;id3&quot;\r\n      }\r\n    ]\r\n```\r\nThe expected json is \r\n```\r\n{\r\n&quot;Objects&quot;:\r\n[\r\n      {\r\n        &quot;Robin&quot;: &quot;id1&quot;\r\n      },\r\n      {\r\n        &quot;John&quot;: &quot;id2&quot;\r\n      },\r\n      {\r\n        &quot;Jane&quot;: &quot;id3&quot;\r\n      }\r\n    ]\r\n}\r\n```\r\ni looked at some existing posts w.r.t jq, however they are not helping as string intended to append has double quotes in it. can some one help me?   ",
        "link": "https://stackoverflow.com/questions/75529330/append-string-to-json-using-jq",
        "title": "Append string to json using jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq",
            "unique"
        ],
        "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": 1677053503,
                "post_id": 75529770,
                "comment_id": 133259379,
                "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": 1677053642,
                "post_id": 75529770,
                "comment_id": 133259414,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677060808,
                "last_edit_date": 1677060808,
                "creation_date": 1677054112,
                "answer_id": 75529901,
                "question_id": 75529770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`unique` works with complex objects too and does not require simple strings. Thus, you can simple dedupe the objects in the array, then stream their ids:\r\n\r\n```\r\n.root.elements | unique[].id\r\n```\r\n\r\nNote that `unique[].id` is just shorthand for `unique[] | .id` which in turn is shorthand for `unique | .[] | .id`.\r\n\r\n*****\r\n\r\nAlternatively, [`map`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) the array to a new array consisting only of ids, dedupe and then stream:\r\n\r\n```\r\n.root.elements | map(.id) | unique[]\r\n```",
                "title": "jq sort and remove duplicates from output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677073824,
        "creation_date": 1677053202,
        "last_edit_date": 1677073824,
        "question_id": 75529770,
        "body_markdown": "I have following json structure \r\n\r\n      { \r\n         &quot;root&quot;: {\r\n           &quot;elements&quot;: [\r\n               {\r\n                 &quot;id&quot;: &quot;abcd&quot;\r\n               },\r\n               {\r\n                 &quot;id&quot;: &quot;efgh&quot;\r\n               },\r\n               {\r\n                 &quot;id&quot;: &quot;abcd&quot;\r\n               }\r\n           ]\r\n         }\r\n      } \r\n\r\nI need to dump values of id fields, alphabetically sorted and without duplicates.\r\n\r\ndesired output: \r\n```\r\nabcd\r\nefgh\r\n```\r\n\r\n`jq &#39;.root.elements[].id&#39;` - will dump me data i need\r\n\r\ni found &#39;unique&#39; jq command should do both - sorting and removing duplicates - but after some testing i found out that it requires an array of strings/numbers but here im working with array of objects instead\r\n\r\ni would like to have this os independent, i cannot use unix utlities like sort and unique",
        "link": "https://stackoverflow.com/questions/75529770/jq-sort-and-remove-duplicates-from-output",
        "title": "jq sort and remove duplicates from output"
    },
    {
        "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": 0,
                "creation_date": 1677081530,
                "post_id": 75535200,
                "comment_id": 133267945,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1640952,
                    "reputation": 7501,
                    "user_id": 1513388,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/a235aa59e48586dcab866c685d042874?s=256&d=identicon&r=PG",
                    "display_name": "user1513388",
                    "link": "https://stackoverflow.com/users/1513388/user1513388"
                },
                "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": 1677082081,
                "post_id": 75535200,
                "comment_id": 133268130,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677082044,
                "creation_date": 1677082044,
                "answer_id": 75535318,
                "question_id": 75535200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a  `join` function:\r\n\r\n```bash\r\ncmd=$(jq -r &#39;. | join(&quot;&quot;)&#39; data.json)\r\n\r\n# To execute it\r\neval $cmd\r\n```\r\n\r\nStandard security warning about `eval`: they can execute any command, so make sure you trust the input source.",
                "title": "Parsing an array of strings with JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677082160,
                "creation_date": 1677082160,
                "answer_id": 75535345,
                "question_id": 75535200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just run `add` on the array, use `-r` for raw output (i.e. no escapes):\r\n\r\n    jq -r &#39;add&#39; file.json\r\n",
                "title": "Parsing an array of strings with JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677082503,
                "creation_date": 1677082503,
                "answer_id": 75535405,
                "question_id": 75535200,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the lines already contain their newline symbols, you could instruct jq to omit its owns by using the `-j` option:\r\n```sh\r\njq -j &#39;.[]&#39; file.json\r\n```\r\n```\r\nnewcert \\\r\n    --cn server1.acme.com \\\r\n    --san-dns server1.acme.com \\\r\n    --key-file ./config/key.pem \\\r\n    --csr-file ./config/csr.pem \\\r\n    --no-prompt \\\r\n```",
                "title": "Parsing an array of strings with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1677082503,
        "creation_date": 1677081370,
        "last_edit_date": 1677082230,
        "question_id": 75535200,
        "body_markdown": "I have a JSON structure that looks like this, it&#39;s essentially a bash shell command stored in JSON. Is there a way in jq to map this data back to multiline string ? \r\n\r\n```\r\n[\r\n  &quot;newcert \\\\\\n&quot;,\r\n  &quot;    --cn server1.acme.com \\\\\\n&quot;,\r\n  &quot;    --san-dns server1.acme.com \\\\\\n&quot;,\r\n  &quot;    --key-file ./config/key.pem \\\\\\n&quot;,\r\n  &quot;    --csr-file ./config/csr.pem \\\\\\n&quot;,\r\n  &quot;    --no-prompt \\\\\\n&quot;\r\n]\r\n```\r\n\r\nI need to map it back to a string that looks like this: \r\n\r\n```\r\n  newcert \\\r\n      --cn server1.acme.com \\\r\n      --san-dns server1.acme.com \\\r\n      --key-file ./config/key.pem \\\r\n      --csr-file ./config/csr.pem \\\r\n      --no-prompt \\\r\n```",
        "link": "https://stackoverflow.com/questions/75535200/parsing-an-array-of-strings-with-jq",
        "title": "Parsing an array of strings with JQ"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677090278,
                "post_id": 75536682,
                "comment_id": 133270678,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677090927,
                "post_id": 75536682,
                "comment_id": 133270835,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5225716,
                    "reputation": 3975,
                    "user_id": 4177828,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GHCgC.jpg?s=256",
                    "display_name": "ufopilot",
                    "link": "https://stackoverflow.com/users/4177828/ufopilot"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677092754,
                "post_id": 75536682,
                "comment_id": 133271359,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1677097753,
                "post_id": 75536682,
                "comment_id": 133272668,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "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": 0,
                "creation_date": 1677101593,
                "post_id": 75536682,
                "comment_id": 133273794,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677101703,
                "last_edit_date": 1677101703,
                "creation_date": 1677090364,
                "answer_id": 75536767,
                "question_id": 75536682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "#### With some Unix* pipes. Works also with your broken JSON, unlike the other answers\r\n\r\n`grep` and `regex` are _universal_. `gron` makes the things sufficiently *atomic* to be able to use `grep` _the reliable way_.\r\n\r\nFor simple task, `jq` is the way to go, but if you need &gt; 10 mn to find the good syntax, `gron` is a very nice tool to have in the _toolchest_.\r\n\r\nThe reason to use this, is that I refuse to go too deeper with [tag:jq]. If you need to know another &#39;language&#39; for each type of structured data files, it&#39;s a mess. I prefer simpler/shorter solutions. Here one:\r\n\r\n    $ yq . file.json | gron | grep -oP &#39;configMapRef\\.name = &quot;\\K[^&quot;]+&#39; \r\n    db-mssql-asd-connection\r\n    db-postgre-asd-connection\r\n    app-url\r\n\r\nI use `yq`, because it&#39;s less strict than `gron` and `jq`:\r\n\r\n    $ jq . file.json\r\n    parse error: Expected another key-value pair at line 7, column 9\r\n\r\nand\r\n\r\n    $ gron file.json\r\n    failed to form statements: invalid character &#39;}&#39; looking for beginning of object key string\r\n\r\nIf the `json` was better formatted, I was able to wrote:\r\n\r\n    gron &#39;https://gist.githubusercontent.com/sputnick-dev/7da057b951c182785dfb837194388350/raw/eaf064c6b44c8304e111fa4e6ee3638d47a4ef48/object.json&#39; |\r\n        grep -oP &#39;configMapRef\\.name = &quot;\\K[^&quot;]+&#39;\r\n\r\n - Python [`yg`](https://github.com/kislyuk/yq) works also with... \r\n - golang [`yq`](https://github.com/mikefarah/yq)\r\n - [`gron`](https://github.com/tomnomnom/gron) _Make JSON greppable!_ ",
                "title": "jq - how to get all the values from a object within object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677093874,
                "last_edit_date": 1677093874,
                "creation_date": 1677090889,
                "answer_id": 75536855,
                "question_id": 75536682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "##### The jq part\r\nThe way you are using `select` isn&#39;t productive. `select` emits either nothing (in which case that particular pipe branch dies), or its whole input (in which case you&#39;d still need to descend into `.configMapRef` yourself). My suggestion is to unconditionally descend into it (and into `.name` as well), which may produce `null` values in the otherwise dying branches. You can filter them out either explicitly by using the alternative operator `//` with `empty`, or directly selecting either all non-null `| values` or, more constrainingly, only `| strings`. Either way, use the `-r` option to output raw text (instead of JSON):\r\n```\r\njq -r &#39;.spec.template.spec.containers[].envFrom[].configMapRef.name // empty&#39; file.json\r\n```\r\n```\r\njq -r &#39;.spec.template.spec.containers[].envFrom[].configMapRef.name | values&#39; file.json\r\n```\r\n```\r\njq -r &#39;.spec.template.spec.containers[].envFrom[].configMapRef.name | strings&#39; file.json\r\n```\r\n```\r\ndb-mssql-asd-connection\r\ndb-postgre-asd-connection\r\napp-url\r\n```\r\n\r\n##### The bash loop part\r\nThere are ways to escape the output (search for `@sh`) and to format it e.g. to fit to a `declare` statement ([example](https://stackoverflow.com/a/75088434/2158479)), which will generate an indexed bash array. But in this case, it&#39;d be simpler to just iterate over the lines output:\r\n```sh\r\nwhile read -r line\r\ndo … &quot;$line&quot; …\r\ndone &lt; &lt;(jq -r &#39;…&#39; file.json)\r\n```",
                "title": "jq - how to get all the values from a object within object"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677090984,
                "creation_date": 1677090984,
                "answer_id": 75536871,
                "question_id": 75536682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just select the `envFrom` objects that `has` the property, then get the desired property in the final result.\r\n\r\n```\r\n$ jq -r &#39;.spec.template.spec.containers[].envFrom[]\r\n  | select(has(&quot;configMapRef&quot;)).configMapRef.name&#39; file.json\r\ndb-mssql-asd-connection\r\ndb-postgre-asd-connection\r\napp-url\r\n\r\n```",
                "title": "jq - how to get all the values from a object within object"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1677092644,
                "last_edit_date": 1677092644,
                "creation_date": 1677091912,
                "answer_id": 75537010,
                "question_id": 75536682,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq -r &#39;.spec.template.spec.containers[].envFrom[].configMapRef|select( . != null )|.name&#39; file.json\r\n    db-mssql-asd-connection\r\n    db-postgre-asd-connection\r\n    app-url\r\n    \r\n    Using AWK\r\n    $ awk -F&#39;&quot;&#39; &#39;/configMapRef/{getline; print $--NF}&#39; &lt;(json_pp &lt;file.json) \r\n    $ awk -F&#39;&quot;&#39; &#39;/configMapRef/{getline; print $--NF}&#39; &lt;(jq -r . file.json)\r\n    db-mssql-asd-connection\r\n    db-postgre-asd-connection\r\n    app-url\r\n        ",
                "title": "jq - how to get all the values from a object within object"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1677101703,
        "creation_date": 1677089893,
        "question_id": 75536682,
        "body_markdown": "I have the following json object.\r\n\r\n```\r\n{\r\n    &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n    &quot;kind&quot;: &quot;Deployment&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;annotations&quot;: {\r\n            &quot;deployment.kubernetes.io/revision&quot;: &quot;1&quot;,\r\n        },\r\n        &quot;creationTimestamp&quot;: &quot;2023-02-22T17:35:22Z&quot;,\r\n        &quot;generation&quot;: 1,\r\n        &quot;labels&quot;: {\r\n            &quot;app&quot;: &quot;addresses&quot;,\r\n            &quot;group&quot;: &quot;de.test&quot;,\r\n            &quot;provider&quot;: &quot;jkube&quot;,\r\n            &quot;version&quot;: &quot;2.3.0-3191&quot;\r\n        },\r\n        &quot;name&quot;: &quot;addresses&quot;,\r\n        &quot;namespace&quot;: &quot;linkerd&quot;,\r\n        &quot;resourceVersion&quot;: &quot;910972&quot;,\r\n        &quot;uid&quot;: &quot;aaee0eb0-5d66-44dd-b9b0-35e17bec4cf4&quot;\r\n    },\r\n    &quot;spec&quot;: {\r\n        &quot;progressDeadlineSeconds&quot;: 600,\r\n        &quot;replicas&quot;: 1,\r\n        &quot;revisionHistoryLimit&quot;: 2,\r\n        &quot;selector&quot;: {\r\n            &quot;matchLabels&quot;: {\r\n                &quot;app&quot;: &quot;addresses&quot;,\r\n                &quot;group&quot;: &quot;de.test&quot;,\r\n                &quot;provider&quot;: &quot;jkube&quot;\r\n            }\r\n        },\r\n        &quot;strategy&quot;: {\r\n            &quot;rollingUpdate&quot;: {\r\n                &quot;maxSurge&quot;: 1,\r\n                &quot;maxUnavailable&quot;: &quot;50%&quot;\r\n            },\r\n            &quot;type&quot;: &quot;RollingUpdate&quot;\r\n        },\r\n        &quot;template&quot;: {\r\n            &quot;metadata&quot;: {\r\n                &quot;annotations&quot;: {\r\n                    &quot;jkube.io/git-branch&quot;: &quot;develop&quot;,\r\n                    &quot;jkube.io/git-commit&quot;: &quot;77aaca38564dffff0ce10a8c70d4139b33f677b2&quot;,\r\n                    &quot;jkube.io/git-url&quot;: &quot;http://bitbucket.org/testzentrale/test-monorepo&quot;,\r\n                    &quot;jkube.io/scm-tag&quot;: &quot;HEAD&quot;,\r\n                    &quot;jkube.io/scm-url&quot;: &quot;https://bitbucket.org/testzentrale/test-monorepo/test/addresses&quot;\r\n                },\r\n                &quot;creationTimestamp&quot;: null,\r\n                &quot;labels&quot;: {\r\n                    &quot;app&quot;: &quot;addresses&quot;,\r\n                    &quot;group&quot;: &quot;de.test&quot;,\r\n                    &quot;provider&quot;: &quot;jkube&quot;,\r\n                    &quot;version&quot;: &quot;2.3.0-3191&quot;\r\n                },\r\n                &quot;namespace&quot;: &quot;test-testing&quot;\r\n            },\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;SENTRY_ENVIRONMENT&quot;,\r\n                                &quot;valueFrom&quot;: {\r\n                                    &quot;fieldRef&quot;: {\r\n                                        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n                                        &quot;fieldPath&quot;: &quot;metadata.namespace&quot;\r\n                                    }\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;SENTRY_SERVERNAME&quot;,\r\n                                &quot;valueFrom&quot;: {\r\n                                    &quot;fieldRef&quot;: {\r\n                                        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n                                        &quot;fieldPath&quot;: &quot;metadata.name&quot;\r\n                                    }\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;SENTRY_TAGS&quot;,\r\n                                &quot;value&quot;: &quot;service:addresses&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;SENTRY_RELEASE&quot;,\r\n                                &quot;value&quot;: &quot;2.3.0-3191&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;JAVA_OPTIONS&quot;,\r\n                                &quot;value&quot;: &quot;-Xms64m -Xmx384m&quot;\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;KUBERNETES_NAMESPACE&quot;,\r\n                                &quot;valueFrom&quot;: {\r\n                                    &quot;fieldRef&quot;: {\r\n                                        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n                                        &quot;fieldPath&quot;: &quot;metadata.namespace&quot;\r\n                                    }\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;name&quot;: &quot;HOSTNAME&quot;,\r\n                                &quot;valueFrom&quot;: {\r\n                                    &quot;fieldRef&quot;: {\r\n                                        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n                                        &quot;fieldPath&quot;: &quot;metadata.name&quot;\r\n                                    }\r\n                                }\r\n                            }\r\n                        ],\r\n                        &quot;envFrom&quot;: [\r\n                            {\r\n                                &quot;configMapRef&quot;: {\r\n                                    &quot;name&quot;: &quot;db-mssql-asd-connection&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;secretRef&quot;: {\r\n                                    &quot;name&quot;: &quot;db-mssql-asd-connection&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;configMapRef&quot;: {\r\n                                    &quot;name&quot;: &quot;db-postgre-asd-connection&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;secretRef&quot;: {\r\n                                    &quot;name&quot;: &quot;db-postgre-asd-connection&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;configMapRef&quot;: {\r\n                                    &quot;name&quot;: &quot;app-url&quot;\r\n                                }\r\n                            },\r\n                            {\r\n                                &quot;secretRef&quot;: {\r\n                                    &quot;name&quot;: &quot;app-token&quot;\r\n                                }\r\n                            }                                                      \r\n                        ],\r\n                        &quot;image&quot;: &quot;myrepo/test/addresses:testing-2.3.0-3191&quot;,\r\n                        &quot;imagePullPolicy&quot;: &quot;IfNotPresent&quot;,\r\n                        &quot;livenessProbe&quot;: {\r\n                            &quot;failureThreshold&quot;: 3,\r\n                            &quot;httpGet&quot;: {\r\n                                &quot;path&quot;: &quot;/&quot;,\r\n                                &quot;port&quot;: 8080,\r\n                                &quot;scheme&quot;: &quot;HTTP&quot;\r\n                            },\r\n                            &quot;initialDelaySeconds&quot;: 300,\r\n                            &quot;periodSeconds&quot;: 10,\r\n                            &quot;successThreshold&quot;: 1,\r\n                            &quot;timeoutSeconds&quot;: 1\r\n                        },\r\n                        &quot;name&quot;: &quot;spring-boot&quot;,\r\n                        &quot;ports&quot;: [\r\n                            {\r\n                                &quot;containerPort&quot;: 8080,\r\n                                &quot;name&quot;: &quot;http&quot;,\r\n                                &quot;protocol&quot;: &quot;TCP&quot;\r\n                            },\r\n                            {\r\n                                &quot;containerPort&quot;: 9779,\r\n                                &quot;name&quot;: &quot;prometheus&quot;,\r\n                                &quot;protocol&quot;: &quot;TCP&quot;\r\n                            },\r\n                            {\r\n                                &quot;containerPort&quot;: 8778,\r\n                                &quot;name&quot;: &quot;jolokia&quot;,\r\n                                &quot;protocol&quot;: &quot;TCP&quot;\r\n                            }\r\n                        ],\r\n                        &quot;readinessProbe&quot;: {\r\n                            &quot;failureThreshold&quot;: 2,\r\n                            &quot;httpGet&quot;: {\r\n                                &quot;path&quot;: &quot;/actuator/health&quot;,\r\n                                &quot;port&quot;: 8080,\r\n                                &quot;scheme&quot;: &quot;HTTP&quot;\r\n                            },\r\n                            &quot;initialDelaySeconds&quot;: 20,\r\n                            &quot;periodSeconds&quot;: 10,\r\n                            &quot;successThreshold&quot;: 1,\r\n                            &quot;timeoutSeconds&quot;: 1\r\n                        },\r\n                        &quot;resources&quot;: {\r\n                            &quot;limits&quot;: {\r\n                                &quot;memory&quot;: &quot;1000Mi&quot;\r\n                            },\r\n                            &quot;requests&quot;: {\r\n                                &quot;cpu&quot;: &quot;100m&quot;,\r\n                                &quot;memory&quot;: &quot;500Mi&quot;\r\n                            }\r\n                        },\r\n                        &quot;securityContext&quot;: {\r\n                            &quot;privileged&quot;: false\r\n                        },\r\n                        &quot;terminationMessagePath&quot;: &quot;/dev/termination-log&quot;,\r\n                        &quot;terminationMessagePolicy&quot;: &quot;File&quot;,\r\n                        &quot;volumeMounts&quot;: [\r\n                            {\r\n                                &quot;mountPath&quot;: &quot;/deployments/config&quot;,\r\n                                &quot;name&quot;: &quot;config&quot;\r\n                            }\r\n                        ]\r\n                    }\r\n                ],\r\n                &quot;dnsPolicy&quot;: &quot;ClusterFirst&quot;,\r\n                &quot;restartPolicy&quot;: &quot;Always&quot;,\r\n                &quot;schedulerName&quot;: &quot;default-scheduler&quot;,\r\n                &quot;securityContext&quot;: {},\r\n                &quot;terminationGracePeriodSeconds&quot;: 30,\r\n                &quot;volumes&quot;: [\r\n                    {\r\n                        &quot;configMap&quot;: {\r\n                            &quot;defaultMode&quot;: 420,\r\n                            &quot;items&quot;: [\r\n                                {\r\n                                    &quot;key&quot;: &quot;application.properties&quot;,\r\n                                    &quot;path&quot;: &quot;application.properties&quot;\r\n                                }\r\n                            ],\r\n                            &quot;name&quot;: &quot;addresses&quot;\r\n                        },\r\n                        &quot;name&quot;: &quot;config&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    },\r\n    &quot;status&quot;: {\r\n        &quot;conditions&quot;: [\r\n            {\r\n                &quot;lastTransitionTime&quot;: &quot;2023-02-22T17:35:23Z&quot;,\r\n                &quot;lastUpdateTime&quot;: &quot;2023-02-22T17:35:23Z&quot;,\r\n                &quot;message&quot;: &quot;Deployment does not have minimum availability.&quot;,\r\n                &quot;reason&quot;: &quot;MinimumReplicasUnavailable&quot;,\r\n                &quot;status&quot;: &quot;False&quot;,\r\n                &quot;type&quot;: &quot;Available&quot;\r\n            },\r\n            {\r\n                &quot;lastTransitionTime&quot;: &quot;2023-02-22T17:45:24Z&quot;,\r\n                &quot;lastUpdateTime&quot;: &quot;2023-02-22T17:45:24Z&quot;,\r\n                &quot;message&quot;: &quot;ReplicaSet \\&quot;addresses-dd575cdc9\\&quot; has timed out progressing.&quot;,\r\n                &quot;reason&quot;: &quot;ProgressDeadlineExceeded&quot;,\r\n                &quot;status&quot;: &quot;False&quot;,\r\n                &quot;type&quot;: &quot;Progressing&quot;\r\n            }\r\n        ],\r\n        &quot;observedGeneration&quot;: 1,\r\n        &quot;replicas&quot;: 1,\r\n        &quot;unavailableReplicas&quot;: 1,\r\n        &quot;updatedReplicas&quot;: 1\r\n    }\r\n}\r\n\r\n```\r\n\r\nI need to extract all the `name` properties of the `configMapRef`\r\n\r\nSo I used the`jq` to extract like below:\r\n\r\n```\r\ncat file.json | jq &#39;.spec.template.spec.containers[].envFrom[] | select(.configMapRef) &#39;\r\n\r\n```\r\n\r\nAnd I get the below output:\r\n\r\n```\r\n{\r\n  &quot;configMapRef&quot;: {\r\n    &quot;name&quot;: &quot;db-mssql-asd-connection&quot;\r\n  }\r\n}\r\n{\r\n  &quot;configMapRef&quot;: {\r\n    &quot;name&quot;: &quot;db-postgre-asd-connection&quot;\r\n  }\r\n}\r\n{\r\n  &quot;configMapRef&quot;: {\r\n    &quot;name&quot;: &quot;app-url&quot;\r\n  }\r\n}\r\n```\r\n\r\nBut I need to get the `name` so my output looks like this:\r\n\r\n```\r\ndb-mssql-asd-connection\r\ndb-postgre-asd-connection\r\napp-url\r\n```\r\n\r\nI tried many things such as;\r\n\r\n```\r\n// not wokring\r\njq &#39;.spec.template.spec.containers[].envFrom[] | select(.configMapRef) | jq .name&#39;\r\n\r\n// not wokring\r\njq &#39;.spec.template.spec.containers[].envFrom[] | select(.configMapRef.name) | jq .name&#39;\r\n\r\n```\r\n\r\nAnd I want to store thee values as a `bash` array so I can iterate through them. Can someone please help me with this? \r\n",
        "link": "https://stackoverflow.com/questions/75536682/jq-how-to-get-all-the-values-from-a-object-within-object",
        "title": "jq - how to get all the values from a object within object"
    },
    {
        "tags": [
            "arrays",
            "json",
            "shell",
            "file",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677093274,
                "creation_date": 1677093274,
                "answer_id": 75537209,
                "question_id": 75537106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `-R` option to read in the markdown file as text, and the `--argfile` option to read in the JSON file. Then, `select` the nodes with path `.blocks[].text.text` and content `&quot;PR_DESCRIPTION&quot;`, and set their values to the markdown input, previously stored in a variable:\r\n```sh\r\n&lt; pr_body.txt jq -Rs --argfile json payload.json &#39;. as $md | $json\r\n  | (.blocks[].text.text | select(. == &quot;PR_DESCRIPTION&quot;)) = $md\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;text&quot;: &quot;Deployment started :rocket:&quot;,\r\n  &quot;blocks&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;header&quot;,\r\n      &quot;text&quot;: {\r\n        &quot;type&quot;: &quot;plain_text&quot;,\r\n        &quot;text&quot;: &quot;:computer:  Deployment release  :computer:&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;context&quot;,\r\n      &quot;elements&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;mrkdwn&quot;,\r\n          &quot;text&quot;: &quot;*${{ steps.date.outputs.date }} | STAGING*&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;divider&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;section&quot;,\r\n      &quot;text&quot;: {\r\n        &quot;type&quot;: &quot;mrkdwn&quot;,\r\n        &quot;text&quot;: &quot;### TITLE\\n\\n\\n**bold text**\\n\\n\\n- qsqds\\n- qsdqds\\n- qsdqsd\\n- qsdqsd\\n\\n1. qsdqsd\\n2. qsdqsd\\n3. qsdqsd\\n4. qsdqsd\\n\\n`some code here`\\n&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;divider&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;actions&quot;,\r\n      &quot;elements&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;button&quot;,\r\n          &quot;text&quot;: {\r\n            &quot;type&quot;: &quot;plain_text&quot;,\r\n            &quot;text&quot;: &quot;&#128688; Pipeline&quot;\r\n          },\r\n          &quot;url&quot;: &quot;${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;attachments&quot;: [\r\n    {\r\n      &quot;color&quot;: &quot;warning&quot;,\r\n      &quot;fields&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;Statut&quot;,\r\n          &quot;short&quot;: true,\r\n          &quot;value&quot;: &quot;Deploying ...&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to update JSON values in a nested JSON with array in Shell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677093274,
        "creation_date": 1677092571,
        "question_id": 75537106,
        "body_markdown": "I have a JSON file `payload.json`:\r\n```\r\n{\r\n   &quot;text&quot;:&quot;Deployment started :rocket:&quot;,\r\n   &quot;blocks&quot;:[\r\n      {\r\n         &quot;type&quot;:&quot;header&quot;,\r\n         &quot;text&quot;:{\r\n            &quot;type&quot;:&quot;plain_text&quot;,\r\n            &quot;text&quot;:&quot;:computer:  Deployment release  :computer:&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;type&quot;:&quot;context&quot;,\r\n         &quot;elements&quot;:[\r\n            {\r\n               &quot;type&quot;:&quot;mrkdwn&quot;,\r\n               &quot;text&quot;:&quot;*${{ steps.date.outputs.date }} | STAGING*&quot;\r\n            }\r\n         ]\r\n      },\r\n      {\r\n         &quot;type&quot;:&quot;divider&quot;\r\n      },\r\n      {\r\n         &quot;type&quot;:&quot;section&quot;,\r\n         &quot;text&quot;:{\r\n            &quot;type&quot;:&quot;mrkdwn&quot;,\r\n            &quot;text&quot;:&quot;PR_DESCRIPTION&quot;\r\n         }\r\n      },\r\n      {\r\n         &quot;type&quot;:&quot;divider&quot;\r\n      },\r\n      {\r\n         &quot;type&quot;:&quot;actions&quot;,\r\n         &quot;elements&quot;:[\r\n            {\r\n               &quot;type&quot;:&quot;button&quot;,\r\n               &quot;text&quot;:{\r\n                  &quot;type&quot;:&quot;plain_text&quot;,\r\n                  &quot;text&quot;:&quot;&#128688; Pipeline&quot;\r\n               },\r\n               &quot;url&quot;:&quot;${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}&quot;\r\n            }\r\n         ]\r\n      }\r\n   ],\r\n   &quot;attachments&quot;:[\r\n      {\r\n         &quot;color&quot;:&quot;warning&quot;,\r\n         &quot;fields&quot;:[\r\n            {\r\n               &quot;title&quot;:&quot;Statut&quot;,\r\n               &quot;short&quot;:true,\r\n               &quot;value&quot;:&quot;Deploying ...&quot;\r\n            }\r\n         ]\r\n      }\r\n   ]\r\n}\r\n```\r\nAnd a txt file `pr_body.txt`:\r\n\r\n```\r\n### TITLE\r\n\r\n\r\n**bold text**\r\n\r\n\r\n- qsqds\r\n- qsdqds\r\n- qsdqsd\r\n- qsdqsd\r\n\r\n1. qsdqsd\r\n2. qsdqsd\r\n3. qsdqsd\r\n4. qsdqsd\r\n\r\n`some code here`\r\n```\r\n\r\nMy goal is to replace `PR_DESCRIPTION` in `payload.json` with the formatted text in `pr_body.txt`\r\n\r\nIs it possible to do that using `jq`?\r\n\r\nI tried to use `jq` to update my JSON but due to array object I struggle to find the right way to do it.\r\n\r\nI can do it in Python of course but it will be much future proof for me to do it using Shell commands.\r\n\r\nThank you in advance!",
        "link": "https://stackoverflow.com/questions/75537106/how-to-update-json-values-in-a-nested-json-with-array-in-shell",
        "title": "How to update JSON values in a nested JSON with array in Shell"
    },
    {
        "tags": [
            "jq",
            "youtube-dl",
            "yt-dlp"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677100586,
                "post_id": 75537383,
                "comment_id": 133273524,
                "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": 1677107155,
                "post_id": 75537383,
                "comment_id": 133274929,
                "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": 1677138091,
                "post_id": 75537383,
                "comment_id": 133279377,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1677094416,
        "creation_date": 1677094416,
        "question_id": 75537383,
        "body_markdown": "I have been going through YoutubeDL&#39;s readme, it&#39;s pretty detailed, but I could find a way to filter videos of a playlist based date they were added to the playlist. \r\n\r\nI am looking for something very similar to `dateafter` but for the date added, not uploaded.\r\n\r\nI thought I could use `match-filter`, but I don&#39;t see any relevant keys when I run:\r\n\r\n    youtube-dl --skip-download --print-json &lt;playlist_url&gt; | jq keys\r\n\r\nIs there any way this can be achieved?",
        "link": "https://stackoverflow.com/questions/75537383/filter-playlist-videos-based-on-date-they-were-added",
        "title": "Filter playlist videos based on date they were added"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "depth"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677534143,
                "last_edit_date": 1677534143,
                "creation_date": 1677136324,
                "answer_id": 75541602,
                "question_id": 75541601,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The streaming parser that comes with jq does not seem to impose any particular limit and can be used as follows:\r\n\r\n    jq --stream -n &#39;[inputs[0]|length]|max&#39; input.json\r\n\r\nor more economically using the same invocation but with the program:\r\n```\r\ndef max(s): reduce s as $_ (null; if $_ &gt; . then $_ else . end);\r\nmax(inputs[0]|length)\r\n```\r\n\r\nAnother option might be to use the Go implementation, which has a limit that lies somewhere between 1024 and 10000.  This is the invocation I&#39;ve used:\r\n```\r\n    gojq &#39;def max(s): reduce s as $_ (null; if $_ &gt; . then $_ else . end);\r\n  max(paths|length)&#39; input.json\r\n```\r\n",
                "title": "Using jq, how to determine the maximum depth of a JSON document if it cannot be loaded into memory?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677534143,
        "creation_date": 1677136324,
        "question_id": 75541601,
        "body_markdown": "The downloadable binaries for the C implementation of [tag:jq] come with a rather low hard-coded value of MAX_PARSING_DEPTH (currently 256). \r\n\r\nWithout having to recompile jq, what are my options for determining the depth of nesting of a JSON document at the command-line?",
        "link": "https://stackoverflow.com/questions/75541601/using-jq-how-to-determine-the-maximum-depth-of-a-json-document-if-it-cannot-be",
        "title": "Using jq, how to determine the maximum depth of a JSON document if it cannot be loaded into memory?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677144246,
                "creation_date": 1677144246,
                "answer_id": 75542816,
                "question_id": 75542815,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer is to use bash command substitution to have jq first convert the file contents to a *single* json string which can be read with `--argfile`\r\n\r\n`--argfile` is like `--slurpfile`, but when the file has just one text, then that is used, else an array of texts is used as in `--slurpfile`. \r\n\r\nWe are going to make sure there is *just one text* so we can ignore the warning in the man page *Do not use. Use --slurpfile instead*\r\n\r\nSo we convert from:\r\n\r\n    jq ... --rawfile foo ./bar\r\n\r\nto\r\n\r\n    jq ... --argfile foo &lt;( jq -s -R &#39;.&#39; ./bar )\r\n\r\n`jq -s -R &#39;.&#39;` reads `./bar` in one go because of `-s` thus obtaining a multiline string instead of an array, and it treats the input as raw text because of `-R` and emits a single json string output.\r\n\r\nExample:\r\n\r\n    $ printf &#39;one\\ntwo\\nthree\\n&#39; &gt; 123\r\n    $ jq -n --rawfile text 123 &#39;{ text: $text }&#39;\r\n    {\r\n      &quot;text&quot;: &quot;one\\ntwo\\nthree\\n&quot;\r\n    }\r\n    $ jq -n --argfile text &lt;( jq -s -R &#39;.&#39; 123 ) &#39;{ text: $text }&#39;\r\n    {\r\n      &quot;text&quot;: &quot;one\\ntwo\\nthree\\n&quot;\r\n    }\r\n",
                "title": "What can I use for jq &lt; 1.6 where rawfile support is missing?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677144246,
        "creation_date": 1677144246,
        "question_id": 75542815,
        "body_markdown": "In jq, `--rawfile &lt;variable-name&gt; &lt;filename&gt;` will read in the named file and bind its content to the given global variable. If you run jq with `--rawfile foo bar`, then `$foo` is  available in the program and has a string whose contents are to the texts in the file named `bar`\r\n\r\nBut in versions of jq before 1.6, `--rawfile` is not present, what can I do?\r\n\r\nThe file contents are too large and/or private to pass on the command line with `--arg foo &quot;$(cat bar)&quot;`, `--argfile` and `--slurpfile` will expect JSON input.",
        "link": "https://stackoverflow.com/questions/75542815/what-can-i-use-for-jq-1-6-where-rawfile-support-is-missing",
        "title": "What can I use for jq &lt; 1.6 where rawfile support is missing?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677187027,
                "last_edit_date": 1677187027,
                "creation_date": 1677158704,
                "answer_id": 75545469,
                "question_id": 75545347,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Only `arr2` is an array. `arr1` is just a string containing spaces. Therefore you can read in `arr1` using the `--arg` option, and `/ &quot; &quot;` to split it at the spaces, and use the `--args` option for the &quot;real&quot; array `arr2`:\r\n```sh\r\njq -n --arg arg &quot;$arr1&quot; &#39;[$arg / &quot; &quot;, $ARGS.positional]\r\n  | reduce transpose[] as [$key, $feature1] ({}; .[$key] = {$feature1})\r\n&#39; --args &quot;${arr2[@]}&quot;\r\n```\r\n```json\r\n{\r\n  &quot;200&quot;: {\r\n    &quot;feature1&quot;: &quot;1000&quot;\r\n  },\r\n  &quot;300&quot;: {\r\n    &quot;feature1&quot;: &quot;10001&quot;\r\n  },\r\n  &quot;400&quot;: {\r\n    &quot;feature1&quot;: &quot;10002&quot;\r\n  }\r\n}\r\n```\r\n---\r\nTo make the conversion to numbers in the values, use `tonumber`:\r\n```sh\r\njq -n --arg arg &quot;$arr1&quot; &#39;[$arg / &quot; &quot;, $ARGS.positional]\r\n  | reduce transpose[] as [$key, $val] ({}; .[$key] = {feature1: $val | tonumber})\r\n&#39; --args &quot;${arr2[@]}&quot;\r\n```\r\n```json\r\n{\r\n  &quot;200&quot;: {\r\n    &quot;feature1&quot;: 1000\r\n  },\r\n  &quot;300&quot;: {\r\n    &quot;feature1&quot;: 10001\r\n  },\r\n  &quot;400&quot;: {\r\n    &quot;feature1&quot;: 10002\r\n  }\r\n}\r\n```\r\n\r\n---\r\n## Generalizing to:\r\n## How can I import two (or more) indexed bash arrays into jq\r\n\r\nThis is less trivial because the trick of using `--args` (populating the argument stack with the array items) can only be used once. Or more precisely: `--args` simply passes all remaining arguments to the internal `$ARGS` object, so even if you pass on both arrays, the items will arrive but the information where the first one ends and the second one starts will be lost. Here are a few workarounds:\r\n\r\n#### Using a separator item\r\nYou could sneak in a special item between the two arrays, so that by spotting its index from within jq the arrays can be recovered by slicing around that item. The caveat here is that this separator item must be unique(ly identifiable), otherwise the splitting may occur anywhere across the arrays. Also finding such an item may or may not be easy, depending on the type of data stored in the arrays. Let&#39;s assume the empty string `&quot;&quot;` is such a value that never occurs as item in any of the arrays. Then you may go with something along the lines of:\r\n```sh\r\nkeys=&quot;200 300 400&quot;\r\narr1=(&quot;one&quot; &quot;two&quot; &quot;two and a half&quot;)\r\narr2=(&quot;three and four&quot; &quot;five&quot; &quot;six&quot;)\r\nsep=&quot;&quot;\r\ninit=1000\r\njq -n --arg keys &quot;$keys&quot; --arg sep &quot;$sep&quot; --argjson init &quot;$init&quot; &#39;\r\n  [$keys / &quot; &quot;, ($ARGS.positional | index($sep) as $i | .[:$i], .[$i+1:])]\r\n  | . + [[$init + range(first | length)]]\r\n  | reduce transpose[] as [$key, $feature1, $feature2, $counter] ({};\r\n      .[$key] = {$counter, $feature1, $feature2}\r\n    )\r\n&#39; --args &quot;${arr1[@]}&quot; &quot;&quot; &quot;${arr2[@]}&quot;    # note the special item\r\n```\r\n\r\n#### Providing array lengths\r\nInstead of determining the index to split at based on the argument array itself, you could provide that information separately, as it is already available in the Bash context. For the use-case at hand, the arrays are believed to have equal lengths, so instead of repeating the indexing from above (which would work too), I will use `_nwise` which produces slices of equal lengths:\r\n```sh\r\nkeys=&quot;200 300 400&quot;\r\narr1=(&quot;one&quot; &quot;two&quot; &quot;two and a half&quot;)\r\narr2=(&quot;three and four&quot; &quot;five&quot; &quot;six&quot;)\r\nlen=${#arr1}    # note the dynamic computation of the length\r\ninit=1000\r\njq -n --arg keys &quot;$keys&quot; --argjson len &quot;$len&quot; --argjson init &quot;$init&quot; &#39;\r\n  [$keys / &quot; &quot;, ($ARGS.positional | _nwise($len))]\r\n  | . + [[$init + range(first | length)]]\r\n  | reduce transpose[] as [$key, $feature1, $feature2, $counter] ({};\r\n      .[$key] = {$counter, $feature1, $feature2}\r\n    )\r\n&#39; --args &quot;${arr1[@]}&quot; &quot;${arr2[@]}&quot;    # just the two arrays\r\n```\r\n\r\n#### Preprocessing the arrays\r\nA completely different approach could be to invoke separate instances of jq just to convert the bash arrays into JSON arrays (one call per array - the `--args` option can be used here as shown above). This is practical, as jq offers more possibilities to read in JSON arrays (after all it&#39;s a JSON processor). However, keep in mind that performacewise this can become expensive, especially when loops and iterations are involved. But If there is only a single run with two arrays, the difference between calling jq once and doing it three times will hardly be noticeable. To import the JSON array, using options like `--argjson` for inline data (as seen in the last approach), or `--argfile` and `--slurpfile` for referenced data (using [process substitution](https://tldp.org/LDP/abs/html/process-sub.html) `&lt;()` here is quite common) would be one way. As this use-case has no (other) external input (we were using the `-n` option all the time), the converted arrays can also be streamed in via the &quot;main enterance&quot;. Using `-s` instead also can take care of collecting the stream into a big array (which is the counterpart of what happened in the first line of the previous approaches):\r\n```sh\r\nkeys=&quot;200 300 400&quot;\r\narr1=(&quot;one&quot; &quot;two&quot; &quot;two and a half&quot;)\r\narr2=(&quot;three and four&quot; &quot;five&quot; &quot;six&quot;)\r\ninit=1000\r\n{\r\n  jq -n &#39;$ARGS.positional&#39; --args &quot;${arr1[@]}&quot;\r\n  jq -n &#39;$ARGS.positional&#39; --args &quot;${arr2[@]}&quot;\r\n} |\r\njq -s --arg keys &quot;$keys&quot; --argjson init &quot;$init&quot; &#39;    # no other parameters here\r\n  [$keys / &quot; &quot;] + . + [[$init + range(first | length)]]\r\n  | reduce transpose[] as [$key, $feature1, $feature2, $counter] ({};\r\n      .[$key] = {$counter, $feature1, $feature2}\r\n    )\r\n&#39;\r\n```\r\n\r\n#### Output\r\nAll these approaches produce the same output:\r\n```json\r\n{\r\n  &quot;200&quot;: {\r\n    &quot;counter&quot;: 1000,\r\n    &quot;feature1&quot;: &quot;one&quot;,\r\n    &quot;feature2&quot;: &quot;three and four&quot;\r\n  },\r\n  &quot;300&quot;: {\r\n    &quot;counter&quot;: 1001,\r\n    &quot;feature1&quot;: &quot;two&quot;,\r\n    &quot;feature2&quot;: &quot;five&quot;\r\n  },\r\n  &quot;400&quot;: {\r\n    &quot;counter&quot;: 1002,\r\n    &quot;feature1&quot;: &quot;two and a half&quot;,\r\n    &quot;feature2&quot;: &quot;six&quot;\r\n  }\r\n}\r\n```\r\n",
                "title": "Creating json from two bash arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677187027,
        "creation_date": 1677158118,
        "last_edit_date": 1677163299,
        "question_id": 75545347,
        "body_markdown": "I have two bash arrays:\r\n```bash\r\narr1=&quot;200 300 400&quot;\r\narr2=(1000 10001 10002)\r\n```\r\n\r\nI would like to produce a `json` file with a bash script:\r\n\r\n```json\r\n{\r\n  &quot;200&quot;: {&quot;feature1&quot;: 1000},\r\n  &quot;300&quot;: {&quot;feature1&quot;: 1001},\r\n  &quot;400&quot;: {&quot;feature1&quot;: 1002}\r\n}\r\n```\r\nI tried doing it with `jq`:\r\n```bash\r\njq -n --arg arg1 &quot;${arr1[*]}&quot; \\\r\n      --arg arg2 &quot;${arr2[*]}&quot; \\\r\n      &#39;{$arg1: {&quot;feature1&quot;: $arg2}}&#39;\r\n```\r\nbut this only expands the whole arrays into one entry.\r\n\r\n[EDIT]: What if I have the third array with file paths and would like to place them as feature 2:\r\n```json\r\n{\r\n  &quot;200&quot;: {\r\n    &quot;feature1&quot;: 1000,\r\n    &quot;feature2&quot;: &quot;path-to-files/1000.log&quot;\r\n  },\r\n  &quot;300&quot;: {\r\n    &quot;feature1&quot;: 1001,\r\n    &quot;feature2&quot;: &quot;path-to-files/1001.log&quot;\r\n  },\r\n  &quot;400&quot;: {\r\n    &quot;feature1&quot;: 1002,\r\n    &quot;feature2&quot;: &quot;path-to-files/1002.log&quot;\r\n  }\r\n}\r\n```\r\n[EDIT2]: My workflow:\r\n```bash\r\narr1=&quot;200 300 400&quot;\r\narr2=()\r\narr3=()\r\narr2_content=1000\r\nfor i in $arr1; do\r\n    arr2+=(&quot;$arr2_content&quot;)\r\n    touch &quot;$arr2_content.log&quot;\r\n    arr3+=(&quot;$PWD/$arr2_content.log&quot;)\r\n    arr2_content=$((arr2_content+1))\r\ndone\r\n```",
        "link": "https://stackoverflow.com/questions/75545347/creating-json-from-two-bash-arrays",
        "title": "Creating json from two bash arrays"
    },
    {
        "tags": [
            "json",
            "github",
            "github-actions",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10402418,
                    "reputation": 14920,
                    "user_id": 7670262,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/3zdDY.jpg?s=256",
                    "display_name": "Azeem",
                    "link": "https://stackoverflow.com/users/7670262/azeem"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677162976,
                "post_id": 75546117,
                "comment_id": 133286603,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2622249,
                    "reputation": 39746,
                    "user_id": 2270041,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cn7rq.jpg?s=256",
                    "display_name": "Matteo",
                    "link": "https://stackoverflow.com/users/2270041/matteo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677163654,
                "post_id": 75546117,
                "comment_id": 133286866,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677165270,
                "post_id": 75546117,
                "comment_id": 133287495,
                "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": 1677186322,
                "post_id": 75546117,
                "comment_id": 133293752,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677179588,
                "creation_date": 1677179588,
                "answer_id": 75549335,
                "question_id": 75546117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can achieve that using [`jq`][1] with `--arg` \r\n\r\nThis example worked for me:\r\n\r\n    steps:\r\n      - name: Create test file\r\n        run: |\r\n          cat &gt; test.json &lt;&lt; EOL\r\n          {\r\n              &quot;secret&quot;: &quot;&quot;,\r\n              &quot;name&quot;: &quot;test&quot;\r\n          }\r\n          EOL\r\n      - name: Edit Json\r\n        shell: bash\r\n        run: |\r\n          echo $(jq --arg a &quot;${{ secrets.MY_SECRET }}&quot; &#39;.secret = ($a)&#39; test.json) &gt; test.json   \r\n      - name: display\r\n        run: |\r\n          cat test.json\r\n      - uses: actions/upload-artifact@v3\r\n        with:\r\n          name: my-test-file\r\n          path: ./test.json\r\n\r\nI used [`actions/upload-artifact`][2] so I upload my `test.json` as artifact and then read it on my machine as a workaround as GitHub hides the outputs.\r\n\r\nYes, if you see `***` in the console that doesn&#39;t mean that the file didn&#39;t change, it&#39;s just replaced in the workflows&#39; console &amp; logs.\r\n\r\n---\r\n\r\nIf the secret is not set to your file, check that it&#39;s set properly in your repository, then check `jq`&#39;s version on your runners if you use self-hosted ones. \r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/\r\n  [2]: https://github.com/actions/upload-artifact",
                "title": "Github Action: How to edit a JSON objects with Github repository secrets"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677482744,
        "creation_date": 1677162241,
        "last_edit_date": 1677482744,
        "question_id": 75546117,
        "body_markdown": "**Github Action: How to edit a JSON object with Github repository secrets** in my workflow I have a job that edits the empty JSON values in JSON file and replaces them with my GitHub secrets. The problem is when I run the ```cat &#39;test.json&#39;``` command my updated value does not appear:\r\n\r\nJSON file:\r\n```\r\n{\r\n&quot;secret&quot;: &quot;&quot;,\r\n&quot;name&quot;: &quot;test&quot;\r\n}\r\n```\r\nWorkflow:\r\n```\r\nsteps:\r\n- name: Edit Json\r\n      shell: bash\r\n      run: |\r\n        echo &quot;`jq &#39;.secret=&quot;${{ secrets.PRIVATE_KEY }}&quot;&#39;test.json`&quot; &gt; test.json\r\n    - name: display\r\n      run: |\r\n        cat &#39;test.json&#39;\r\n```\r\n\r\nOutput:\r\n```\r\n{\r\n&quot;secret&quot;: &quot;&quot;,\r\n&quot;name&quot;: &quot;test&quot;\r\n}\r\n```\r\n\r\nExpected Output:\r\n```\r\n{\r\n&quot;secret&quot;: &quot;ABCDEFGH&quot;,\r\n&quot;name&quot;: &quot;test&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75546117/github-action-how-to-edit-a-json-objects-with-github-repository-secrets",
        "title": "Github Action: How to edit a JSON objects with Github repository secrets"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677178357,
                "creation_date": 1677178357,
                "answer_id": 75549133,
                "question_id": 75548994,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add the `-n` or `--null-input` option. (On jqplay.org tick the checkbox reading &quot;Null Input&quot;).\r\n\r\nThis is because the first input is consumed by the context `.`, and any subsequent inputs are consumed either by reiteration to `.` (which happens programmatically), or earlier, if present, by the use of `input` (one) or `inputs` (all). The include the first input into the consumption via `input` or `inputs` you have to sort of prepend `null` as a new first input (which is then consumed by `.`), so all the other ones (beginning with the first &quot;real&quot; input) are left to be consumed by `input` and `inputs`.",
                "title": "JQ Raw Input of CSV missing first line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677178357,
        "creation_date": 1677177487,
        "question_id": 75548994,
        "body_markdown": "It&#39;s not clear to me why my output with this template is missing the first line of the data, what am I missing?\r\n\r\nSample: https://jqplay.org/s/6VAJCkLQo9v\r\n\r\nRaw Data:\r\n\r\n    watts;2023-02-21T06:50:00+01:00;0\r\n    watts;2023-02-21T07:00:00+01:00;1928\r\n    watts;2023-02-21T08:00:00+01:00;2686\r\n    watts;2023-02-21T09:00:00+01:00;5054\r\n    watts;2023-02-21T10:00:00+01:00;7466\r\n    watts;2023-02-21T11:00:00+01:00;7797\r\n    watts;2023-02-21T12:00:00+01:00;7520\r\n    watts;2023-02-21T13:00:00+01:00;6585\r\n    watts;2023-02-21T14:00:00+01:00;5084\r\n    watts;2023-02-21T15:00:00+01:00;3235\r\n    watts;2023-02-21T16:00:00+01:00;1345\r\n    watts;2023-02-21T17:00:00+01:00;294\r\n    watts;2023-02-21T17:31:00+01:00;0\r\n    watts;2023-02-22T06:49:00+01:00;0\r\n    watts;2023-02-22T07:00:00+01:00;2637\r\n    watts;2023-02-22T08:00:00+01:00;4629\r\n    watts;2023-02-22T09:00:00+01:00;6155\r\n    watts;2023-02-22T10:00:00+01:00;6639\r\n    watts;2023-02-22T11:00:00+01:00;6582\r\n    watts;2023-02-22T12:00:00+01:00;6124\r\n    watts;2023-02-22T13:00:00+01:00;5135\r\n    watts;2023-02-22T14:00:00+01:00;3412\r\n    watts;2023-02-22T15:00:00+01:00;1816\r\n    watts;2023-02-22T16:00:00+01:00;721\r\n    watts;2023-02-22T17:00:00+01:00;189\r\n    watts;2023-02-22T17:33:00+01:00;0\r\n    watt_hours_period;2023-02-21T06:50:00+01:00;0\r\n    watt_hours_period;2023-02-21T07:00:00+01:00;161\r\n    watt_hours_period;2023-02-21T08:00:00+01:00;2307\r\n    watt_hours_period;2023-02-21T09:00:00+01:00;3870\r\n    watt_hours_period;2023-02-21T10:00:00+01:00;6260\r\n    watt_hours_period;2023-02-21T11:00:00+01:00;7632\r\n    watt_hours_period;2023-02-21T12:00:00+01:00;7659\r\n    watt_hours_period;2023-02-21T13:00:00+01:00;7053\r\n    watt_hours_period;2023-02-21T14:00:00+01:00;5835\r\n    watt_hours_period;2023-02-21T15:00:00+01:00;4160\r\n    watt_hours_period;2023-02-21T16:00:00+01:00;2290\r\n    watt_hours_period;2023-02-21T17:00:00+01:00;820\r\n    watt_hours_period;2023-02-21T17:31:00+01:00;76\r\n    watt_hours_period;2023-02-22T06:49:00+01:00;0\r\n    watt_hours_period;2023-02-22T07:00:00+01:00;242\r\n    watt_hours_period;2023-02-22T08:00:00+01:00;3633\r\n    watt_hours_period;2023-02-22T09:00:00+01:00;5392\r\n    watt_hours_period;2023-02-22T10:00:00+01:00;6397\r\n    watt_hours_period;2023-02-22T11:00:00+01:00;6611\r\n    watt_hours_period;2023-02-22T12:00:00+01:00;6353\r\n    watt_hours_period;2023-02-22T13:00:00+01:00;5630\r\n    watt_hours_period;2023-02-22T14:00:00+01:00;4274\r\n    watt_hours_period;2023-02-22T15:00:00+01:00;2614\r\n    watt_hours_period;2023-02-22T16:00:00+01:00;1269\r\n    watt_hours_period;2023-02-22T17:00:00+01:00;455\r\n    watt_hours_period;2023-02-22T17:33:00+01:00;52\r\n    watt_hours;2023-02-21T06:50:00+01:00;0\r\n    watt_hours;2023-02-21T07:00:00+01:00;161\r\n    watt_hours;2023-02-21T08:00:00+01:00;2468\r\n    watt_hours;2023-02-21T09:00:00+01:00;6338\r\n    watt_hours;2023-02-21T10:00:00+01:00;12598\r\n    watt_hours;2023-02-21T11:00:00+01:00;20230\r\n    watt_hours;2023-02-21T12:00:00+01:00;27889\r\n    watt_hours;2023-02-21T13:00:00+01:00;34942\r\n    watt_hours;2023-02-21T14:00:00+01:00;40777\r\n    watt_hours;2023-02-21T15:00:00+01:00;44937\r\n    watt_hours;2023-02-21T16:00:00+01:00;47227\r\n    watt_hours;2023-02-21T17:00:00+01:00;48047\r\n    watt_hours;2023-02-21T17:31:00+01:00;48123\r\n    watt_hours;2023-02-22T06:49:00+01:00;0\r\n    watt_hours;2023-02-22T07:00:00+01:00;242\r\n    watt_hours;2023-02-22T08:00:00+01:00;3875\r\n    watt_hours;2023-02-22T09:00:00+01:00;9267\r\n    watt_hours;2023-02-22T10:00:00+01:00;15664\r\n    watt_hours;2023-02-22T11:00:00+01:00;22275\r\n    watt_hours;2023-02-22T12:00:00+01:00;28628\r\n    watt_hours;2023-02-22T13:00:00+01:00;34258\r\n    watt_hours;2023-02-22T14:00:00+01:00;38532\r\n    watt_hours;2023-02-22T15:00:00+01:00;41146\r\n    watt_hours;2023-02-22T16:00:00+01:00;42415\r\n    watt_hours;2023-02-22T17:00:00+01:00;42870\r\n    watt_hours;2023-02-22T17:33:00+01:00;42922\r\n    watt_hours_day;2023-02-21;48123\r\n    watt_hours_day;2023-02-22;42922\r\n\r\nJQ Template (called with --raw-data flag):\r\n\r\n    { south: [inputs | split(&quot;;&quot;) | {label: .[0], date: .[1], values: .[2] | gsub(&quot;[\\r]&quot;; &quot;&quot;) | tonumber } ]  \r\n    | group_by(.label) | map({ key: (.[0].label), value: [.[] | {date: .date, values: .values}] }) | from_entries\r\n    }\r\n\r\nIf I examine the results, the first entry is missing. I do not understand why. It is not the group_by section or anything because if I remove that it also fails to grab the first line. And it is not in the array later or anything, it is just missing.\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/TpFsl.png",
        "link": "https://stackoverflow.com/questions/75548994/jq-raw-input-of-csv-missing-first-line",
        "title": "JQ Raw Input of CSV missing first line"
    },
    {
        "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": 1677178668,
                "post_id": 75549123,
                "comment_id": 133291779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 137088,
                    "reputation": 1875,
                    "user_id": 5302993,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/H7TNa.jpg?s=256",
                    "display_name": "Jeff",
                    "link": "https://stackoverflow.com/users/5302993/jeff"
                },
                "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": 1677183252,
                "post_id": 75549123,
                "comment_id": 133292990,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677186946,
                "post_id": 75549123,
                "comment_id": 133293912,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677186275,
                "creation_date": 1677186275,
                "answer_id": 75550313,
                "question_id": 75549123,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.connections[]` will stream the elements of `connection`. When using inside an object construction filter, this will create one object per element in the stream.\r\n\r\nIf there are multiple streams involved, the cartesian product will be built.\r\nIf the array is empty, nothing will be streamed (and consequently, the product will be empty; see example at the bottom).\r\n\r\nHere&#39;s an example:\r\n\r\n```\r\n$ jq -cn &#39;{\r\n  a: [ 1, 2 ],\r\n  b: [ 3, 4 ]\r\n}\r\n| { x: (.a[] | . + 10), y: (.b[] | . + 20) }&#39;\r\n{&quot;x&quot;:11,&quot;y&quot;:23}\r\n{&quot;x&quot;:11,&quot;y&quot;:24}\r\n{&quot;x&quot;:12,&quot;y&quot;:23}\r\n{&quot;x&quot;:12,&quot;y&quot;:24}\r\n```\r\n\r\nNote that `?` only has an effect on missing values/properties. An empty array is not missing, it has a value: the empty array itself.\r\n\r\nYou  probably want to use the `map` filter, e.g. to extract an array of ids from your connections: `{ connections: (.connections | map({id})) }`.\r\n\r\nRewriting the example from above with `map`:\r\n\r\n```\r\n$ jq -cn &#39;{\r\n  a: [ 1, 2 ],\r\n  b: [ 3, 4 ]\r\n}\r\n| { x: .a | map(. + 10), y: .b | map(. + 20) }&#39;\r\n{&quot;x&quot;:[11,12],&quot;y&quot;:[23,24]}\r\n```\r\n\r\n*****\r\n\r\nEmpty cartesian product:\r\n\r\n```\r\n$ jq -cn &#39;{\r\n  a: [ 1, 2 ],\r\n  b: [ 3, 4 ],\r\n  c: []\r\n}\r\n| { x: (.a[] | . + 10), y: (.b[] | . + 20), z: (.c[] | . + 30) }&#39;\r\n$ # empty\r\n```\r\n\r\n```\r\n$ jq -cn &#39;{\r\n  a: [ 1, 2 ],\r\n  b: [ 3, 4 ],\r\n  c: []\r\n}\r\n| { x: .a | map(. + 10), y: .b | map(. + 20), z: .c | map(. + 30) }&#39;\r\n{&quot;x&quot;:[11,12],&quot;y&quot;:[23,24],&quot;z&quot;:[]}\r\n```",
                "title": "jq: parse result where some properties are empty arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677186275,
        "creation_date": 1677178265,
        "question_id": 75549123,
        "body_markdown": "Using [**jq**][1], wish to parse results that may include array values \r\n\r\nConfused. If data contains an empty array:\r\n```\r\n&quot;connections&quot;: []\r\n```\r\n\r\nThought that [jq][1] would be able to parse it with:\r\n```\r\nconnections: .connections[]? | { id: .id }\r\n```\r\n\r\nFor example, `&quot;apps&quot;` is an array, and each `app` is defined with the following:\r\n\r\n - `&quot;actions&quot;` array\r\n - `&quot;connections&quot;` array\r\n\r\nHere result where `apps` has an `app` instance that contains `connections` as an empty array.\r\n```\r\n  &quot;apps&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1a902fb4-1b43-4df9-b9d7-9b54cd14e2ad&quot;,\r\n      &quot;actions&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;0dc38f41-49fe-4056-b035-850764733a44&quot;,\r\n        }\r\n      ],\r\n      &quot;connections&quot;: []\r\n    },\r\n  ]\r\n```\r\n\r\nAssume all `apps` have `connections` currently containing empty arrays.\r\n\r\nUsing [jq][1], parsing `apps` without including `connections` (all currently contain empty arrays), no problem, result is parsed:\r\n\r\n```\r\napps: .apps[]? | { id: .id \\\r\n  , actions: .actions[]? | { id: .id }\r\n}\r\n```\r\n\r\nUsing [jq][1], parsing `apps` including empty `connections`, no results, nothing:\r\n```\r\ninstances: .instances[]? | { id: .id \\\r\n  , actions: .actions[]? | { id: .id } \\\r\n  , connections: .connections[]? | { id: .id } \\\r\n}\r\n```\r\n\r\nWhat am I missing?\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/75549123/jq-parse-result-where-some-properties-are-empty-arrays",
        "title": "jq: parse result where some properties are empty arrays"
    },
    {
        "tags": [
            "awk",
            "sed",
            "grep",
            "ip",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1677178865,
                "post_id": 75549196,
                "comment_id": 133291823,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27863268,
                    "reputation": 11,
                    "user_id": 21275321,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2fa08bf5d21527f43827774dc6ecd154?s=256&d=identicon&r=PG",
                    "display_name": "ksmm",
                    "link": "https://stackoverflow.com/users/21275321/ksmm"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677179395,
                "post_id": 75549196,
                "comment_id": 133291972,
                "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": 0,
                "creation_date": 1677210897,
                "post_id": 75549196,
                "comment_id": 133297323,
                "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": 1677345530,
                "post_id": 75549196,
                "comment_id": 133321216,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27863268,
                    "reputation": 11,
                    "user_id": 21275321,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2fa08bf5d21527f43827774dc6ecd154?s=256&d=identicon&r=PG",
                    "display_name": "ksmm",
                    "link": "https://stackoverflow.com/users/21275321/ksmm"
                },
                "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": 1677507052,
                "post_id": 75549196,
                "comment_id": 133345589,
                "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": 1677507439,
                "post_id": 75549196,
                "comment_id": 133345710,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677220385,
                "creation_date": 1677220385,
                "answer_id": 75553264,
                "question_id": 75549196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON (your provided sample needs the following fixes to turn it into one (see the specs at https://www.json.org/):\r\n\r\n- a document cannot just start with a field name, here `&quot;address_details&quot;:`, you have to open an object with curly braces `{` - just like as you *do* close it at the end.\r\n\r\n- Strings have to be wrapped into double qoutes (`&quot;`). For `&quot;zone&quot;: “Germany”` you can see that `“Germany”` uses different ones.\r\n\r\n), then the following [stedolan/jq](https://github.com/stedolan/jq) filter can extract what you want:\r\n\r\n- `.addresses` traverses to the array under the `&quot;addresses&quot;` field name.\r\n- `.[]` iterates through the items of that array (when contracting with a field name, the initial dot is omitted)\r\n- the `--raw-output` flag turns the outputs into raw text (until then they are JSON strings, i.e. wrapped into quotes as discussed above)\r\n\r\n```sh\r\njq --raw-output &#39;.addresses[]&#39; file.json\r\n```\r\n```\r\n135.138.168.78\r\n135.138.168.79\r\n```\r\n\r\nIf in your calling environment you are using a pipeline (a program produces the JSON output, and you want to process it on the fly without first saving it into a file), jq can also read in from stdin:\r\n```sh\r\n… | jq --raw-output &#39;.addresses[]&#39;\r\n```\r\n\r\nTo easily play around with jq, there is https://jqplay.org/. Enter the jq filter (`.addresses[]` in this case) into the upper left box, and the input JSON into the lower left box, and the (still JSON-encoded) result is immediately shown on the right side. Tick the checkbox reading `Raw Output` to apply the `--raw-output` flag we used earlier. Below the input boxes you are shown a command ready to be used on the command line, compiled from the inputs you have made above. Following this example it should now read `jq --raw-output &#39;.addresses[]&#39;`. Here&#39;s a link that brings you right into this final state: https://jqplay.org/s/BMmPjsL6sUT (valid until the site maintainers decide to reset the site which happens every now and then.)\r\n\r\nTo dive more into the jq language, have a look at the (clickable) examples on  the bottom of the jqplay.org site, and consult the manual at https://stedolan.github.io/jq/manual/.",
                "title": "grab IP addresses (but not subnets) from a command (or file) and output them one per line to a new file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677278239,
                "creation_date": 1677278239,
                "answer_id": 75561978,
                "question_id": 75549196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    cat &lt;file&gt; | grep -Eo &#39;&quot;[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}&quot;&#39; | tr -d &#39;&quot;&#39; | sort -u\r\n\r\nshould do it",
                "title": "grab IP addresses (but not subnets) from a command (or file) and output them one per line to a new file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1677939856,
                "last_edit_date": 1677939856,
                "creation_date": 1677506373,
                "answer_id": 75581430,
                "question_id": 75549196,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "so, again, totally new to this. Trial and error got me to this command.\r\n\r\n    jq --raw-output &#39;.result | .[].addresses[]&#39;\r\n\r\nIt works. I have no idea if this is a well-formatted or thought out jq command, but it outputs the IPs in both my test file and the real data.",
                "title": "grab IP addresses (but not subnets) from a command (or file) and output them one per line to a new file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1678111411,
        "creation_date": 1677178735,
        "last_edit_date": 1678111411,
        "question_id": 75549196,
        "body_markdown": "```\r\n{\r\n\t&quot;status&quot;: &quot;success&quot;,\r\n\t&quot;result&quot;: [{\r\n\t\t&quot;address_details&quot;: [{\r\n\t\t\t\t&quot;address&quot;: &quot;135.138.168.78&quot;,\r\n\t\t\t\t&quot;serviceType&quot;: &quot;go_gateway&quot;,\r\n\t\t\t\t&quot;addressType&quot;: &quot;active&quot;,\r\n\t\t\t\t&quot;create_time&quot;: 1631879023,\r\n\t\t\t\t&quot;allow_listed&quot;: false\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;address&quot;: &quot;135.138.168.79&quot;,\r\n\t\t\t\t&quot;serviceType&quot;: &quot;gp_gateway&quot;,\r\n\t\t\t\t&quot;addressType&quot;: &quot;active&quot;,\r\n\t\t\t\t&quot;create_time&quot;: 1631879023,\r\n\t\t\t\t&quot;allow_listed&quot;: false\r\n\t\t\t}\r\n\t\t],\r\n\t\t&quot;zone&quot;: &quot;Germany&quot;,\r\n\t\t&quot;addresses&quot;: [\r\n\t\t\t&quot;135.138.168.78&quot;,\r\n\t\t\t&quot;135.138.168.79&quot;\r\n\t\t],\r\n\t\t&quot;zone_subnet&quot;: [\r\n\t\t\t&quot;137.183.192.0/18&quot;,\r\n\t\t\t&quot;208.27.0.0/16&quot;,\r\n\t\t\t&quot;34.3.0.0/16&quot;,\r\n\t\t\t&quot;34.199.0.0/16&quot;,\r\n\t\t\t&quot;66.59.192.0/19&quot;,\r\n\t\t\t&quot;165.11.128.0/17&quot;,\r\n\t\t\t&quot;135.138.0.0/16&quot;,\r\n\t\t\t&quot;130.141.0.0/16&quot;,\r\n\t\t\t&quot;165.185.0.0/16&quot;\r\n\t\t],\r\n\t\t&quot;addresses_v6&quot;: [],\r\n\t\t&quot;address_details_v6&quot;: []\r\n\t}]\r\n}\r\n```\r\n\r\nHere is some sanitized fake example output of a command I&#39;m using an API to pull.\r\n\r\nI only need the actual IP addresses, not the subnets, and I only need the IP addresses once.\r\n\r\nFrom the above example the hopeful output of this would just be the two IP addresses on two lines, like this\r\n\r\n\r\n```\r\n135.138.168.78\r\n135.139.168.79\r\n```\r\n\r\nThis is just one block of output from about 10 that are in the output/file, all formatted just like this.\r\n\r\nUsing my mediocre skillset and regex, I attempted to pull this information using grep and awk and had no real success, getting either multiples of the IP addresses in my output, or both the IPs and the subnets.\r\n\r\nEDIT - updated with the validated JSON.\r\n- now getting an error using the command\r\n     jq --raw-output &#39;.addresses[]&#39;\r\n\r\n**&quot;jq: error (at &lt;stdin&gt;:37): Cannot iterate over null (null)\r\nexit status 5&quot;**    \r\n\r\ntried adding a &quot;?&quot; after the square brackets and it outputs nothing.\r\n\r\ntried doing &#39;.result.addresses[]&#39; or &#39;.status.addresses[]&#39;\r\n\r\nget **&quot;jq: error (at &lt;stdin&gt;:37): Cannot index string with string &quot;addresses&quot;\r\nexit status 5&quot;**\r\n",
        "link": "https://stackoverflow.com/questions/75549196/grab-ip-addresses-but-not-subnets-from-a-command-or-file-and-output-them-one",
        "title": "grab IP addresses (but not subnets) from a command (or file) and output them one per line to a new file"
    },
    {
        "tags": [
            "swagger",
            "jq",
            "openapi"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677217360,
                "creation_date": 1677217360,
                "answer_id": 75552992,
                "question_id": 75551855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Load the second file into a variable (e.g. using `--argfile`), and reference by the appropriate key. \r\n\r\nI assumed that the lookup result has to be added `+` with a glueing space in between `&quot; &quot;`. I further assumed that if the lookup yields `null` (key not present), then nothing should be added (I used the empty string `&quot;&quot;`), i.e. the original content is being kept as-is.\r\n\r\n```sh\r\njq --argfile lookup endpoint-descriptions.json &#39;.paths[][] |= (\r\n  .description += ($lookup[.operationId].description | &quot; &quot; + values // &quot;&quot;)\r\n)&#39; swagger.json\r\n```\r\n```json\r\n{\r\n  &quot;swagger&quot;: &quot;2.0&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;description&quot;: &quot;Professional&quot;,\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;title&quot;: &quot;Pro&quot;,\r\n    &quot;contact&quot;: {},\r\n    &quot;license&quot;: {\r\n      &quot;name&quot;: &quot;Public&quot;\r\n    }\r\n  },\r\n  &quot;host&quot;: &quot;api.com&quot;,\r\n  &quot;schemes&quot;: [\r\n    &quot;https&quot;\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/cloud/{cloud_type}/{id}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Cloud Account Info&quot;,\r\n        &quot;description&quot;: &quot;Returns top level information about the cloud account.&quot;,\r\n        &quot;operationId&quot;: &quot;get-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;includeGroupInfo&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Include account group info. Default is false.&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/CloudAccountModel&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;put&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Update Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Update information related to a cloud account. The request body parameters differ depending on the cloud type of the account you want to add.&quot;,\r\n        &quot;operationId&quot;: &quot;update-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;skipStatusChecks&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Skip account status checks to improve response time&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_id_format / duplicate_cloud_account_name / duplicate_cloud_account / cannot_select_zero_account_groups / invalid_account_group_ids&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_type&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;not_found / internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Delete Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Deletes the onboarded cloud account that has the specified cloud account ID.&quot;,\r\n        &quot;operationId&quot;: &quot;delete-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / bad_request&quot;\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;cannot_delete_org_child&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / invalid_account_id_format&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;patch&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Patch Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Enable / disable cloud account (and children) OR Update the Account Groups it belongs to&quot;,\r\n        &quot;operationId&quot;: &quot;patch-cloud-account&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account Patch&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/CloudAccountPatchModel&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_id_format / invalid_account_patch&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / invalid_account_id_format&quot;\r\n          },\r\n          &quot;405&quot;: {\r\n            &quot;description&quot;: &quot;cloud_account_already_enabled / cloud_account_already_disabled&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/cloud/{cloud_type}&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Add Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Onboard a new cloud account onto the Prisma Cloud platform. The request body parameters differ depending on the cloud type&quot;,\r\n        &quot;operationId&quot;: &quot;add-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;skipStatusChecks&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Skip account status checks to improve response time&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;duplicate_cloud_account_name / duplicate_cloud_account / invalid_account_id_format / duplicate_cloud_account_needs_upgrade / cannot_select_zero_account_groups / invalid_account_group_ids&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_type&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/cloud/{cloud_type}/app_provisioner&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Get&#39;s terraform script/link to create Prisma Cloud App&quot;,\r\n        &quot;description&quot;: &quot;Get&#39;s terraform script/link to create Prisma Cloud App The payload will be variable&quot;,\r\n        &quot;operationId&quot;: &quot;cloud-app-provisioner&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;App provisioning Params&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;default&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/login&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Login&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Login&quot;,\r\n        &quot;description&quot;: &quot;Returns a JWT auth token for accessing the Prisma Cloud APIs.  To generate a token, you must have an access key and include the following values in the request body parameter — access key ID as the username and your secret key as the password. Prisma Cloud requires this JWT in the request header to authorize API access. Note that access keys maintain the same level of permissions as the permission group of the account that created them.  If you are a multi-tenant user and the body parameters of your login request include a user name and password instead of an access key ID and secret key. &quot;,\r\n        &quot;operationId&quot;: &quot;app-login&quot;,\r\n        &quot;consumes&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Model used for authentication&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/LoginModel&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/LoginResponseModel&quot;\r\n            }\r\n          },\r\n          &quot;401&quot;: {\r\n            &quot;description&quot;: &quot;sso_enabled_password_login_attempt / invalid_credentials&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;login_failed_unknown_error&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "Using jq, traverse swagger file and append each endpoint&#39;s description with the content from a lookup table where operationId acts as a key"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677217360,
        "creation_date": 1677201986,
        "question_id": 75551855,
        "body_markdown": "Ok, I will try my best to make it easy to understand.\r\n\r\nSo what do I have? TWO json files:\r\n1. swagger.json (main file that needs to be modified)\r\n```\r\n{\r\n  &quot;swagger&quot;: &quot;2.0&quot;,\r\n  &quot;info&quot;: {\r\n    &quot;description&quot;: &quot;Professional&quot;,\r\n    &quot;version&quot;: &quot;v1&quot;,\r\n    &quot;title&quot;: &quot;Pro&quot;,\r\n    &quot;contact&quot;: {},\r\n    &quot;license&quot;: {\r\n      &quot;name&quot;: &quot;Public&quot;\r\n    }\r\n  },\r\n  &quot;host&quot;: &quot;api.com&quot;,\r\n  &quot;schemes&quot;: [\r\n    &quot;https&quot;\r\n  ],\r\n  &quot;paths&quot;: {\r\n    &quot;/cloud/{cloud_type}/{id}&quot;: {\r\n      &quot;get&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Cloud Account Info&quot;,\r\n        &quot;description&quot;: &quot;Returns top level information about the cloud account.&quot;,\r\n        &quot;operationId&quot;: &quot;get-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;includeGroupInfo&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Include account group info. Default is false.&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/CloudAccountModel&quot;\r\n            }\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;put&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Update Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Update information related to a cloud account.&quot;,\r\n        &quot;operationId&quot;: &quot;update-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;skipStatusChecks&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Skip account status checks to improve response time&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_id_format / duplicate_cloud_account_name / duplicate_cloud_account / cannot_select_zero_account_groups / invalid_account_group_ids&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_type&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;not_found / internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;delete&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Delete Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Deletes the onboarded cloud account that has the specified cloud account ID.&quot;,\r\n        &quot;operationId&quot;: &quot;delete-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / bad_request&quot;\r\n          },\r\n          &quot;403&quot;: {\r\n            &quot;description&quot;: &quot;cannot_delete_org_child&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / invalid_account_id_format&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      &quot;patch&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Patch Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Enable / disable cloud account (and children) OR Update the Account Groups it belongs to&quot;,\r\n        &quot;operationId&quot;: &quot;patch-cloud-account&quot;,\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;id&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Account ID&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;pattern&quot;: &quot;.+&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account Patch&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/CloudAccountPatchModel&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_id_format / invalid_account_patch&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_cloud_type / invalid_account_id_format&quot;\r\n          },\r\n          &quot;405&quot;: {\r\n            &quot;description&quot;: &quot;cloud_account_already_enabled / cloud_account_already_disabled&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/cloud/{cloud_type}&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Add Cloud Account&quot;,\r\n        &quot;description&quot;: &quot;Onboard a new cloud account onto the Prisma Cloud platform.&quot;,\r\n        &quot;operationId&quot;: &quot;add-cloud-account&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Cloud Account&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;skipStatusChecks&quot;,\r\n            &quot;in&quot;: &quot;query&quot;,\r\n            &quot;description&quot;: &quot;true = Skip account status checks to improve response time&quot;,\r\n            &quot;required&quot;: false,\r\n            &quot;type&quot;: &quot;boolean&quot;\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          },\r\n          &quot;400&quot;: {\r\n            &quot;description&quot;: &quot;duplicate_cloud_account_name / duplicate_cloud_account / invalid_account_id_format / duplicate_cloud_account_needs_upgrade / cannot_select_zero_account_groups / invalid_account_group_ids&quot;\r\n          },\r\n          &quot;404&quot;: {\r\n            &quot;description&quot;: &quot;invalid_account_type&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;internal_error&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/cloud/{cloud_type}/app_provisioner&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Cloud Accounts&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Get&#39;s terraform script/link to create Prisma Cloud App&quot;,\r\n        &quot;description&quot;: &quot;Get&#39;s terraform script/link to create Prisma Cloud App&quot;,\r\n        &quot;operationId&quot;: &quot;cloud-app-provisioner&quot;,\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;App provisioning Params&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;type&quot;: &quot;object&quot;,\r\n              &quot;additionalProperties&quot;: {\r\n                &quot;type&quot;: &quot;object&quot;\r\n              }\r\n            }\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;cloud_type&quot;,\r\n            &quot;in&quot;: &quot;path&quot;,\r\n            &quot;description&quot;: &quot;Cloud Type&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;type&quot;: &quot;string&quot;,\r\n            &quot;enum&quot;: [\r\n              &quot;aws&quot;,\r\n              &quot;azure&quot;,\r\n              &quot;gcp&quot;,\r\n              &quot;alibaba_cloud&quot;,\r\n              &quot;oci&quot;\r\n            ]\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;default&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;\r\n          }\r\n        },\r\n        &quot;security&quot;: [\r\n          {\r\n            &quot;x-redlock-auth&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    &quot;/login&quot;: {\r\n      &quot;post&quot;: {\r\n        &quot;tags&quot;: [\r\n          &quot;Login&quot;\r\n        ],\r\n        &quot;summary&quot;: &quot;Login&quot;,\r\n        &quot;description&quot;: &quot;Returns a JWT auth token for accessing the Prisma Cloud APIs.  To generate a token, you must have an access key and include the following values in the request body parameter — access key ID as the username and your secret key as the password. Prisma Cloud requires this JWT in the request header to authorize API access. Note that access keys maintain the same level of permissions as the permission group of the account that created them. &quot;,\r\n        &quot;operationId&quot;: &quot;app-login&quot;,\r\n        &quot;consumes&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;produces&quot;: [\r\n          &quot;application/json; charset=UTF-8&quot;\r\n        ],\r\n        &quot;parameters&quot;: [\r\n          {\r\n            &quot;in&quot;: &quot;body&quot;,\r\n            &quot;name&quot;: &quot;body&quot;,\r\n            &quot;description&quot;: &quot;Model used for authentication&quot;,\r\n            &quot;required&quot;: true,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/LoginModel&quot;\r\n            }\r\n          }\r\n        ],\r\n        &quot;responses&quot;: {\r\n          &quot;200&quot;: {\r\n            &quot;description&quot;: &quot;successful operation&quot;,\r\n            &quot;schema&quot;: {\r\n              &quot;$ref&quot;: &quot;#/definitions/LoginResponseModel&quot;\r\n            }\r\n          },\r\n          &quot;401&quot;: {\r\n            &quot;description&quot;: &quot;sso_enabled_password_login_attempt / invalid_credentials&quot;\r\n          },\r\n          &quot;500&quot;: {\r\n            &quot;description&quot;: &quot;login_failed_unknown_error&quot;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n2. endpoint-descriptions.json (look-up file)\r\n```\r\n{\r\n  &quot;update-cloud-account&quot;: {\r\n    &quot;path&quot;: &quot;/cloud/{cloud_type}/{id}&quot;,\r\n    &quot;description&quot;: &quot;The request body parameters differ depending on the cloud type of the account you want to add.&quot;\r\n  },\r\n  &quot;app-login&quot;: {\r\n    &quot;path&quot;: &quot;/login&quot;,\r\n    &quot;description&quot;: &quot;If you are a multi-tenant user and the body parameters of your login request include a user name and password instead of an access key ID and secret key. &quot;\r\n  },\r\n  &quot;cloud-app-provisioner&quot;: {\r\n    &quot;path&quot;: &quot;/cloud/app_provisioner&quot;,\r\n    &quot;description&quot;: &quot;The payload will be variable&quot;\r\n  },\r\n  &quot;add-cloud-account&quot;: {\r\n    &quot;path&quot;: &quot;/cloud&quot;,\r\n    &quot;description&quot;: &quot;The request body parameters differ depending on the cloud type&quot;\r\n  }\r\n}\r\n\r\n```\r\n\r\nWhat needs to be done?\r\n\r\nI am trying to traverse the first file (swagger.json) and append each endpoint&#39;s description with the content from the look-up file (endpoint-descriptions.json) based on the operationId which acts as a key in the second file.\r\n\r\nHere&#39;s how far I got:\r\n```\r\njq -s &#39;{&quot;swagger&quot;: .[0], &quot;endpoint_descriptions&quot;: .[1]}&#39; swagger.json endpoint-descriptions.json | \\\r\njq &#39;.swagger | .paths[][].description |= . + $endpoint_descriptions[&quot;I do not know how to reference the proper operationId here&quot;].description\r\n```",
        "link": "https://stackoverflow.com/questions/75551855/using-jq-traverse-swagger-file-and-append-each-endpoints-description-with-the",
        "title": "Using jq, traverse swagger file and append each endpoint&#39;s description with the content from a lookup table where operationId acts as a key"
    },
    {
        "tags": [
            "bash",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677228073,
                "creation_date": 1677228073,
                "answer_id": 75554312,
                "question_id": 75554178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[stedolan/jq](https://github.com/stedolan/jq) would be a good choice to process JSON content. But the content of `$default` is not valid JSON (it lacks string quoting, coompare it to the file&#39;s content which *is* valid JSON).\r\n\r\nHowever, the variable&#39;s content is valid YAML (a superset of JSON), so using a YAML-processor will work. Here are a few options:\r\n\r\n#### Using [itchyny/gojq](https://github.com/itchyny/gojq):\r\n```sh\r\ngojq --yaml-input --slurpfile in override.json &#39;. * $in[0]&#39; &lt;&lt;&lt; &quot;$default&quot;\r\n```\r\n```json\r\n{\r\n  &quot;admin&quot;: {\r\n    &quot;enabled&quot;: true\r\n  },\r\n  &quot;horses&quot;: {\r\n    &quot;count&quot;: 1,\r\n    &quot;fizz&quot;: &quot;buzz&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  }\r\n}\r\n```\r\n\r\n#### Using [kislyuk/yq](https://github.com/kislyuk/yq):\r\n```sh\r\nyq --argfile in override.json &#39;. * $in&#39; &lt;&lt;&lt; &quot;$default&quot;\r\n```\r\n```json\r\n{\r\n  &quot;horses&quot;: {\r\n    &quot;count&quot;: 1,\r\n    &quot;fizz&quot;: &quot;buzz&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;admin&quot;: {\r\n    &quot;enabled&quot;: true\r\n  }\r\n}\r\n```\r\n\r\n#### Using [mikefarah/yq](https://github.com/mikefarah/yq):\r\n```sh\r\nyq -o json &#39;. * load(&quot;override.json&quot;)&#39; &lt;&lt;&lt; &quot;$default&quot;\r\n```\r\n```json\r\n{\r\n  &quot;horses&quot;: {\r\n    &quot;count&quot;: 1,\r\n    &quot;fizz&quot;: &quot;buzz&quot;,\r\n    &quot;foo&quot;: &quot;bar&quot;\r\n  },\r\n  &quot;admin&quot;: {\r\n    &quot;enabled&quot;: true\r\n  }\r\n}\r\n```\r\n",
                "title": "Recursive merge JSON string with file using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677243343,
                "last_edit_date": 1677243343,
                "creation_date": 1677229499,
                "answer_id": 75554544,
                "question_id": 75554178,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Incidentally, your `default` variable is _almost_ (!) valid jq program/filter (albeit not valid JSON). If you quote the value in the `fizz:buzz` line (change to `fizz: &quot;buzz&quot;`), then you could use it directly as the LHS of the recursive-merge operator:\r\n\r\n```\r\njq &quot;$default * .&quot; override.json\r\n```\r\n\r\n*****\r\n\r\nWith the updated question (which now has valid JSON in the `default` variable), jq should be invoked as follows:\r\n\r\n```\r\njq --argjson defaults &quot;$default&quot; &#39;$defaults * .&#39; override.json\r\n```",
                "title": "Recursive merge JSON string with file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1677243343,
        "creation_date": 1677227247,
        "last_edit_date": 1677232318,
        "question_id": 75554178,
        "body_markdown": "I have a bash string `default` with content\r\n```\r\n$ echo $default\r\n{\r\n    &quot;horses&quot;: {\r\n        &quot;count&quot;: 0,\r\n        &quot;fizz&quot;: &quot;buzz&quot;\r\n    },\r\n    &quot;admin&quot;: {\r\n        &quot;enabled&quot;: false\r\n    }\r\n}\r\n```\r\n\r\nand a file `override.json` with content\r\n\r\n```\r\n$ cat override.json\r\n{\r\n    &quot;horses&quot;: {\r\n        &quot;count&quot;: 1,\r\n        &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;admin&quot;: {\r\n        &quot;enabled&quot;: true\r\n    }\r\n}\r\n```\r\n\r\n\r\nI want to recursively merge these using `jq` to produce the result \r\n```\r\n{\r\n    &quot;horses&quot;: {\r\n        &quot;count&quot;: 1,\r\n        &quot;foo&quot;: &quot;bar&quot;,\r\n        &quot;fizz&quot;: &quot;buzz&quot;\r\n    },\r\n    &quot;admin&quot;: {\r\n        &quot;enabled&quot;: true\r\n    }\r\n}\r\n```\r\n\r\n\r\nI&#39;ve tried to understand the docs and a few things like \r\n```\r\njq -s &#39;.[0] * .[1]&#39; $(echo $default) override.json\r\n```\r\nbut my bash and stream skills are limited.",
        "link": "https://stackoverflow.com/questions/75554178/recursive-merge-json-string-with-file-using-jq",
        "title": "Recursive merge JSON string with file using jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "rename"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677235692,
                "last_edit_date": 1677235692,
                "creation_date": 1677233722,
                "answer_id": 75555266,
                "question_id": 75555150,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Please specify [which implementation](https://stackoverflow.com/tags/yq/info) of `yq` you are using. As you are referring to examples for the `contains` filter in the manual to [stedolan/jq](https://github.com/stedolan/jq), I assume you are using [kislyuk/yq](https://github.com/kislyuk/yq), which is a YAML-wrapper around jq.\r\n\r\njq&#39;s `contains` [tests](https://stedolan.github.io/jq/manual/#contains%28element%29) if its argument is partially contained in the input. As this is done recursively, it also affects the string items of your array, not only the surrounding array itself. And as `&quot;pe&quot;` is contained in `&quot;hyper&quot;`, it evaluates to `true`.\r\n\r\njq [offers](https://stedolan.github.io/jq/manual/#any%2Cany%28condition%29%2Cany%28generator%3Bcondition%29) the `any` filter to test if in a given stream at least one item evaluates to `true` for a given filter. For that filter you could use the equals `==` operator which evaluates to `true` for exact matches, and for the stream, if omitted, `any` will [default](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L184) to the items of an input array.\r\n\r\n```sh\r\n$ yq -n &#39;[&quot;hyper&quot;] | any(. == &quot;pe&quot;)&#39;\r\nfalse\r\n```\r\n\r\n```sh\r\n$ yq -n &#39;[&quot;hyper&quot;] | any(. == &quot;hyper&quot;)&#39;\r\ntrue\r\n```\r\n\r\n---\r\nJust in case, if you do use the other implementation [mikefarah/yq](https://github.com/mikefarah/yq), it [offers](https://mikefarah.gitbook.io/yq/operators/boolean-operators#any_c-returns-true-if-any-element-in-the-array-is-true-for-the-given-condition.) a similar function called `any_c` (as it is not based on jq and hence has a (sometimes) different syntax):\r\n\r\n```sh\r\n$ yq -n &#39;[&quot;hyper&quot;] | any_c(. == &quot;pe&quot;)&#39;\r\nfalse\r\n```\r\n\r\n```sh\r\n$ yq -n &#39;[&quot;hyper&quot;] | any_c(. == &quot;hyper&quot;)&#39;\r\ntrue\r\n```",
                "title": "how to test if array contains item, as is, not some subset of it"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677240517,
                "creation_date": 1677240517,
                "answer_id": 75556393,
                "question_id": 75555150,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming a jq-like implementation, you&#39;d use [`IN`](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) (capitalized)\r\n\r\n```sh\r\n$ jq -n --arg elem &quot;pe&quot;    &#39;[&quot;hyper&quot;] as $list | $elem | IN($list[])&#39;\r\nfalse\r\n\r\n$ jq -n --arg elem &quot;hyper&quot; &#39;[&quot;hyper&quot;] as $list | $elem | IN($list[])&#39;\r\ntrue\r\n```\r\n\r\nThe argument to `IN()` is a _stream_ of elements, not an array.",
                "title": "how to test if array contains item, as is, not some subset of it"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1677382062,
        "creation_date": 1677233021,
        "last_edit_date": 1677382062,
        "question_id": 75555150,
        "body_markdown": "So it seems that I fell for *contains* function definition, since:\r\n\r\n    yq -n &#39;[&quot;hyper&quot;]|contains([&quot;pe&quot;])&#39;\r\n\r\n&#39;surprisingly&#39; returns true. I don&#39;t know what usecase this have, still new to funcitolan world but it&#39;s clearly shown in docs as:\r\n\r\n    jq &#39;contains([&quot;baz&quot;, &quot;bar&quot;])&#39;\r\n    Input\t[&quot;foobar&quot;, &quot;foobaz&quot;, &quot;blarp&quot;]\r\n    Output\ttrue\r\n\r\nSo how to trivially write exact matching, string-is-contained-in-array-contains?\r\n\r\n    yq -n &#39;[&quot;hyper&quot;] as $i | $i - [&quot;pe&quot;] != $i&#39;\r\n\r\n? Or what would be correct solution?",
        "link": "https://stackoverflow.com/questions/75555150/how-to-test-if-array-contains-item-as-is-not-some-subset-of-it",
        "title": "how to test if array contains item, as is, not some subset of it"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 27823633,
                    "reputation": 31,
                    "user_id": 21243474,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3b7b4ad783c7bd296d4a9255e1703f0f?s=256&d=identicon&r=PG",
                    "display_name": "stickyIcky",
                    "link": "https://stackoverflow.com/users/21243474/stickyicky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677264465,
                "post_id": 75560037,
                "comment_id": 133310153,
                "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": 1677265223,
                "post_id": 75560037,
                "comment_id": 133310345,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677262851,
                "creation_date": 1677262851,
                "answer_id": 75560094,
                "question_id": 75560037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `with_entries`, and update `|=` the `.key`:\r\n```sh\r\njq --arg u &#39;user&#39; &#39;with_entries(.key |= $u + &quot;.&quot; + .)&#39; file.txt\r\n```\r\n```json\r\n{\r\n  &quot;user.user1&quot;: 10,\r\n  &quot;user.joe&quot;: 13,\r\n  &quot;user.jane&quot;: 55\r\n}\r\n```",
                "title": "Use jq to rename object keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677262851,
        "creation_date": 1677262381,
        "last_edit_date": 1677262712,
        "question_id": 75560037,
        "body_markdown": "I have something that is probably simple for someone with experience with jq.  I have a file.txt with this in it:\r\n\r\n{&quot;user1&quot;: 10, &quot;joe&quot;: 13, &quot;jane&quot;: 55}\r\n\r\nI would like to format this so that it produces the following result:\r\n\r\n```\r\ncat file.txt |jq \\&lt;???\\&gt;\r\n\r\n{\r\n&quot;user.user1&quot;: 10,\r\n&quot;user.joe&quot;: 13,\r\n&quot;user.jane&quot;: 55,\r\n}\r\n\r\n```\r\nMy goal is to be able to query by something like &quot;user = user.\\*&quot; and get a result of all the users because the specific usernames will vary.\r\n\r\nThis is as far as I have been able to get:\r\n\r\n```\r\ncat file.txt |jq --arg v &#39;user&#39; --arg k &#39;key&#39;  &#39;\\[.\\]| to_entries\\[\\]|.\\[$k\\] = $v&#39;\r\n{\r\n&quot;key&quot;: &quot;user&quot;,\r\n&quot;value&quot;: {\r\n&quot;user1&quot;: 10,\r\n&quot;joe&quot;: 13,\r\n&quot;jane&quot;: 55\r\n}\r\n}\r\n```\r\n\r\nBut that does not give me the ability to query by user.",
        "link": "https://stackoverflow.com/questions/75560037/use-jq-to-rename-object-keys",
        "title": "Use jq to rename object keys"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "command-line-interface",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677272603,
                "post_id": 75560114,
                "comment_id": 133311992,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1677267305,
                "last_edit_date": 1677267305,
                "creation_date": 1677265532,
                "answer_id": 75560441,
                "question_id": 75560114,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the niftiest way would be to use `from_entries`.  E.g. for the &quot;OS&quot; key:\r\n\r\n    .Tags | from_entries | .OS\r\n\r\n\r\nMore generally, but more verbosely, you could go with:\r\n\r\n    .Tags | first( .[] | select(.Key == &quot;OS&quot;) | .Value)\r\n\r\nor if you&#39;re concerned about the result if the specified key is not present:\r\n```\r\n.Tags | first( .[] | select(.Key == &quot;OS&quot;) // {} | .Value)\r\n```\r\n\r\n---\r\n\r\nWithout seeing a complete sample, it&#39;s hard to say exactly what the most economical expression would be, but piggy-backing off your example, you could go with something like:\r\n\r\n\r\n    [.InstanceId, .State.Name] +\r\n     [.Tags | from_entries | (.OS, .Role)]\r\n\r\n",
                "title": "jq json - select by key name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1677312187,
        "creation_date": 1677262955,
        "last_edit_date": 1677312187,
        "question_id": 75560114,
        "body_markdown": "I&#39;m using jq to try to parse some details from an AWS CLI query.&lt;br&gt;\r\nExample JSON:\r\n```\r\n                    &quot;Tags&quot;: [\r\n                        {\r\n                            &quot;Key&quot;: &quot;Name&quot;,\r\n                            &quot;Value&quot;: &quot;db01&quot;\r\n                        },\r\n                        {\r\n                            &quot;Key&quot;: &quot;BackupResourceType&quot;,\r\n                            &quot;Value&quot;: &quot;EC2&quot;\r\n                        },\r\n                        {\r\n                            &quot;Key&quot;: &quot;Role&quot;,\r\n                            &quot;Value&quot;: &quot;db_edi01&quot;\r\n                        },\r\n                        {\r\n                            &quot;Key&quot;: &quot;OS&quot;,\r\n                            &quot;Value&quot;: &quot;Ubuntu 18.04&quot;\r\n                        }\r\n                    ],\r\n  ```\r\nThe issue I&#39;m running into is these tag values aren&#39;t in a consistent order.  Is there a way I can select the value where key=OS instead of selecting the specific array value?\r\n\r\n```[.InstanceId, .State.Name, .Tags[1].Value, .Tags[0].Value, etc]```\r\n\r\nThanks for the help!",
        "link": "https://stackoverflow.com/questions/75560114/jq-json-select-by-key-name",
        "title": "jq json - select by key name"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "projection"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677492852,
                "post_id": 75578288,
                "comment_id": 133341617,
                "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": 1677493007,
                "post_id": 75578288,
                "comment_id": 133341644,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1677487408,
                "creation_date": 1677487408,
                "answer_id": 75578334,
                "question_id": 75578288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the select function in jq to filter a JSON object based on the keys being in an array. for example \r\njq &#39;select(keys_unmatched([&quot;name&quot;, &quot;city&quot;]) | not)&#39; file.json\r\n",
                "title": "How can I filter json basing on keys being in array in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677487546,
                "creation_date": 1677487546,
                "answer_id": 75578346,
                "question_id": 75578288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is not JSON but javascript:\r\n\r\n    $ node\r\n    Welcome to Node.js v19.7.0.\r\n    Type &quot;.help&quot; for more information.\r\n    &gt; ARRAY=[&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;]\r\n    [ &#39;keyA&#39;, &#39;keyC&#39;, &#39;keyE&#39; ]\r\n    &gt; JSON={\r\n    ...   &quot;keyA&quot;: &quot;valueA&quot;,\r\n    ...   &quot;keyB&quot;: &quot;valueB&quot;,\r\n    ...   &quot;keyC&quot;: &quot;valueC&quot;,\r\n    ...   &quot;keyD&quot;: &quot;valueD&quot;,\r\n    ...   &quot;keyE&quot;: &quot;valueE&quot;,\r\n    ...   &quot;keyF&quot;: &quot;valueF&quot;\r\n    ... }\r\n    {\r\n      keyA: &#39;valueA&#39;,\r\n      keyB: &#39;valueB&#39;,\r\n      keyC: &#39;valueC&#39;,\r\n      keyD: &#39;valueD&#39;,\r\n      keyE: &#39;valueE&#39;,\r\n      keyF: &#39;valueF&#39;\r\n    }\r\n    &gt; \r\n    &gt; var j = {}\r\n    &gt; ARRAY.forEach(elt =&gt; j[elt] = JSON[elt] )\r\n    &gt; console.log(j)\r\n    { keyA: &#39;valueA&#39;, keyC: &#39;valueC&#39;, keyE: &#39;valueE&#39; }\r\n\r\n",
                "title": "How can I filter json basing on keys being in array in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677492169,
                "creation_date": 1677492169,
                "answer_id": 75579027,
                "question_id": 75578288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq —-argjson a &quot;$ARRAY&quot; &#39;\r\n  def project($a): . as $in\r\n  | reduce $a[] as $k (null;.[$k] =$in[$k]); \r\n  project($a)&#39; &lt;&lt;&lt; &quot;$JSON&quot;\r\n```",
                "title": "How can I filter json basing on keys being in array in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677492958,
                "last_edit_date": 1677492958,
                "creation_date": 1677492390,
                "answer_id": 75579078,
                "question_id": 75578288,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one possible solution using [`reduce`](https://stedolan.github.io/jq/manual/#Reduce):\r\n\r\n```\r\n. as $obj\r\n| reduce [&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;][] as $key (\r\n    {}; .[$key] = $obj[$key]\r\n)\r\n```\r\n\r\nOr with user-provided variables:\r\n\r\n```\r\njq --argjson keys &#39;[&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;]&#39; &#39;. as $obj\r\n| reduce $keys[] as $key ({}; .[$key] = $obj[$key])\r\n```\r\n\r\n*****\r\n\r\nIf you don&#39;t care about the order of keys in the result (there is no inherent meaning to order of keys in JSON objects, because they are a bag of key-value pairs without order), then an alternative would be using [`with_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries), although it will be slower for large inputs:\r\n\r\n```\r\njq --argjson keys &#39;[&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;]&#39; &#39;with_entries(select(.key | IN($keys[])))&#39;\r\n```\r\n\r\nbut this could be avoided by building a lookup/index object first:\r\n\r\n```\r\njq --argjson keys &#39;[&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;]&#39; &#39;INDEX($keys[]; .) as $keys\r\n| with_entries(select(.key | in($keys)))&#39;\r\n```",
                "title": "How can I filter json basing on keys being in array in JQ"
            }
        ],
        "is_answered": false,
        "answer_count": 4,
        "score": -2,
        "last_activity_date": 1677498691,
        "creation_date": 1677487011,
        "last_edit_date": 1677498691,
        "question_id": 75578288,
        "body_markdown": "How can this be achieved?\r\n\r\nThose are inputs:\r\n\r\n    ARRAY=[&quot;keyA&quot;, &quot;keyC&quot;, &quot;keyE&quot;]\r\n    JSON={\r\n      &quot;keyA&quot;: &quot;valueA&quot;,\r\n      &quot;keyB&quot;: &quot;valueB&quot;,\r\n      &quot;keyC&quot;: &quot;valueC&quot;,\r\n      &quot;keyD&quot;: &quot;valueD&quot;,\r\n      &quot;keyE&quot;: &quot;valueE&quot;,\r\n      &quot;keyF&quot;: &quot;valueF&quot;\r\n    }\r\n\r\nSo basing on what I have in `ARRAY` (keys) how can I output corresponding keys and values from `JSON` in order to have `TARGET_JSON` like this:\r\n\r\n    TARGET_JSON={\r\n      &quot;keyA&quot;: &quot;valueA&quot;,\r\n      &quot;keyC&quot;: &quot;valueC&quot;,\r\n      &quot;keyE&quot;: &quot;valueE&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/75578288/how-can-i-filter-json-basing-on-keys-being-in-array-in-jq",
        "title": "How can I filter json basing on keys being in array in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677489587,
                "post_id": 75578551,
                "comment_id": 133340749,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677489771,
                "last_edit_date": 1677489771,
                "creation_date": 1677489532,
                "answer_id": 75578619,
                "question_id": 75578551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the [array value iterator `[]`](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]) in combination with the [(arithmetic)](https://stedolan.github.io/jq/manual/#Arithmeticupdate-assignment:+=,-=,*=,/=,%=,//=) [update-assignment operator `|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=).\r\n\r\nTo update all `someValue`s:\r\n\r\n```\r\n.very.&quot;un-fortunate&quot;.&quot;p-a-t-h&quot;[].someValue |= . + 10\r\n```\r\n\r\nor\r\n\r\n```\r\n.very.&quot;un-fortunate&quot;.&quot;p-a-t-h&quot;[].someValue += 10\r\n```\r\n\r\nTo update only `someValue`s which are odd, filter through [`select`](https://stedolan.github.io/jq/manual/#select(boolean_expression)) and don&#39;t forget to parenthesize the LHS):\r\n\r\n```\r\n(.very.&quot;un-fortunate&quot;.&quot;p-a-t-h&quot;[].someValue | select(. % 2 != 0)) += 10\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;very&quot;: {\r\n    &quot;un-fortunate&quot;: {\r\n      &quot;p-a-t-h&quot;: {\r\n        &quot;first&quot;: {\r\n          &quot;veryDeepSubTree&quot;: {},\r\n          &quot;someValue&quot;: 11\r\n        },\r\n        &quot;second&quot;: {\r\n          &quot;veryDeepSubTree&quot;: {},\r\n          &quot;someValue&quot;: 2\r\n        },\r\n        &quot;third&quot;: {\r\n          &quot;veryDeepSubTree&quot;: {},\r\n          &quot;someValue&quot;: 13\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nBut even recursive descent would work, you just have to make sure to only select the correct values:\r\n\r\n```\r\n(.. | objects | .someValue | values | select(. % 2 != 0)) += 10\r\n```\r\n\r\nor\r\n\r\n```\r\n(.. | .someValue? | values | select(. % 2 != 0)) += 10\r\n```\r\n\r\nOutput is identical to above.",
                "title": "updating fields matching condition under not nice path"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677497573,
                "last_edit_date": 1677497573,
                "creation_date": 1677496971,
                "answer_id": 75579825,
                "question_id": 75578551,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following approach using `walk` is worth knowing about:\r\n\r\n    walk(if try (.someValue % 2 != 0) catch false then .somevalue += 10 else . end)\r\n\r\nOr with fewer keystrokes:\r\n\r\n    walk(if (.someValue% 2 != 0)? // null then .somevalue += 10 else . end)\r\n\r\nOr a bit more targeted:\r\n\r\n    (try (.[][][][].someValue) | select(. % 2 != 0)) += 10",
                "title": "updating fields matching condition under not nice path"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1677497573,
        "creation_date": 1677489120,
        "question_id": 75578551,
        "body_markdown": "I need very often update conditionally some fields in subtree to which leads ugly path. I kinda can solve it, but it&#39;s very ugly solution, I&#39;d like to know if there is smth better.\r\n\r\n**Sample input**:\r\n\r\n    {\r\n      &quot;very&quot;: {\r\n        &quot;un-fortunate&quot;: {\r\n          &quot;p-a-t-h&quot;: {\r\n            &quot;first&quot;: {\r\n              &quot;veryDeepSubTree&quot;: {},\r\n              &quot;someValue&quot;: 1\r\n            },\r\n            &quot;second&quot;: {\r\n              &quot;veryDeepSubTree&quot;: {},\r\n              &quot;someValue&quot;: 2\r\n            },\r\n            &quot;third&quot;: {\r\n              &quot;veryDeepSubTree&quot;: {},\r\n              &quot;someValue&quot;: 3\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n**desired output**: say that I would like to add 10 to _someValue_. Suppose that I cannot use recursive descent, for example I want to update only odd _someValue_.\r\n\r\nI can write solution like this:\r\n\r\n    jq &#39;.very|=(.[&quot;un-fortunate&quot;]|=(.[&quot;p-a-t-h&quot;] |=(  . as $root| reduce keys[] as $k ({}; . + {($k): ($root|.[$k]|.someValue|=(.+10))})      )))&#39;\r\n\r\nbut it&#39;s hard to read and write (matching brackets)...\r\n\r\nexplained motivation, based on my (_mis_?)understanding:\r\n- iiuc I need to bracket every non-trivial right operand of |= , especially if there are more of them, otherwise it does not compile\r\n- I cannot express longer path than just one field at a time, if path is sufficiently ugly\r\n- there isn&#39;t other way(maybe except foreach, which I cannot understand) to update all items of object, than using reduce to copy all into new updating value, and update each part in update clause of reduce command\r\n\r\n\r\nquestions:\r\n- is there some better way of expressing unfortunate path from tree root? \r\n- can I express it somehow easier than via using this reduce over keys, and putting field update logic into accumulator part of reduce command?\r\n- if you are writing commands into shell, how do you do it so that you can easily edit it + it&#39;s readable?",
        "link": "https://stackoverflow.com/questions/75578551/updating-fields-matching-condition-under-not-nice-path",
        "title": "updating fields matching condition under not nice path"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1677508902,
                "post_id": 75581831,
                "comment_id": 133346214,
                "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": 1677508969,
                "post_id": 75581831,
                "comment_id": 133346231,
                "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": 1677509030,
                "post_id": 75581831,
                "comment_id": 133346248,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677511014,
                "post_id": 75581831,
                "comment_id": 133346987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677522470,
                "last_edit_date": 1677522470,
                "creation_date": 1677509796,
                "answer_id": 75582032,
                "question_id": 75581831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n$ IDS=(1 2 3 4)\r\n$ jq &#39;.[] | select(IN(.id; $ARGS.positional[])) .value&#39; file.json --jsonargs &quot;${IDS[@]}&quot;\r\n10\r\n100\r\n5\r\n17\r\n```",
                "title": "Select values that match an element in bash array in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677510239,
                "last_edit_date": 1677510239,
                "creation_date": 1677509806,
                "answer_id": 75582035,
                "question_id": 75581831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`--arg`][1] and then convert the Bash array to JSON integers:  \r\n```none\r\n($IDS | split(&quot; &quot;) | map(tonumber)) as $PIDS\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nCombine that with [`select()`][2] and [`index()`][3]:\r\n\r\n```bash\r\njq \\\r\n    --arg IDS &quot;${IDS[*]}&quot; \\\r\n    &#39;($IDS | split(&quot; &quot;) | map(tonumber)) as $PIDS | \r\n        .[] | select([.id] | index($PIDS[])).value&#39; \\\r\ninput\r\n```\r\n\r\nGives:\r\n```none\r\n10\r\n100\r\n5\r\n17\r\n```\r\n\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Invokingjq\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [3]: https://stedolan.github.io/jq/manual/#index(s),rindex(s)",
                "title": "Select values that match an element in bash array in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677520062,
                "last_edit_date": 1677520062,
                "creation_date": 1677510627,
                "answer_id": 75582204,
                "question_id": 75581831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach is to create a map of acceptable IDs and then do lookups within it:\r\n\r\n```\r\nids=( 1 2 3 4 )\r\n\r\njq --arg idstr &quot;${ids[*]}&quot; &#39;\r\n  ([$idstr | split(&quot; &quot;)[] | {&quot;key&quot;: ., &quot;value&quot;: true}] | from_entries) as $idmap\r\n  | .[] | select($idmap[.id | tostring]).value&#39;\r\n```",
                "title": "Select values that match an element in bash array in JQ"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677521347,
                "creation_date": 1677521347,
                "answer_id": 75584055,
                "question_id": 75581831,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Alternatively, pass `ids` individual array elements as arguments to `jq` using  `--args &quot;${ids[@]}&quot;` and read the values back into a bash array with `mapfile`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nids=( 1 2 3 4 )\r\n\r\nmapfile -t values &lt; &lt;(\r\n\r\njq &#39;\r\n  (\r\n    [$ARGS.positional[] | {&quot;key&quot;: ., &quot;value&quot;: true}] |\r\n    from_entries\r\n  ) as $idmap |\r\n  .[] |\r\n  select($idmap[.id | tostring]).value&#39; \\\r\n  input.json \\\r\n  --args &quot;${ids[@]}&quot; \r\n)\r\n\r\n# Debug show content of values array\r\ndeclare -p values\r\n```\r\n\r\nSample output:\r\n```sh\r\ndeclare -a values=([0]=&quot;10&quot; [1]=&quot;100&quot; [2]=&quot;5&quot; [3]=&quot;17&quot;)\r\n```",
                "title": "Select values that match an element in bash array in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 1,
        "last_activity_date": 1677522470,
        "creation_date": 1677508534,
        "last_edit_date": 1677511552,
        "question_id": 75581831,
        "body_markdown": "I need to run a script where I have an array of ids, and a json that contains elements with these ids and more data. I need to filter/select the values that matches the ones in the array. For some reason, when running directly on bash I got good results with some of the things I&#39;ve tried, but not when running with a script. Not sure if this may be relevant or I did something wrong when passing from one to the other\r\n\r\nFor example, if I have a json file like\r\n\r\n```\r\n[\r\n {\r\n   &quot;id&quot;: 1,\r\n   &quot;value&quot;: 10\r\n },   \r\n {\r\n   &quot;id&quot;: 2,\r\n   &quot;value&quot;: 100\r\n },\r\n {\r\n   &quot;id&quot;: 3,\r\n   &quot;value&quot;: 5\r\n },\r\n {\r\n   &quot;id&quot;: 4,\r\n   &quot;value&quot;: 17\r\n },\r\n {\r\n   &quot;id&quot;: 5,\r\n   &quot;value&quot;: 84\r\n }\r\n]\r\n```\r\n\r\nAnd the following array:\r\n```\r\nIDS=(1 2 3 4)\r\n```\r\n\r\nI need to retrieve the values 10, 100, 5 and 17.\r\n\r\nI&#39;ve tried some ways:\r\n\r\n```\r\nVALUES=$(jq --argjson IDS &quot;$IDS&quot; &#39;.[] | select( $IDS =~ .id ) | .value&#39; file.json)\r\nVALUES=$(jq --argjson IDS &quot;$IDS&quot; &#39;.[] | select( ${IDS[*]} =~ .id ) | .value&#39; file.json)\r\n# I have certainty that IDS will always have 4 elements, no more no less\r\nVALUES=$(jq --argjson IDS &quot;$IDS&quot; &#39;.[] | select( .id == ${IDS[0]} | .id == ${IDS[1]} | .id == ${IDS[2]} | .id == ${IDS[3]} ) | .value&#39; file.json)\r\n```\r\n\r\nIn all cases I&#39;m getting `unexpected INVALID_CHARACTER (Unix shell quoting issues?)\r\n\r\nAlso, on the last case, when I replaced the ${IDS[n]} for a hardcoded number, it worked fine. Yet, I won&#39;t have the same numbers on each run, so I need that parametrized. \r\n\r\nAny help would be great! \r\n\r\nEDIT\r\n\r\nThanks everyone for the solutions. I kept the one I understood the most for now, but I&#39;m really greatful with all",
        "link": "https://stackoverflow.com/questions/75581831/select-values-that-match-an-element-in-bash-array-in-jq",
        "title": "Select values that match an element in bash array in JQ"
    },
    {
        "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": 1677538813,
                "post_id": 75586322,
                "comment_id": 133354384,
                "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": 1677538879,
                "post_id": 75586322,
                "comment_id": 133354399,
                "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": 1677539008,
                "post_id": 75586322,
                "comment_id": 133354418,
                "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": 1677539130,
                "post_id": 75586322,
                "comment_id": 133354443,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1677538924,
        "creation_date": 1677538369,
        "last_edit_date": 1677538745,
        "question_id": 75586322,
        "body_markdown": "I am trying parse the value of a json property whose key has hyphens in it.\r\n\r\n1. I read the json content into a variable using sub shell commands\r\n`srcJson=$(someshellcommand)`\r\n\r\n2. I pipe the variable into jq read operation (and also pipe it further to sed for some changes - but beside the point)\r\n`value=$(echo $srcJson | jq .root.parent.$srcKey | sed -e &#39;s/\\\\\\&quot;/\\&quot;/g&#39; -e &#39;s/^.//g&#39; -e &#39;s/.$//g&#39;)`\r\n\r\nI am running the code inside a bash script on mac.\r\n\r\nThis approach works just fine if the $srcKey variable does NOT have any hyphens in it, but breaks with the following error if it has hyphens\r\n`jq: error: Part1OfHypenatedKey/0 is not defined at &lt;top-level&gt;`\r\n`jq: error: Part2OfHypenatedKey/0 is not defined at &lt;top-level&gt;`\r\n\r\n\r\nTried putting just the variable with hyphens inside quotes - didnt make a difference\r\n`value=$(echo $srcJson | jq .root.parent.&quot;$srcKey&quot; | sed -e &#39;s/\\\\\\&quot;/\\&quot;/g&#39; -e &#39;s/^.//g&#39; -e &#39;s/.$//g&#39;)`\r\n\r\n\r\nTried putting the entire jq key reference in quote - but didnt work at all, may be i was doing something wrong with the subshell commands &amp; jq (not a bash expert)\r\n`value=$(echo $srcJson | jq &quot;.root.parent.$srcKey&quot; | sed -e &#39;s/\\\\\\&quot;/\\&quot;/g&#39; -e &#39;s/^.//g&#39; -e &#39;s/.$//g&#39;)`",
        "link": "https://stackoverflow.com/questions/75586322/how-to-read-json-value-for-a-key-with-hyphen-within-a-bash-variable-using-jq",
        "title": "How to read json value for a key with hyphen within a bash variable using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677543033,
                "last_edit_date": 1677543033,
                "creation_date": 1677542696,
                "answer_id": 75586722,
                "question_id": 75586686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will return the whole object with the updated value\r\n```\r\n(.projects[] | select(.name == &quot;project1&quot;).autoplan.enabled) |= true\r\n```\r\n\r\nThe `()` around the [`select()`][1] makes the [`|=`][2] not update the value of the complete object, rather just the selected one\r\n\r\n\r\n\r\n\r\n### [Try it online](https://jqplay.org/s/t4X1NL8vwLr)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)\r\n  [2]: https://stedolan.github.io/jq/manual/#Update-assignment:%7C=",
                "title": "How to return input JSON with one changed property in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677551150,
        "creation_date": 1677542197,
        "last_edit_date": 1677551150,
        "question_id": 75586686,
        "body_markdown": "I am trying to make JQ return an output that&#39;s nearly identical to the input, only chaing one property whose sibling matches a string.\r\n\r\nSay an input of:\r\n```json\r\n{\r\n  &quot;version&quot;: 3,\r\n  &quot;projects&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;project1&quot;,\r\n      &quot;autoplan&quot;: { &quot;enabled&quot;: false }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;project2&quot;,\r\n      &quot;autoplan&quot;: { &quot;enabled&quot;: false }\r\n    }\r\n  ],\r\n  &quot;workflows&quot;: {}\r\n}\r\n```\r\n\r\nI&#39;ve gotten close with the following:\r\n```bash\r\njq &#39;.projects[] | select(.name == &quot;project1&quot;).autoplan.enabled |= true&#39;\r\n```\r\nBut the problem is this just returns the projects individually (and without other root properties), like so:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;project1&quot;,\r\n  &quot;autoplan&quot;: { &quot;enabled&quot;: true }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;project2&quot;,\r\n  &quot;autoplan&quot;: { &quot;enabled&quot;: false }\r\n}\r\n```\r\n\r\nHow can I return the data how it was structured originally, but with my changed value? I would rather not have to reassemble an array with the returned items and manually specify each original property.\r\n\r\nI am looking for the following:\r\n```json\r\n{\r\n  &quot;version&quot;: 3,\r\n  &quot;projects&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;project1&quot;,\r\n      &quot;autoplan&quot;: { &quot;enabled&quot;: true }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;project2&quot;,\r\n      &quot;autoplan&quot;: { &quot;enabled&quot;: false }\r\n    }\r\n  ],\r\n  &quot;workflows&quot;: {}\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/75586686/how-to-return-input-json-with-one-changed-property-in-jq",
        "title": "How to return input JSON with one changed property in JQ"
    },
    {
        "tags": [
            "json",
            "jq",
            "elementwise-operations"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1677558610,
                "last_edit_date": 1677558610,
                "creation_date": 1677558218,
                "answer_id": 75587856,
                "question_id": 75587836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be using `--slurpfile` to read in the files as arrays, then use `transpose` and `add` to &quot;zip&quot; them:\r\n```sh\r\njq --slurpfile s1 file1.json --slurpfile s2 file2.json -n \\\r\n  &#39;[$s1, $s2] | transpose[] | add&#39;\r\n```\r\n```json\r\n{\r\n  &quot;k11&quot;: &quot;v111&quot;,\r\n  &quot;k12&quot;: &quot;v112&quot;,\r\n  &quot;k21&quot;: &quot;v211&quot;,\r\n  &quot;k22&quot;: &quot;v212&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v121&quot;,\r\n  &quot;k12&quot;: &quot;v122&quot;,\r\n  &quot;k21&quot;: &quot;v221&quot;,\r\n  &quot;k22&quot;: &quot;v222&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v131&quot;,\r\n  &quot;k12&quot;: &quot;v132&quot;,\r\n  &quot;k21&quot;: &quot;v231&quot;,\r\n  &quot;k22&quot;: &quot;v232&quot;\r\n}\r\n```\r\n\r\n---\r\n&gt; the two object lists (which can easily be turned into arrays)\r\n\r\nIf the two files were already arrays, you can move from using `--slurpfile` to a single `--slurp` (or `-s`), then reading in the files as regular input files instead, and using the same &quot;zipping&quot; technique:\r\n```\r\njq -s &#39;transpose[] | add&#39; arrayfile1.json arrayfile2.json\r\n```\r\n\r\n\r\n\r\n",
                "title": "Can jq add objects in two JSON object lists sequentially?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677572746,
                "last_edit_date": 1677572746,
                "creation_date": 1677567321,
                "answer_id": 75588738,
                "question_id": 75587836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As illustrated by the accepted answer, one approach to the problem is to convert both streams to arrays,\r\nbut this imposes an unnecessary memory requirement, as illustrated by the following solution,\r\nwhich requires that only one of the two streams be &quot;slurped&quot;, and which\r\nincidentally also does not incur the various costs of `transpose`.\r\n\r\n```\r\n&lt; s2 jq -n --slurpfile s1 s1 &#39;\r\n  def zips(s): \r\n    . as $in\r\n    | foreach s as $x (-1; .+1; $in[.] + $x);\r\n  $s1 | zips(inputs)&#39;\r\n```\r\n \r\n",
                "title": "Can jq add objects in two JSON object lists sequentially?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677612468,
                "creation_date": 1677612468,
                "answer_id": 75596480,
                "question_id": 75587836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I know this is cheating, I just wanted to see if it would work: a shell pipeline\r\n```sh\r\npaste -d+ &lt;(jq -c . file1.json) &lt;(jq -c . file2.json) \\\r\n| paste -sd, \\\r\n| xargs -0 jq -n\r\n```",
                "title": "Can jq add objects in two JSON object lists sequentially?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1677612468,
        "creation_date": 1677557845,
        "last_edit_date": 1677572849,
        "question_id": 75587836,
        "body_markdown": "I am seeking the simultaneous iteration of two lists.\r\n\r\nInput object list:\r\n\r\n**First Input Object List**\r\n``` json\r\n{\r\n  &quot;k11&quot;: &quot;v111&quot;,\r\n  &quot;k12&quot;: &quot;v112&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v121&quot;,\r\n  &quot;k12&quot;: &quot;v122&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v131&quot;,\r\n  &quot;k12&quot;: &quot;v132&quot;\r\n}\r\n```\r\n**Second Input Object List**\r\n``` json\r\n{\r\n  &quot;k21&quot;: &quot;v211&quot;,\r\n  &quot;k22&quot;: &quot;v212&quot;\r\n}\r\n{\r\n  &quot;k21&quot;: &quot;v221&quot;,\r\n  &quot;k22&quot;: &quot;v222&quot;\r\n}\r\n{\r\n  &quot;k21&quot;: &quot;v231&quot;,\r\n  &quot;k22&quot;: &quot;v232&quot;\r\n}\r\n```\r\n**Wanted Output Object List**\r\n``` json\r\n{\r\n  &quot;k11&quot;: &quot;v111&quot;,\r\n  &quot;k12&quot;: &quot;v112&quot;\r\n  &quot;k21&quot;: &quot;v211&quot;,\r\n  &quot;k22&quot;: &quot;v212&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v121&quot;,\r\n  &quot;k12&quot;: &quot;v122&quot;\r\n  &quot;k21&quot;: &quot;v221&quot;,\r\n  &quot;k22&quot;: &quot;v222&quot;\r\n}\r\n{\r\n  &quot;k11&quot;: &quot;v131&quot;,\r\n  &quot;k12&quot;: &quot;v132&quot;\r\n  &quot;k21&quot;: &quot;v231&quot;,\r\n  &quot;k22&quot;: &quot;v232&quot;\r\n}\r\n```\r\nThere are no matching keys between the two object lists (which can easily be turned into arrays).\r\nThank you for reading this question.",
        "link": "https://stackoverflow.com/questions/75587836/can-jq-add-objects-in-two-json-object-lists-sequentially",
        "title": "Can jq add objects in two JSON object lists sequentially?"
    },
    {
        "tags": [
            "json",
            "merge",
            "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": 1677612745,
                "post_id": 75596476,
                "comment_id": 133371613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677618991,
                "creation_date": 1677618991,
                "answer_id": 75597380,
                "question_id": 75596476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a couple approaches I found:\r\n\r\nFirst, this is a [known issue](https://github.com/stedolan/jq/issues/957)\r\n\r\nSecond, from the known issues I found this:\r\n\r\n`jq -s &#39;[.[] | to_entries] | flatten | reduce .[] as $dot ({}; .[$dot.key] += $dot.value)&#39;`\r\n\r\ne.g.:\r\n\r\n`echo &#39;{&quot;messages&quot;:[&quot;one&quot;], &quot;keyA&quot;: &quot;valueA&quot;}{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}&#39; | jq -s &#39;[.[] | to_entries] | flatten | reduce .[] as $dot ({}; .[$dot.key] += $dot.value)&#39;`\r\n\r\nproduces:\r\n\r\n```\r\n{\r\n  &quot;messages&quot;: [\r\n    &quot;one&quot;,\r\n    &quot;two&quot;\r\n  ],\r\n  &quot;keyA&quot;: &quot;valueA&quot;,\r\n  &quot;keyB&quot;: &quot;valueB&quot;\r\n}\r\n```\r\n\r\n(as desired)\r\n\r\nThis is from https://github.com/stedolan/jq/issues/502\r\n\r\nAdditionally, inspired by https://github.com/stedolan/jq/issues/957 I was able to do this:\r\n\r\n`echo &#39;{&quot;messages&quot;:[&quot;one&quot;], &quot;keyA&quot;: &quot;valueA&quot;}{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}&#39; | jq -s &#39;.[2].messages = .[0].messages + .[1].messages | .[0] + .[1] + .[2]&#39;`\r\n\r\nWhich also produces the expected output, but in a non-generalized way. The inspiration to store the desired merged array in the third element of the root array is pretty neat (which is why I mention it); then use the existing &quot;right side wins&quot; behavior to insert the properly merged array back into the result.\r\n\r\nLastly, from that same issue, there&#39;s this:\r\n\r\n`echo &#39;{&quot;messages&quot;:[&quot;one&quot;], &quot;keyA&quot;: &quot;valueA&quot;}{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}&#39; | jq -s &#39;.[0] as $o1 | .[1] as $o2 | ($o1 + $o2) | .messages = ($o1.messages + $o2.messages)&#39;`\r\n\r\nwhich is essentially the same non-generalized solution (but perhaps more elegant?) than the temp-storage approach above.",
                "title": "Using jq, how can I merge two (or more) objects with the same keys whose value is an array while concatenating the array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677677496,
                "last_edit_date": 1677677496,
                "creation_date": 1677658658,
                "answer_id": 75601078,
                "question_id": 75596476,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For simple examples such as in the question, the following filter\r\nprovides a simple but principled approach that also qualifies for the “bonus points”:\r\n```\r\n# Assumption: the input and $obj are objects that are array-consistent\r\n# in the sense that if $k is a key of either object, then:\r\n# (a) if .[$k] is an array then $obj[$k] is an array or null, and\r\n# (b) if $obj[$k] is an array, then .[$k] is an array or null\r\n# The output is . + $obj except that array-valued keys are concatenated.\r\n# WARNING: the assumption is not checked.\r\ndef combine($obj):\r\n  . as $in\r\n  | reduce ($obj|keys_unsorted[]) as $key\r\n      ($in;\r\n       if (.[$key] | type) == &quot;array&quot; then .[$key] += $obj[$key]\r\n       else .[$key] = $obj[$key]\r\n       end ) ;\r\n```\r\nOf course, this is not commutative.\r\n\r\nFor more than two objects, simply use `reduce`, e.g. for an array of objects:\r\n\r\n    def combine: if length==0 then . else reduce .[] as $_ ([]; combine($_)):",
                "title": "Using jq, how can I merge two (or more) objects with the same keys whose value is an array while concatenating the array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1677677496,
        "creation_date": 1677612424,
        "question_id": 75596476,
        "body_markdown": "Imagine we have two json objects:\r\n\r\n`{&quot;messages&quot;:[&quot;one&quot;], &quot;keyA&quot;: &quot;valueA&quot;}`\r\n\r\nand\r\n\r\n`{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}`\r\n\r\nI expect there&#39;s a way to merge these two objects while concatenating the array values, such that the resulting object would be:\r\n\r\n`{&quot;messages&quot;:[&quot;one&quot;,&quot;two&quot;], &quot;keyA&quot;: &quot;valueA&quot;, &quot;keyB&quot;: &quot;valueB&quot;}`\r\n\r\nMost of the approaches I&#39;ve seen thus far to do this are inadequate in that the array gets overwritten by the &quot;right most&quot; object&#39;s version.\r\n\r\ni.e.:\r\n\r\n`echo &#39;{&quot;messages&quot;:[&quot;one&quot;], &quot;keyA&quot;: &quot;valueA&quot;}{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}&#39; | jq -s &#39;.[0] * .[1]&#39;`\r\n\r\nproduces:\r\n\r\n```{\r\n  &quot;messages&quot;: [\r\n    &quot;two&quot;\r\n  ],\r\n  &quot;keyA&quot;: &quot;valueA&quot;,\r\n  &quot;keyB&quot;: &quot;valueB&quot;\r\n}\r\n```\r\n\r\n(NOTE: the `messages` array value only contains `two` (from the second (right-most) object)\r\n\r\nFrom the [jq manual](https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions) on the &quot;add&quot; command:\r\n\r\n&gt; Objects are added by merging, that is, inserting all the key-value pairs from both objects into a single combined object. If both objects contain a value for the same key, the object on the right of the + wins. **(For recursive merge use the * operator.)**\r\n\r\n(emphasis added)\r\n\r\nBut changing the `+` operator to `*` does not appear to change the output.\r\n\r\nI&#39;ve seen https://stackoverflow.com/questions/53661930/jq-recursively-merge-objects-and-concatenate-arrays but... wow... is there no better way?\r\n\r\nBonus points if the solution can handle an object whose array key&#39;s value is `null` as if it were an empty array:\r\n\r\n`{&quot;messages&quot;:null, &quot;keyA&quot;: &quot;valueA&quot;}{&quot;messages&quot;:[&quot;two&quot;], &quot;keyB&quot;: &quot;valueB&quot;}`\r\n",
        "link": "https://stackoverflow.com/questions/75596476/using-jq-how-can-i-merge-two-or-more-objects-with-the-same-keys-whose-value-i",
        "title": "Using jq, how can I merge two (or more) objects with the same keys whose value is an array while concatenating the array?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677681530,
                "post_id": 75605101,
                "comment_id": 133386030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18694845,
                    "reputation": 650,
                    "user_id": 13628404,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a46c22b0cb211aed536eef8810a584d0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "M.M",
                    "link": "https://stackoverflow.com/users/13628404/m-m"
                },
                "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": 1677681776,
                "post_id": 75605101,
                "comment_id": 133386126,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677682162,
                "creation_date": 1677682162,
                "answer_id": 75605276,
                "question_id": 75605101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can read the rows text file using the `-R` option. To iterate over the `inputs`, also use the `-n` option to start with the first line.\r\n\r\n```sh\r\njq -Rn &#39;\r\n  reduce inputs as $row ([]; . += [{reads: [(&quot;first&quot;, &quot;last&quot;) as $sfx | {\r\n    forward: &quot;forward-\\($row)-\\($sfx)&quot;,\r\n    reverse: &quot;reverse-\\($row)-\\($sfx)&quot;\r\n  }]}])\r\n&#39; rows.txt\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;reads&quot;: [\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row1-first&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row1-first&quot;\r\n      },\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row1-last&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row1-last&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;reads&quot;: [\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row2-first&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row2-first&quot;\r\n      },\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row2-last&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row2-last&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "jq create an array with nested strcuture"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677682915,
                "creation_date": 1677682915,
                "answer_id": 75605459,
                "question_id": 75605101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not as clean as [@Pmf&#39;s solution][1], but without `reduce()`, you could `map()` over the rows, and create the desired objects by looping over `[ &quot;first, &quot;last&quot; ]` and create the object for each item:\r\n```\r\njq -Rn &#39;\r\n    [ inputs ] \r\n        | map(. as $tmp \r\n        | { reads: [ ([ &quot;first&quot;, &quot;last&quot; ] \r\n        | map({ forward: &quot;forward-\\($tmp)-\\(.)&quot;, reverse: &quot;reverse-\\($tmp)-\\(.)&quot; })) \r\n    ] \r\n})&#39;  input_file\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;reads&quot;: [\r\n      [\r\n        {\r\n          &quot;forward&quot;: &quot;forward-row1-first&quot;,\r\n          &quot;reverse&quot;: &quot;reverse-row1-first&quot;\r\n        },\r\n        {\r\n          &quot;forward&quot;: &quot;forward-row1-last&quot;,\r\n          &quot;reverse&quot;: &quot;reverse-row1-last&quot;\r\n        }\r\n      ]\r\n    ]\r\n  },\r\n  {\r\n    &quot;reads&quot;: [\r\n      [\r\n        {\r\n          &quot;forward&quot;: &quot;forward-row2-first&quot;,\r\n          &quot;reverse&quot;: &quot;reverse-row2-first&quot;\r\n        },\r\n        {\r\n          &quot;forward&quot;: &quot;forward-row2-last&quot;,\r\n          &quot;reverse&quot;: &quot;reverse-row2-last&quot;\r\n        }\r\n      ]\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/iJzY99Nei3j)\r\n\r\n  [1]: https://stackoverflow.com/a/75605276/5625547",
                "title": "jq create an array with nested strcuture"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1677683008,
        "creation_date": 1677681214,
        "last_edit_date": 1677683008,
        "question_id": 75605101,
        "body_markdown": "I have a file which holds several rows.\r\nfile:\r\n```\r\nrow1\r\nrow2\r\n```\r\nFor each row, I want to create the following, where the first set of reads are suffixed with &quot;first&quot;, and the second is suffixed with &quot;last&quot;\r\n```\r\n[\r\n  {\r\n    &quot;forward&quot;: &quot;forward-row1-first&quot;,\r\n    &quot;reverse&quot;: &quot;reverse-row1-first&quot;\r\n      },\r\n  {\r\n    &quot;forward&quot;: &quot;forward-row1-last&quot;,\r\n    &quot;reverse&quot;: &quot;reverse-row1-last&quot;\r\n      }\r\n]\r\n```\r\n\r\nNext, I would like to combine the above structure for each row in the file as the following:\r\n```\r\n[\r\n  {\r\n    &quot;reads&quot;: [\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row1-first&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row1-first&quot;\r\n      },\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row1-last&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row1-last&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;reads&quot;: [\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row2-first&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row2-first&quot;\r\n      },\r\n      {\r\n        &quot;forward&quot;: &quot;forward-row2-last&quot;,\r\n        &quot;reverse&quot;: &quot;reverse-row2-last&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI have the following code:\r\n```\r\ncreate_json () {\r\n  ROW=&quot;$1&quot;\r\n\r\n  for SUFFIX in 1 2; do\r\n    FORWARD=&quot;forward-${ROW}_${SUFFIX}&quot;\r\n    REVERSE=&quot;reverse-${ROW}_${SUFFIX}&quot;\r\n    jq -n --arg forward &quot;$FORWARD&quot; --arg reverse &quot;$REVERSE&quot; &#39;{forward: $forward, reverse: $reverse}&#39;\r\n  done | jq -n &#39;.reads |= [inputs]&#39;\r\n}\r\n\r\nDATA=()\r\n\r\nwhile read -r line; do\r\n    DATA+=($(create_json $line))\r\ndone &lt; prefixes.txt\r\n\r\necho &quot;${DATA[*]}&quot;\r\n```\r\n\r\nThe problem with this approach is that the json objects for each row from the file are appended to a bash array, and there for the output looks like:\r\n```\r\n{ &quot;reads&quot;: [ { &quot;forward&quot;: &quot;forward-row1_first&quot;, &quot;reverse&quot;: &quot;reverse-row1_first&quot; }, { &quot;forward&quot;: &quot;forward-row1_last&quot;, &quot;reverse&quot;: &quot;reverse-row1_last&quot; } ] } { &quot;reads&quot;: [ { &quot;forward&quot;: &quot;forward-row2_first&quot;, &quot;reverse&quot;: &quot;reverse-row2_first&quot; }, { &quot;forward&quot;: &quot;forward-row2_last&quot;, &quot;reverse&quot;: &quot;reverse-row2_last&quot; } ] }\r\n```\r\n\r\nHow can I use jq in an elegant way to get the desired output format?",
        "link": "https://stackoverflow.com/questions/75605101/jq-create-an-array-with-nested-strcuture",
        "title": "jq create an array with nested strcuture"
    },
    {
        "tags": [
            "json",
            "jq",
            "github-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1677683173,
                "post_id": 75605213,
                "comment_id": 133386631,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1104351,
                    "reputation": 441,
                    "user_id": 1096082,
                    "user_type": "registered",
                    "accept_rate": 22,
                    "profile_image": "https://i.sstatic.net/A4RRr.png?s=256",
                    "display_name": "David Williams",
                    "link": "https://stackoverflow.com/users/1096082/david-williams"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677769314,
                "post_id": 75605213,
                "comment_id": 133406340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677682668,
                "creation_date": 1677682668,
                "answer_id": 75605394,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using `.reviews` you say: Take the complete `reviews` data and reuse it.\r\n\r\nSimilar to what you are doing for the complete list you could also map that array and only extract the required data for each entry:\r\n\r\n`jq &#39;map({ title: .title, URL: .url, author: .author.login, reviews: .reviews | map({ author: .author.login, state: .state }), &quot;merged by&quot;: .mergedBy.login})&#39;`\r\n\r\nThe pipe operator `|` allows you to apply a filter to the result of the `.reviews` expression.",
                "title": "JQ: filter nested array of objects in only include selected fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677682671,
                "creation_date": 1677682671,
                "answer_id": 75605395,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the same technique with `map({…})` as you did on the outer object:\r\n```sh\r\nmap({\r\n  title,\r\n  URL: .url,\r\n  author: .author.login,\r\n  reviews: (.reviews | map({\r\n    author: .author.login,\r\n    state\r\n  })),\r\n  &quot;merged by&quot;: .mergedBy.login\r\n})\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Jedi Training&quot;,\r\n    &quot;URL&quot;: &quot;https://github.com/rebels/training/pull/222&quot;,\r\n    &quot;author&quot;: &quot;luke123&quot;,\r\n    &quot;reviews&quot;: [\r\n      {\r\n        &quot;author&quot;: &quot;han123&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;\r\n      },\r\n      {\r\n        &quot;author&quot;: &quot;leia&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;\r\n      }\r\n    ],\r\n    &quot;merged by&quot;: &quot;luke123&quot;\r\n  }\r\n]\r\n```\r\n\r\nNote: To just replicate a field, e.g. `{title: .title}`, you can shorten it to just `{title}`.",
                "title": "JQ: filter nested array of objects in only include selected fields"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1677682808,
                "creation_date": 1677682808,
                "answer_id": 75605427,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities for preserving the structure:\r\n\r\n\r\n    …, reviews: (.reviews | map({author,state} | .author|= {login})) …\r\n\r\nThe technique of writing {foo} as an abbreviation for {&quot;foo&quot;: .foo} comes in handy.",
                "title": "JQ: filter nested array of objects in only include selected fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677683948,
                "last_edit_date": 1677683948,
                "creation_date": 1677682815,
                "answer_id": 75605429,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can easily nest `map` calls. Just make sure that you group value expressions with a pipe:\r\n\r\n```\r\nmap({\r\n    title,\r\n    URL: .url,\r\n    author: .author.login,\r\n    reviews: (.reviews | map({&quot;reviewed by&quot;: .author.login, state})),\r\n    &quot;merged by&quot;: .mergedBy.login\r\n})\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Jedi Training&quot;,\r\n    &quot;URL&quot;: &quot;https://github.com/rebels/training/pull/222&quot;,\r\n    &quot;author&quot;: &quot;luke123&quot;,\r\n    &quot;reviews&quot;: [\r\n      {\r\n        &quot;reviewed by&quot;: &quot;han123&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;\r\n      },\r\n      {\r\n        &quot;reviewed by&quot;: &quot;leia&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;\r\n      }\r\n    ],\r\n    &quot;merged by&quot;: &quot;luke123&quot;\r\n  }\r\n]\r\n```",
                "title": "JQ: filter nested array of objects in only include selected fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677683793,
                "last_edit_date": 1677683793,
                "creation_date": 1677683485,
                "answer_id": 75605587,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this to extract the required data:\r\n\r\n    jq &#39;[.[] |\r\n        {\r\n          title: .title,\r\n          URL: .url,\r\n          author: .author.login,\r\n          reviews: [.reviews[] | {\r\n            &quot;author&quot;: .author.login,\r\n            &quot;state&quot;: .state\r\n          }],\r\n          &quot;merged by&quot;: .mergedBy.login\r\n        }\r\n      ]&#39; data.json",
                "title": "JQ: filter nested array of objects in only include selected fields"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677755287,
                "creation_date": 1677755287,
                "answer_id": 75614608,
                "question_id": 75605213,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Starting off with your own solution, restricting all nests within &quot;reviews&quot; to two keys - &quot;author&quot; and &quot;state&quot; - and finally, setting &quot;author&quot; to .author.login\r\n\r\n    map({ \r\n      title: .title, \r\n      URL: .url, \r\n      author: .author.login, \r\n      reviews: [(.reviews[] | with_entries(select(.key == &quot;author&quot; or .key == &quot;state&quot;)) | .author=.author.login)], \r\n      &quot;merged by&quot;: .mergedBy.login\r\n    })\r\n\r\nResult:\r\n\r\n    [\r\n      {\r\n        &quot;title&quot;: &quot;Jedi Training&quot;,\r\n        &quot;URL&quot;: &quot;https://github.com/rebels/training/pull/222&quot;,\r\n        &quot;author&quot;: &quot;luke123&quot;,\r\n        &quot;reviews&quot;: [\r\n          {\r\n            &quot;author&quot;: &quot;han123&quot;,\r\n            &quot;state&quot;: &quot;APPROVED&quot;\r\n          },\r\n          {\r\n            &quot;author&quot;: &quot;leia&quot;,\r\n            &quot;state&quot;: &quot;APPROVED&quot;\r\n          }\r\n        ],\r\n        &quot;merged by&quot;: &quot;luke123&quot;\r\n      }\r\n    ]",
                "title": "JQ: filter nested array of objects in only include selected fields"
            }
        ],
        "is_answered": true,
        "answer_count": 6,
        "score": 0,
        "last_activity_date": 1677755287,
        "creation_date": 1677681887,
        "last_edit_date": 1677683074,
        "question_id": 75605213,
        "body_markdown": "Starting with the following, I just want the .title, .url, .author.login, .reviews.author.login, .reviews.state and .mergedBy.login fields? I&#39;m getting close with `map({ title: .title, URL: .url, author: .author.login, reviews: .reviews, &quot;merged by&quot;: .mergedBy.login})` but how do I also limit the fields in the reviews array to author.login and state?\r\n\r\n```\r\n[\r\n  {\r\n    &quot;author&quot;: {\r\n      &quot;id&quot;: &quot;MDQ6VXNlcjYGJOYzNTIw&quot;,\r\n      &quot;is_bot&quot;: false,\r\n      &quot;login&quot;: &quot;luke123&quot;,\r\n      &quot;name&quot;: &quot;Luke&quot;\r\n    },\r\n    &quot;mergedAt&quot;: &quot;2023-01-12T20:29:41Z&quot;,\r\n    &quot;mergedBy&quot;: {\r\n      &quot;id&quot;: &quot;MDQ6VXNlcjYGJOYzNTIw&quot;,\r\n      &quot;is_bot&quot;: false,\r\n      &quot;login&quot;: &quot;luke123&quot;,\r\n      &quot;name&quot;: &quot;Luke&quot;\r\n    },\r\n    &quot;reviews&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;PRR_kwDODrt9D55KSvlh&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;login&quot;: &quot;han123&quot;\r\n        },\r\n        &quot;authorAssociation&quot;: &quot;CONTRIBUTOR&quot;,\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;submittedAt&quot;: &quot;2023-01-12T20:26:50Z&quot;,\r\n        &quot;includesCreatedEdit&quot;: false,\r\n        &quot;reactionGroups&quot;: [],\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;oid&quot;: &quot;ff541b49775eab1ffc63www850dc405ecabc045f&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;PRR_kwDODrt7OM8WHwat&quot;,\r\n        &quot;author&quot;: {\r\n          &quot;login&quot;: &quot;leia&quot;\r\n        },\r\n        &quot;authorAssociation&quot;: &quot;CONTRIBUTOR&quot;,\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;submittedAt&quot;: &quot;2023-01-12T20:29:15Z&quot;,\r\n        &quot;includesCreatedEdit&quot;: false,\r\n        &quot;reactionGroups&quot;: [],\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n        &quot;commit&quot;: {\r\n          &quot;oid&quot;: &quot;dd541b49775eab1ffc63bbb850dc405edhwc045c&quot;\r\n        }\r\n      }\r\n    ],\r\n    &quot;title&quot;: &quot;Jedi Training&quot;,\r\n    &quot;url&quot;: &quot;https://github.com/rebels/training/pull/222&quot;\r\n  },\r\n  ...\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/75605213/jq-filter-nested-array-of-objects-in-only-include-selected-fields",
        "title": "JQ: filter nested array of objects in only include selected fields"
    },
    {
        "tags": [
            "json",
            "date",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1677703630,
                "creation_date": 1677703630,
                "answer_id": 75608845,
                "question_id": 75608793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `gmtime` and `mktime` (see the [manual](https://stedolan.github.io/jq/manual/#Dates)) to convert to and from a &quot;broken down time&quot;, which is an array of items such as year, month, date etc. Substract, and re-assemble:\r\n```sh\r\nnow | gmtime | .[1] -= 6 | mktime | strftime(&quot;%FT%TZ&quot;)\r\n```\r\n[Demo](https://jqplay.org/s/n3UxL1i7f4w)",
                "title": "How to subtract 6 months from today&#39;s date using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1677706860,
        "creation_date": 1677703359,
        "last_edit_date": 1677706860,
        "question_id": 75608793,
        "body_markdown": "I&#39;m getting lost on how to subtract 6 months from today&#39;s date using JQ. \r\n\r\nI know I can get today&#39;s date by doing `(now | todate | split(&quot;T&quot;) | .[0])` but from there I&#39;m not sure the best solution to subtract 6 months. ",
        "link": "https://stackoverflow.com/questions/75608793/how-to-subtract-6-months-from-todays-date-using-jq",
        "title": "How to subtract 6 months from today&#39;s date using JQ?"
    },
    {
        "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": 0,
                "creation_date": 1677746116,
                "post_id": 75612961,
                "comment_id": 133399559,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677747576,
                "creation_date": 1677747576,
                "answer_id": 75613215,
                "question_id": 75612961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get a stream of elements (i.e. multiple JSON documents):\r\n\r\n```\r\n.hits.hits[] | { score: ._score, id: ._id }\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;score&quot;: 1,\r\n  &quot;id&quot;: &quot;1&quot;\r\n}\r\n```\r\n\r\nOr to get a single JSON array:\r\n\r\n```\r\n.hits.hits | map({ score: ._score, id: ._id })\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;score&quot;: 1,\r\n    &quot;id&quot;: &quot;1&quot;\r\n  }\r\n]\r\n```",
                "title": "Using jq, how to print a new json string based on value parsed from a json string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677752831,
                "last_edit_date": 1677752831,
                "creation_date": 1677752515,
                "answer_id": 75614101,
                "question_id": 75612961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution using **with_entries**:\r\n\r\n    .hits.hits[] | with_entries(select(.key == &quot;_score&quot; or .key == &quot;_id&quot;))\r\nthough the _score and _id keys may not appear in the order you want (eg you may want the _score at the top of the JSON). If this doesn&#39;t matter, this is another possible solution. ",
                "title": "Using jq, how to print a new json string based on value parsed from a json string"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677763563,
                "creation_date": 1677763563,
                "answer_id": 75616055,
                "question_id": 75612961,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I tried `jq &#39;[score: .hits.hits[]._score, id: .hits.hits[]._id]&#39;` and also  `jq &#39;{.hits.hits[]._score, .hits.hits[]._id}&#39;`, but both have compile error.\r\n\r\nYou swapped the symbols for arrays (`[...]`) and objects (`{...}`).\r\n\r\nAs in any other language, a JavaScript array is a collection of items (presumably of the same type but this is not required), listed in a certain order. In the JavaScript source code or as JSON they are separated by commas and enclosed in square brackets (`[` and `]`). They do not have names/labels and are identified by their index (starting with `0`).&lt;br&gt;\r\n`jq &#39;.hits.hits&#39;` extracts from the input JSON an array (of objects); the JSON fragment that you posted in the question shows only a fragment of the first item of the array.\r\n\r\nA JavaScript object is a collection of properties that have values. The order of the properties does not matter. In JavaScript code (or in JSON, which is a valid fragment of JavaScript code), an object is represented as pairs of (property, value) joined by `:`. The pairs are joined by commas (`,`) and all the pairs are wrapped in curly braces (`{` and `}`). The JSON in the question encodes an object having properties `took`, `timed_out` and so one.\r\n\r\nIn order to be correct, your attempts should be like:\r\n```shell\r\njq &#39;[ .hits.hits[]._score, .hits.hits[]._id ]&#39;\r\n```\r\nor:\r\n```shell\r\njq &#39;{ score: .hits.hits[]._score, id: .hits.hits[]._id }&#39;\r\n```\r\n\r\nThey probably do not extract what you want but at least they are correct and extract some data.\r\n\r\nIn order to extract the data you need, you can try something like this:\r\n\r\n```shell\r\njq &#39;[.hits.hits[] | { id: ._id, score: ._score }]&#39;\r\n```\r\n\r\n## How it works\r\n\r\n```text\r\n[                                # wrap the results of the next filters into an array\r\n  .hits.hits                     # extract the property `hits` of the property `hits`...\r\n                                 # ... from input (it is an array)\r\n  []                             # split the array to individual items\r\n  |                              # pass the output of the previous filter as input...\r\n                                 # ... to the next filter\r\n  { id: ._id, score: ._score }   # extract the properties `_id` and `_score` from...\r\n                                 # ... the current input (`.`) and produce an object...\r\n                                 # ... whose properties are `id` and `score`\r\n]                                # close the opening `[` that starts the `jq` program\r\n```\r\n\r\nNote that `[]` (or `| .[]`) splits an input array into items and feeds the next filter multiple input objects. They are processed individually by the next filter and collected back into an array by the wrapping square brackets (`[...]`).\r\n\r\nAn alternative way to get the same result is to use the [`map()`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) filter. It runs the filter passed as argument against each item of the input array and collects the results into a new array.\r\n\r\n```shell\r\njq &#39;.hits.hits | map({ id: ._id, score: ._score })&#39;\r\n```\r\n\r\nTechnically it is the same as:\r\n```shell\r\njq &#39;.hits.hits | [.[] | { id: ._id, score: ._score }]&#39;\r\n```\r\n\r\nCheck these solutions [online](https://jqplay.org/s/L8PJV-YXBHp).",
                "title": "Using jq, how to print a new json string based on value parsed from a json string"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1677763563,
        "creation_date": 1677745702,
        "last_edit_date": 1677748111,
        "question_id": 75612961,
        "body_markdown": "I would like to print `{score: score_value, id: id_value}`, by using `jq` from the following json script (only a small part is here for introduction), I tried ` jq &#39;[score: .hits.hits[]._score, id: .hits.hits[]._id]&#39;` and also ` jq &#39;{.hits.hits[]._score, .hits.hits[]._id}&#39;`, but both have compile error.\r\n```\r\n{\r\n  &quot;took&quot; : 17,\r\n  &quot;timed_out&quot; : false,\r\n  &quot;_shards&quot; : {\r\n    &quot;total&quot; : 1,\r\n    &quot;successful&quot; : 1,\r\n    &quot;skipped&quot; : 0,\r\n    &quot;failed&quot; : 0\r\n  },\r\n  &quot;hits&quot; : {\r\n    &quot;total&quot; : {\r\n      &quot;value&quot; : 100,\r\n      &quot;relation&quot; : &quot;eq&quot;\r\n    },\r\n    &quot;max_score&quot; : 1.0,\r\n    &quot;hits&quot; : [\r\n      {\r\n        &quot;_index&quot; : &quot;ff0&quot;,\r\n        &quot;_id&quot; : &quot;1&quot;,\r\n        &quot;_score&quot; : 1.0,\r\n        &quot;_source&quot; : {\r\n          &quot;server_id&quot; : 86,\r\n          &quot;@timestamp&quot; : &quot;2023-03-01T11:09:23.474948161Z&quot;,\r\n```",
        "link": "https://stackoverflow.com/questions/75612961/using-jq-how-to-print-a-new-json-string-based-on-value-parsed-from-a-json-strin",
        "title": "Using jq, how to print a new json string based on value parsed from a json string"
    },
    {
        "tags": [
            "javascript",
            "sorting",
            "ecmascript-6",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4846147,
                    "reputation": 7115,
                    "user_id": 16540390,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GQyFH.jpg?s=256",
                    "display_name": "jabaa",
                    "link": "https://stackoverflow.com/users/16540390/jabaa"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1677751532,
                "post_id": 75613848,
                "comment_id": 133401025,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18267374,
                    "reputation": 194,
                    "user_id": 13298803,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/w5nPj.jpg?s=256",
                    "display_name": "Motalib Hossain",
                    "link": "https://stackoverflow.com/users/13298803/motalib-hossain"
                },
                "reply_to_user": {
                    "account_id": 4846147,
                    "reputation": 7115,
                    "user_id": 16540390,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GQyFH.jpg?s=256",
                    "display_name": "jabaa",
                    "link": "https://stackoverflow.com/users/16540390/jabaa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1702199072,
                "post_id": 75613848,
                "comment_id": 136865598,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4846147,
                    "reputation": 7115,
                    "user_id": 16540390,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/GQyFH.jpg?s=256",
                    "display_name": "jabaa",
                    "link": "https://stackoverflow.com/users/16540390/jabaa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1702204272,
                "post_id": 75613848,
                "comment_id": 136865940,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677903256,
                "last_edit_date": 1677903256,
                "creation_date": 1677751667,
                "answer_id": 75613945,
                "question_id": 75613848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if you want to swap them you can do:\r\n```\r\nconst users = Post_Comment\r\nconst idx = users.findIndex(r=&gt;r.user.username === username)\r\n[users[0], users[idx]] = [users[idx], users[0]]\r\n```\r\n\r\nIf you want to add it to the beginning while moving other elements indexes you can do:\r\n```\r\nconst users = Post_Comment\r\nconst idx = users.findIndex(r=&gt;r.user.username === username)\r\nusers.unshift(...users.splice(idx, 1))\r\n```",
                "title": "How to find a data from array and set this data in first index of array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1677903256,
        "creation_date": 1677751154,
        "last_edit_date": 1677751739,
        "question_id": 75613848,
        "body_markdown": "Here is my data\r\n\r\n    &quot;Post_Comment&quot;: [\r\n        {\r\n            &quot;comment&quot;: &quot;nice&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;sahed&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;comment&quot;: &quot;best&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;motalib&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;comment&quot;: &quot;nice.&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;admin&quot;\r\n            }\r\n        }\r\n    ]\r\n\r\nBut I want to find an object through **username** and set this object in the first index into the array. I want to find this object whose user name is **motalib**.\r\n\r\nExpected output:\r\n```\r\nconst findCurrentUser = Post_Comment.findIndex(r=&gt;r.user.username === username)\r\nconst SortedComment = Post_Comment.splice(findCurrentUser,1)\r\n```\r\n```\r\n&quot;Post_Comment&quot;: [\r\n             {\r\n                &quot;comment&quot;: &quot;best&quot;,\r\n                &quot;user&quot;: {\r\n                    &quot;username&quot;: &quot;motalib&quot;\r\n                },\r\n            },\r\n            {\r\n                &quot;comment&quot;: &quot;nice&quot;,\r\n                &quot;user&quot;: {\r\n                    &quot;username&quot;: &quot;sahed&quot;\r\n                },\r\n            },\r\n            {\r\n                &quot;comment&quot;: &quot;nice.&quot;,\r\n                &quot;user&quot;: {\r\n                    &quot;username&quot;: &quot;admin&quot;\r\n                },\r\n            }\r\n        ]\r\n```\r\n\r\nExample:\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    const Post_Comment = [\r\n        {\r\n            &quot;comment&quot;: &quot;nice&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;sahed&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;comment&quot;: &quot;best&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;motalib&quot;\r\n            }\r\n        },\r\n        {\r\n            &quot;comment&quot;: &quot;nice.&quot;,\r\n            &quot;user&quot;: {\r\n                &quot;username&quot;: &quot;admin&quot;\r\n            }\r\n        }\r\n    ];\r\n\r\n    const findCurrentUser = Post_Comment.findIndex(r=&gt;r.user.username === &#39;motalib&#39;)\r\n    const SortedComment = Post_Comment.splice(findCurrentUser,1)\r\n    console.log(SortedComment)\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75613848/how-to-find-a-data-from-array-and-set-this-data-in-first-index-of-array",
        "title": "How to find a data from array and set this data in first index of array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677784774,
                "last_edit_date": 1677784774,
                "creation_date": 1677783835,
                "answer_id": 75619809,
                "question_id": 75619786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Start the index counter at the third-last element `[-3`, and go until the end `:]`:\r\n```sh\r\n… | jq -r &#39;.tags | sort[-3:][]&#39;\r\n```\r\n```\r\n2.9.7\r\n2.9.8\r\n2.9.9\r\n```\r\n\r\nWatch out, however, as you are sorting strings here, where `2.9.12` will be sorted before `2.9.7`. If you want to sort the array by version numbers (structured as seen), split them at the dot into an array, convert the items into numbers, and sort by that:\r\n```sh\r\n… | jq -r &#39;.tags | sort_by(split(&quot;.&quot;) | map(tonumber))[:3][]&#39;\r\n```\r\n```\r\n2.9.7\r\n2.9.8\r\n2.9.9\r\n```",
                "title": "Use jq to remove the last three elements of an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677784774,
        "creation_date": 1677783661,
        "question_id": 75619786,
        "body_markdown": "I&#39;m trying to use `jq` to get an array from a json object and I need to remove the last three elements of this array. So this is what I did so far:\r\n\r\n    echo &#39;{ &quot;tags&quot;: [ &quot;2.9.7&quot;, &quot;2.9.8&quot;, &quot;2.9.9&quot;, &quot;2.9.10&quot;, &quot;2.9.11&quot;, &quot;2.9.12&quot; ]}&#39; | jq -r &#39;.tags | sort[:3][]&#39;\r\n\r\ngives me `2.9.10 2.9.11 2.9.12`, but need it the other way round. These values should be removed, so the result should be:\r\n\r\n    2.9.7 2.9.8 2.9.9",
        "link": "https://stackoverflow.com/questions/75619786/use-jq-to-remove-the-last-three-elements-of-an-array",
        "title": "Use jq to remove the last three elements of an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677786100,
                "post_id": 75620085,
                "comment_id": 133411206,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1677786734,
                "last_edit_date": 1677786734,
                "creation_date": 1677785937,
                "answer_id": 75620107,
                "question_id": 75620085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use an `if … then … else … end` expression (see the [manual](https://stedolan.github.io/jq/manual/#if-then-else)) checking the existence of a field using `has` (see the [manual](https://stedolan.github.io/jq/manual/#has%28key%29)):\r\n```sh\r\n… | jq -r &#39;if has(&quot;errors&quot;) then .errors[0].message else &quot;no errors&quot; end&#39;\r\n```\r\n\r\nAlternatively, use the alternative operator `//` which is triggered on `null` or `false` (see the [manual](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F)):\r\n```sh\r\n… | jq -r &#39;.errors[0].message // &quot;no errors&quot;&#39;\r\n```\r\n\r\nIf your code would run into an exception, you can also equip the test with the error suppression operator `?` (see the [manual](https://stedolan.github.io/jq/manual/#ErrorSuppression%2FOptionalOperator%3A%3F)), which is not necessary with your sample code as it evaluates to `null` without errors if the `.errors` field was missing (see the [manual](https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index%3A.foo%2C.foo.bar): &quot;it produces the value at the key, or `null` if there&#39;s none present.&quot;):\r\n```sh\r\n… | jq -r &#39;(.errors[0].message)? // &quot;no errors&quot;&#39;\r\n```\r\n\r\nAs @SUTerliakov pointed out, you can use `empty` anywhere in these examples instead of (the dummy string) `&quot;no errors&quot;` if you want no result at all on success.",
                "title": "How to select a value, which is optional - using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1677786734,
        "creation_date": 1677785768,
        "question_id": 75620085,
        "body_markdown": "This is how I am trying to ouput the message of an array element using `jq`\r\n\r\n    echo &#39;{ errors: [{ &quot;code&quot;: &quot;INVALID&quot;, &quot;message&quot;: &quot;message&quot; }] }&#39; | jq -r &#39;.errors[0].message&#39;\r\n\r\nBut `errors` is an optional value. If there is no error, the field is missing. How do I have to handle the optional value correctly in `jq`?\r\n\r\nSo in the example the result is `message` and if there is no error, the result is empty.",
        "link": "https://stackoverflow.com/questions/75620085/how-to-select-a-value-which-is-optional-using-jq",
        "title": "How to select a value, which is optional - using jq"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1677790536,
                "post_id": 75620656,
                "comment_id": 133412287,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677790563,
                "post_id": 75620656,
                "comment_id": 133412291,
                "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": 1677790625,
                "post_id": 75620656,
                "comment_id": 133412310,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7721349,
                    "reputation": 863,
                    "user_id": 5847482,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9761b1aa8814f06f3000ed2c231b06b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lorccan",
                    "link": "https://stackoverflow.com/users/5847482/lorccan"
                },
                "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": 1677790633,
                "post_id": 75620656,
                "comment_id": 133412313,
                "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": 1677790651,
                "post_id": 75620656,
                "comment_id": 133412319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7721349,
                    "reputation": 863,
                    "user_id": 5847482,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9761b1aa8814f06f3000ed2c231b06b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Lorccan",
                    "link": "https://stackoverflow.com/users/5847482/lorccan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677790679,
                "post_id": 75620656,
                "comment_id": 133412325,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1677790930,
                "last_edit_date": 1677790930,
                "creation_date": 1677790721,
                "answer_id": 75620754,
                "question_id": 75620656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could bind `.city.sunrise` to a variable and use it later:\r\n```sh\r\njq -r &#39;.city.sunrise as $sunrise | .list[] | select(.dt &gt; $sunrise) | .clouds.all&#39;\r\n```\r\n\r\nNote: If calculating the average is all you need `awk` for, consider also doing it inside jq, to save another call to another program, e.g.\r\n```sh\r\njq -r &#39;.city.sunrise as $sunrise | .list | map(select(.dt &gt; $sunrise) | .clouds.all) | add / length&#39;\r\n```\r\n\r\nIf there is a chance for `length` to be `0`, catch the error using `?` and `//` as in `(add / length)? // &quot;no data&quot;`.\r\n",
                "title": "jq: Assign Value to Variable then Use Variable in select in One Statement"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1677790741,
                "creation_date": 1677790741,
                "answer_id": 75620756,
                "question_id": 75620656,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can bind `.city.sunrise` to a variable in the filter itself.\r\n\r\n    $ curl ... | jq -r &#39;.city.sunrise as $sr | .list[] | select(.dt &gt; $sr) | .clouds.all | add&#39;\r\n    &lt;your sum&gt;\r\n\r\n\r\nAn `as` expression is a pass-through assignment whose output is the same as its input. The filter argument is applied to the input as well, with the result bound to the variable argument a as a side effect.",
                "title": "jq: Assign Value to Variable then Use Variable in select in One Statement"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1677790930,
        "creation_date": 1677790033,
        "question_id": 75620656,
        "body_markdown": "Output from `curl` contains JSON and this is piped to `jq`.\r\n\r\nRunning this:\r\n```\r\njq -r &#39;.list[] | select(.dt &gt; 1677812400) | .clouds.all&#39;\r\n```\r\nget me several lines of integers which I then average by piping to `awk`\r\n\r\nWhat I&#39;d like to do is to substitute the value 1677812400 with one that I can obtain by running the same `curl` and then piping to this:\r\n```\r\njq -r &#39;.city.sunrise&#39;\r\n```\r\nI appreciate that it could be done in two steps - (1) running the `curl|jq` and assigning the value to a shell var (2) using the var in the second `curl|jq`, but I am sure there is a way to do it all in one go.\r\n\r\nI have tried:\r\n```\r\njq -r --arg sunrise &quot;$(jq -r &#39;.city.sunrise&#39;)&quot; &#39;.list[] | select(.dt &gt; ($sunrise|tonumber)) | .clouds.all&#39;\r\n```\r\nbut this yields precisely nothing, so I&#39;m stuck.\r\n\r\nIf more detail is needed on the JSON I am happy to provide it.\r\n",
        "link": "https://stackoverflow.com/questions/75620656/jq-assign-value-to-variable-then-use-variable-in-select-in-one-statement",
        "title": "jq: Assign Value to Variable then Use Variable in select in One Statement"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677838203,
                "last_edit_date": 1677838203,
                "creation_date": 1677818836,
                "answer_id": 75623262,
                "question_id": 75622260,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If this isn&#39;t exactly what you&#39;re after, it will hopefully set you on the right path:\r\n```\r\n# input: an object, the source of the values\r\n# $obj: an object, the source of the relevant keys\r\n# output: an array\r\ndef array($obj):\r\n  . as $in | [$obj|keys_unsorted[] as $k | $in[$k]];\r\n  \r\n({} | {price,counterparty,quantity,allOrNothing,timestamp,orderId,implied}) as $fields\r\n| .orderbookSnapshotItem \r\n| [.exchange,.contract,.qtyDecimals, .contractTitle, .instrumentName]  as $common\r\n| range(0; .bidPrice|length) as $i\r\n| ($common + (.bidPrice[$i] | array($fields)) + (.askPrice[$i] | array($fields)))\r\n| @csv\r\n```\r\n",
                "title": "Converting nested JSON to CSV - specifically an object containing necessary values for each record and an array of values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678788919,
        "creation_date": 1677804837,
        "last_edit_date": 1678788919,
        "question_id": 75622260,
        "body_markdown": "I want to parse out a set of CSV records from JSON. \r\n\r\nThe JSON looks like this:\r\n```json\r\n{\r\n   &quot;orderbookSnapshotItem&quot;:{\r\n      &quot;exchange&quot;:&quot;WhirlyGig&quot;,\r\n      &quot;contract&quot;:&quot;OptimalSpring&quot;,\r\n      &quot;bidPrice&quot;:[\r\n         {\r\n            &quot;price&quot;:&quot;47.205&quot;,\r\n            &quot;counterparty&quot;:&quot;WhirlyGig&quot;,\r\n            &quot;quantity&quot;:&quot;10&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         },\r\n         {\r\n            &quot;price&quot;:&quot;47.200&quot;,\r\n            &quot;counterparty&quot;:&quot;WhirlyGig&quot;,\r\n            &quot;quantity&quot;:&quot;5&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         }\r\n      ],\r\n      &quot;askPrice&quot;:[\r\n         {\r\n            &quot;price&quot;:&quot;47.295&quot;,\r\n            &quot;counterparty&quot;:&quot;WhirlyGig&quot;,\r\n            &quot;quantity&quot;:&quot;10&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         },\r\n         {\r\n            &quot;price&quot;:&quot;47.300&quot;,\r\n            &quot;counterparty&quot;:&quot;WhirlyGig&quot;,\r\n            &quot;quantity&quot;:&quot;25&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         }\r\n      ],\r\n      &quot;qtyDecimals&quot;:&quot;0&quot;,\r\n      &quot;contractTitle&quot;:&quot;Ancient Greek LPG - Apr23&quot;,\r\n      &quot;instrumentName&quot;:&quot;GDP&quot;\r\n   }\r\n}\r\n```\r\nNo header line is required, I intend to specify all fields required with jq.\r\n\r\nI want to unbundle each orderbookSnapshotItem into a set of records which each look like:\r\n```\r\n  &quot;ICE&quot;,\r\n  &quot;TFM FMJ0023!&quot;,\r\n  &quot;0&quot;,\r\n  &quot;Dutch TTF Natural Gas Futures - TTF - Apr23&quot;,\r\n  &quot;TFM&quot;,\r\n  &quot;47.295&quot;,\r\n  &quot;ICE&quot;,\r\n  &quot;10&quot;,\r\n  &quot;false&quot;,\r\n  &quot;2023-03-02T11:52:36.554Z&quot;,\r\n  &quot;0&quot;,\r\n  &quot;false&quot;\r\n  &quot;47.295&quot;,\r\n  &quot;ICE&quot;,\r\n  &quot;10&quot;,\r\n  &quot;false&quot;,\r\n  &quot;2023-03-02T11:52:36.554Z&quot;,\r\n  &quot;0&quot;,\r\n  &quot;false&quot;\r\n```\r\nOr more exactly, as a CSV with no header, but if there was one it would be like this:\r\n```\r\nexchange,contract,qtyDecimals,contractTitle,instrumentName,bidprice,bidcounterparty,bidquantity,bidallornothing,bidtimestamp,bidorderid,bidimplied,askprice,askcounterparty,askquantity,askallornothing,asktimestamp,askorderid,askimplied\r\n```\r\nI have got quite a long way however it&#39;s just not right and I am struggling. I would be so very grateful if someone would point me in the right direction. It&#39;s approaching 01:00am and I can see I am not getting single lines containg both bid &amp; ask but extra lines.\r\n\r\nBelow is my lamentable jq script.\r\n```\r\n.orderbookSnapshotItem as $parent | $parent | [.exchange as $ex | .contract as $con | .qtyDecimals as $decimals | .contractTitle as $title | .instrumentName as $name | $parent | .bidPrice[] | $ex, $con, $decimals, $title, $name, .price,.counterparty,.quantity,.allOrNothing,.timestamp,.orderId,.implied | $parent | .askPrice[] | $ex, $con, $decimals, $title, $name, .price,.counterparty,.quantity,.allOrNothing,.timestamp,.orderId,.implied]\r\n\r\n```\r\nThank you for looking.\r\n\r\nEdit: Just to finish off, with enormous thanks to @peak for educating me and pushing me in the right direction with an elegant solution.\r\n\r\nThe person for whom I was producing this data clarified his requirement upon seeing @peak&#39;s solution.\r\n\r\nHe just wanted a single line with the max bid &amp; min ask. In response, I produced the following jq abomination which works, but doesn&#39;t handle missing bids/asks at all:\r\n```\r\n| $parent | .bidPrice | max_by(.price) as $bidme | $parent | .askPrice | min_by(.price) as $askme\r\n| $parent | ([.exchange, .contract, .qtyDecimals, .contractTitle, .instrumentName,\r\n$bidme.price,$bidme.counterparty,$bidme.quantity,$bidme.allOrNothing,$bidme.timestamp,$bidme.orderId,$bidme.implied,\r\n$askme.price,$askme.counterparty,$askme.quantity,$askme.allOrNothing,$askme.timestamp,$askme.orderId,$askme.implied])? | @csv\r\n```\r\nYes - embarrassing, isn&#39;t it?\r\n\r\nSo I looked again at @peak&#39;s work and came up with this, a hacked plagiarisation of @peak&#39;s solution:\r\n```\r\n# input: an object, the source of the values\r\n# $obj: an object, the source of the relevant keys\r\n# output: an array\r\ndef rec($obj):\r\n  . as $in | [$obj|keys_unsorted[] as $k | $in[$k]];\r\n\r\n({} | {price,counterparty,quantity,allOrNothing,timestamp,orderId,implied}) as $fields\r\n| .orderbookSnapshotItem\r\n| [.exchange,.contract,.qtyDecimals, .contractTitle, .instrumentName]  as $common\r\n| ($common + (.bidPrice // [{}] | max_by(.price) | rec($fields)) + (.askPrice // [{}] | min_by(.price) | rec($fields)))?\r\n| @csv\r\n```\r\nAgainst the following test.json,\r\n```json\r\n{\r\n   &quot;?xml&quot;:{\r\n      &quot;@version&quot;:&quot;1.0&quot;,\r\n     &quot;@encoding&quot;:&quot;UTF-8&quot;,\r\n      &quot;@standalone&quot;:&quot;yes&quot;\r\n   },\r\n   &quot;orderbookSnapshotItem&quot;:{\r\n      &quot;exchange&quot;:&quot;WhirlyGig&quot;,\r\n      &quot;contract&quot;:&quot;OptimalSpring&quot;,\r\n      &quot;bidPrice&quot;:[\r\n         {\r\n            &quot;price&quot;:&quot;47.205&quot;,\r\n            &quot;counterparty&quot;:&quot;BiddyGig0&quot;,\r\n            &quot;quantity&quot;:&quot;10&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         },\r\n         {\r\n            &quot;price&quot;:&quot;47.200&quot;,\r\n            &quot;counterparty&quot;:&quot;BiddyGig1&quot;,\r\n            &quot;quantity&quot;:&quot;5&quot;,\r\n            &quot;allOrNothing&quot;:&quot;false&quot;,\r\n            &quot;timestamp&quot;:&quot;2023-03-02T11:52:36.554Z&quot;,\r\n            &quot;orderId&quot;:&quot;0&quot;,\r\n            &quot;implied&quot;:&quot;false&quot;\r\n         }\r\n      ],\r\n      &quot;qtyDecimals&quot;:&quot;0&quot;,\r\n      &quot;contractTitle&quot;:&quot;Ancient Greek LPG - Apr23&quot;,\r\n      &quot;instrumentName&quot;:&quot;GDP&quot;\r\n   }\r\n}\r\n```\r\nwith the command line (under windows) where query.jq contains the jq script above:\r\n```\r\ntype test.json | .\\jq-win64.exe -r -f query.jq\r\n```\r\nproduces the following output:\r\n```\r\n&quot;WhirlyGig&quot;,&quot;OptimalSpring&quot;,&quot;0&quot;,&quot;Ancient Greek LPG - Apr23&quot;,&quot;GDP&quot;,&quot;47.205&quot;,&quot;BiddyGig0&quot;,&quot;10&quot;,&quot;false&quot;,&quot;2023-03-02T11:52:36.554Z&quot;,&quot;0&quot;,&quot;false&quot;,,,,,,,\r\n```\r\nWhich is exactly what I wanted.\r\n\r\nSo it&#39;s a big thank you and thumbs up for @peak.",
        "link": "https://stackoverflow.com/questions/75622260/converting-nested-json-to-csv-specifically-an-object-containing-necessary-valu",
        "title": "Converting nested JSON to CSV - specifically an object containing necessary values for each record and an array of values"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677824928,
                "post_id": 75622802,
                "comment_id": 133417274,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2984956,
                    "reputation": 69,
                    "user_id": 2534033,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/60f36cc2230d860c6c2b3fbc14c11868?s=256&d=identicon&r=PG",
                    "display_name": "user2534033",
                    "link": "https://stackoverflow.com/users/2534033/user2534033"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677825528,
                "post_id": 75622802,
                "comment_id": 133417359,
                "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": 1677838327,
                "post_id": 75622802,
                "comment_id": 133420265,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1677825571,
        "creation_date": 1677812464,
        "last_edit_date": 1677825571,
        "question_id": 75622802,
        "body_markdown": "below is the aws cli command that works.\r\n\r\n```\r\naws elb describe-load-balancers |\\\r\n   jq &#39;.LoadBalancerDescriptions[] |\r\n       select(.DNSName == &quot;internal-elbdnsendpoint1.us-east-1.elb.amazonaws.com&quot;) |\r\n       .LoadBalancerName, .SecurityGroups[]&#39;\r\n```\r\n\r\nI am trying to get the security group for all the services (load balancers) deployed:\r\n``` \r\nfor i in `kubectl get svc -A | grep LoadB | awk &#39;{print $5}&#39;`; do\r\n    aws elb describe-load-balancers |\\\r\n    jq -r --arg var $i &#39;.LoadBalancerDescriptions[] | select(.DNSName == $var) | ...&#39;;\r\ndone&#160;\r\n```\r\n\r\nI tried with `&quot;$var&quot;`, `$var` and `[$var]`. doesn&#39;t work anything at `select(.DNSName == $var)`\r\nbut the above command doesn&#39;t work. \r\n\r\nBut again, here is my test command that worked with no issues, so really need some help finding the right command and some understanding on why the way it behaves:\r\n```\r\necho &#39;{&quot;vikas&quot;: [{&quot;k2&quot;: &quot;v1&quot;},{&quot;k2&quot;:&quot;v2&quot;,&quot;k3&quot;:&quot;v3&quot;}]}&#39; |\\\r\n    jq -r --arg var &quot;$i&quot; &#39;.vikas[] | select(.k2 == &quot;v2&quot;) | .k2, .k3&#39;`\r\n```\r\n\r\nAlso, Below is a sample output for the list of load balancers for: \r\n``` \r\nfor i in `kubectl get svc -A | grep LoadB | awk &#39;{print $5}&#39;`; do\r\n    echo $i\r\ndone \r\n```\r\n\r\n```\r\ninternal-elbdnsendpoint1.us-east-1.elb.amazonaws.com\r\ninternal-elbdnsendpoint2.us-east-1.elb.amazonaws.com\r\ninternal-elbdnsendpoint3.us-east-1.elb.amazonaws.com\r\ninternal-elbdnsendpoint4.us-east-1.elb.amazonaws.com\r\n```",
        "link": "https://stackoverflow.com/questions/75622802/passing-variable-into-jq-to-select-a-value-from-the-piped-output",
        "title": "passing variable into JQ to select a value from the piped output"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677831882,
                "last_edit_date": 1677831882,
                "creation_date": 1677826324,
                "answer_id": 75623975,
                "question_id": 75623166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `.evidence[] | …`, you first iterate over the array, and just then produce whatever you produce but once for each array item. IIUC, you want one object (per `.evidence` array, probably), and collect various parts from single array items into it. Therefore, you need to iterate for each of those parts separately in order to retrieve the matching ones: `.evidence | … [] … [] …`.\r\n\r\n```sh\r\n.evidence | {\r\n  upn: (.[] | select(.&quot;@odata.type&quot; == &quot;#microsoft.graph.security.userEvidence&quot;).userAccount.userPrincipalName),\r\n  ip: (.[] | select(.&quot;@odata.type&quot; == &quot;#microsoft.graph.security.ipEvidence&quot;).ipAddress)\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;upn&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;ip&quot;: &quot;&lt;redacted&gt;&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/p0tsj-iPQjh)\r\n\r\nBe careful, though, because if any of the `(.[] | select(…) …)` constructs emits more than just one item, the whole output object will be duplicated, once for each one of them. You could thwart this by e.g. just taking the first match, as in `first(.[] | select(…) …)`.\r\n\r\nAlternatively, if `.&quot;@odata.type&quot;` is known to be unique across the array, all your constraints are based on it, and especially if there are many parts to collect, you might consider first building up an `INDEX` which you can use to reference the array items in constant time (instead of iterating through the array over and over again):\r\n\r\n```sh\r\n.evidence | INDEX(.&quot;@odata.type&quot;) as $e | {\r\n  upn: $e[&quot;#microsoft.graph.security.userEvidence&quot;].userAccount.userPrincipalName,\r\n  ip: $e[&quot;#microsoft.graph.security.ipEvidence&quot;].ipAddress\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;upn&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;ip&quot;: &quot;&lt;redacted&gt;&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/yEvWJ_lptBz)\r\n\r\n",
                "title": "JQ, Create New Dict With Two Unique Select Statements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1677831882,
        "creation_date": 1677817641,
        "question_id": 75623166,
        "body_markdown": "I have a response from the Graph API which contains an array of objects. Each object contains different evidence categories for an alert.\r\n\r\n```bash\r\n$ cat event.json | jq &#39;.evidence[].&quot;@odata.type&quot;&#39;                 \r\n&quot;#microsoft.graph.security.userEvidence&quot;\r\n&quot;#microsoft.graph.security.cloudApplicationEvidence&quot;\r\n&quot;#microsoft.graph.security.cloudApplicationEvidence&quot;\r\n&quot;#microsoft.graph.security.ipEvidence&quot;\r\n```\r\n\r\nI am trying to construct a new object with the results, but the event structure is making this kind of difficult:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;providerAlertId&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;incidentId&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;status&quot;: &quot;new&quot;,\r\n  &quot;severity&quot;: &quot;low&quot;,\r\n  &quot;classification&quot;: null,\r\n  &quot;determination&quot;: null,\r\n  &quot;serviceSource&quot;: &quot;microsoftDefenderForCloudApps&quot;,\r\n  &quot;detectionSource&quot;: &quot;cloudAppSecurity&quot;,\r\n  &quot;detectorId&quot;: &quot;MCAS_ALERT_ANUBIS_DETECTION_REPEATED_ACTIVITY_FAILED_LOGIN&quot;,\r\n  &quot;tenantId&quot;: &quot;&lt;redacted&gt;&quot;,\r\n  &quot;title&quot;: &quot;Multiple failed login attempts&quot;,\r\n  &quot;description&quot;: &quot;The user &lt;redacted&gt; (&lt;redacted&gt;) performed more than 51 failed logins attempts in a single session.&quot;,\r\n  &quot;recommendedActions&quot;: &quot;&quot;,\r\n  &quot;category&quot;: &quot;CredentialAccess&quot;,\r\n  &quot;assignedTo&quot;: null,\r\n  &quot;alertWebUrl&quot;: &quot;https://security.microsoft.com/alerts/&lt;redacted&gt;?tid=&lt;redacted&gt;&quot;,\r\n  &quot;incidentWebUrl&quot;: &quot;https://security.microsoft.com/incidents/&lt;redacted&gt;?tid=6&lt;redacted&gt;&quot;,\r\n  &quot;actorDisplayName&quot;: null,\r\n  &quot;threatDisplayName&quot;: null,\r\n  &quot;threatFamilyName&quot;: null,\r\n  &quot;mitreTechniques&quot;: [\r\n    &quot;T1110&quot;,\r\n    &quot;T1110.001&quot;\r\n  ],\r\n  &quot;createdDateTime&quot;: &quot;2023-03-01T18:13:38.812686Z&quot;,\r\n  &quot;lastUpdateDateTime&quot;: &quot;2023-03-01T18:14:46.6766667Z&quot;,\r\n  &quot;resolvedDateTime&quot;: null,\r\n  &quot;firstActivityDateTime&quot;: &quot;2023-03-01T17:56:52.145Z&quot;,\r\n  &quot;lastActivityDateTime&quot;: &quot;2023-03-01T17:58:11.708Z&quot;,\r\n  &quot;comments&quot;: [],\r\n  &quot;evidence&quot;: [\r\n    {\r\n      &quot;@odata.type&quot;: &quot;#microsoft.graph.security.userEvidence&quot;,\r\n      &quot;createdDateTime&quot;: &quot;2023-03-01T18:13:38.8966667Z&quot;,\r\n      &quot;verdict&quot;: &quot;unknown&quot;,\r\n      &quot;remediationStatus&quot;: &quot;none&quot;,\r\n      &quot;remediationStatusDetails&quot;: null,\r\n      &quot;roles&quot;: [],\r\n      &quot;tags&quot;: [],\r\n      &quot;userAccount&quot;: {\r\n        &quot;accountName&quot;: &quot;&lt;redacted&gt;&quot;,\r\n        &quot;domainName&quot;: null,\r\n        &quot;userSid&quot;: &quot;&lt;redacted&gt;&quot;,\r\n        &quot;azureAdUserId&quot;: &quot;&lt;redacted&gt;&quot;,\r\n        &quot;userPrincipalName&quot;: &quot;&lt;redacted&gt;&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;@odata.type&quot;: &quot;#microsoft.graph.security.cloudApplicationEvidence&quot;,\r\n      &quot;createdDateTime&quot;: &quot;2023-03-01T18:13:38.8966667Z&quot;,\r\n      &quot;verdict&quot;: &quot;unknown&quot;,\r\n      &quot;remediationStatus&quot;: &quot;none&quot;,\r\n      &quot;remediationStatusDetails&quot;: null,\r\n      &quot;roles&quot;: [],\r\n      &quot;tags&quot;: [],\r\n      &quot;appId&quot;: 11161,\r\n      &quot;displayName&quot;: &quot;Office 365&quot;,\r\n      &quot;instanceId&quot;: 0,\r\n      &quot;instanceName&quot;: null,\r\n      &quot;saasAppId&quot;: 11161\r\n    },\r\n    {\r\n      &quot;@odata.type&quot;: &quot;#microsoft.graph.security.cloudApplicationEvidence&quot;,\r\n      &quot;createdDateTime&quot;: &quot;2023-03-01T18:13:38.8966667Z&quot;,\r\n      &quot;verdict&quot;: &quot;unknown&quot;,\r\n      &quot;remediationStatus&quot;: &quot;none&quot;,\r\n      &quot;remediationStatusDetails&quot;: null,\r\n      &quot;roles&quot;: [],\r\n      &quot;tags&quot;: [],\r\n      &quot;appId&quot;: 28375,\r\n      &quot;displayName&quot;: &quot;Microsoft Teams&quot;,\r\n      &quot;instanceId&quot;: 0,\r\n      &quot;instanceName&quot;: null,\r\n      &quot;saasAppId&quot;: 28375\r\n    },\r\n    {\r\n      &quot;@odata.type&quot;: &quot;#microsoft.graph.security.ipEvidence&quot;,\r\n      &quot;createdDateTime&quot;: &quot;2023-03-01T18:13:38.8966667Z&quot;,\r\n      &quot;verdict&quot;: &quot;unknown&quot;,\r\n      &quot;remediationStatus&quot;: &quot;none&quot;,\r\n      &quot;remediationStatusDetails&quot;: null,\r\n      &quot;roles&quot;: [\r\n        &quot;attacker&quot;\r\n      ],\r\n      &quot;tags&quot;: [],\r\n      &quot;ipAddress&quot;: &quot;&lt;redacted&gt;&quot;,\r\n      &quot;countryLetterCode&quot;: null\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHere is my first attempt:\r\n\r\n```bash\r\n➜  cat event.json | jq &#39;[.evidence[] | {upn: .userAccount.userPrincipalName, ip: .ipAddress }]&#39;\r\n[\r\n  {\r\n    &quot;upn&quot;: &quot;&lt;redacted&gt;&quot;,\r\n    &quot;ip&quot;: null\r\n  },\r\n  {\r\n    &quot;upn&quot;: null,\r\n    &quot;ip&quot;: null\r\n  },\r\n  {\r\n    &quot;upn&quot;: null,\r\n    &quot;ip&quot;: null\r\n  },\r\n  {\r\n    &quot;upn&quot;: null,\r\n    &quot;ip&quot;: &quot;&lt;redacted&gt;&quot;\r\n  }\r\n]\r\n```\r\n\r\nThis output makes sense. There are 4 objects contained within the `evidence[]` array. My next attempt was a proof of concept on simply selecting a specific object from the array, and it proved successful for a singular value:\r\n\r\n```json\r\n➜  cat event.json | jq &#39;[.evidence[] | {upn: select(.&quot;@odata.type&quot; == &quot;#microsoft.graph.security.userEvidence&quot;) | .userAccount.userPrincipalName, ip: .ipAddress }]&#39;\r\n[\r\n  {\r\n    &quot;upn&quot;: &quot;&lt;redacted&gt;&quot;,\r\n    &quot;ip&quot;: null\r\n  }\r\n]\r\n```\r\n\r\nObviously, the select `userEvidence` object doesn&#39;t contain an IP - no surprise that field returned `null`. I figured I could simply do another select statement to get the IP, but this causes a complete whiff:\r\n\r\n```bash\r\n➜  cat event.json | jq &#39;[.evidence[] | {upn: select(.&quot;@odata.type&quot; == &quot;#microsoft.graph.security.userEvidence&quot;) | .userAccount.userPrincipalName, ip: select(.&quot;@odata.type&quot; == &quot;#microsoft.graph.security.ipEvidence&quot;) | .ipAddress }]&#39;\r\n[]\r\n```\r\n\r\nHow might I accomplish this? Why are my current attempts unsuccessful?",
        "link": "https://stackoverflow.com/questions/75623166/jq-create-new-dict-with-two-unique-select-statements",
        "title": "JQ, Create New Dict With Two Unique Select Statements"
    },
    {
        "tags": [
            "curl",
            "jq",
            "github-api",
            "xq"
        ],
        "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": 1677834147,
                "post_id": 75624951,
                "comment_id": 133419153,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 436801,
                    "reputation": 25,
                    "user_id": 6121608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0f92746a24bf5e2e18f1b066d57c8a59?s=256&d=identicon&r=PG",
                    "display_name": "ziad_tawfeek",
                    "link": "https://stackoverflow.com/users/6121608/ziad-tawfeek"
                },
                "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": 1677835265,
                "post_id": 75624951,
                "comment_id": 133419450,
                "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": 1677836178,
                "post_id": 75624951,
                "comment_id": 133419703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1066600,
                    "reputation": 22163,
                    "user_id": 1067003,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/e3af2bd4b5604b0b661b5e6646544eba?s=256&d=identicon&r=PG",
                    "display_name": "hanshenrik",
                    "link": "https://stackoverflow.com/users/1067003/hanshenrik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677857179,
                "post_id": 75624951,
                "comment_id": 133425546,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1677834974,
                "creation_date": 1677834974,
                "answer_id": 75625176,
                "question_id": 75624951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One thing that I was missing is to get the log output of $FAILED_TESTS as text by piping as `jq -sR &#39;. | @text&#39;` and I needed to remove the double quotes in the following line `&quot;body&quot;: $FAILED_TESTS` and it worked",
                "title": "How can I post multiple json objects in a single pull request comment in curl?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1677853844,
                "last_edit_date": 1677853844,
                "creation_date": 1677836394,
                "answer_id": 75625402,
                "question_id": 75624951,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I suggest to not use shell string interpolation to generate JSON; instead use `jq` directly to produce your expected output document:\r\n\r\n```\r\ngenerate_pull_request_payload()\r\n{\r\n  xq -r &#39;.testsuites.testsuite.testcase[] | select(.failure)&#39; &lt; JUnitReport.xml \\\r\n  | jq -sR &#39;{ body: . }&#39;\r\n}\r\n```\r\n\r\nThere shouldn&#39;t be a need for `@text` if you format JSON directly, without going through plain text and string interpolation in the first place.\r\n\r\nAnd eventually read the data for the post request directly from stdin:\r\n\r\n```\r\ngenerate_pull_request_payload | curl -X POST &quot;https://api.github.com/repos/owner/repo/issues/3943/comments&quot; \\\r\n  -H &quot;Authorization: token $GITHUB_TOKEN&quot; \\\r\n  -H &quot;Content-type: text/json; charset=utf-8&quot; \\\r\n  -d @-\r\n```",
                "title": "How can I post multiple json objects in a single pull request comment in curl?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1677853844,
        "creation_date": 1677833386,
        "question_id": 75624951,
        "body_markdown": "I have the following output that I wanted to post to a github pull request as a comment\r\n\r\n```\r\n{\r\n  &quot;@name&quot;: &quot;testWalletDeepLinkLoginFlow&quot;,\r\n  &quot;@classname&quot;: &quot;iphone13pro-15.7-en-portrait#.AppUI-Tests.WalletDeepLinkLoginFlowTest&quot;,\r\n  &quot;@time&quot;: &quot;30.246&quot;,\r\n  &quot;failure&quot;: &quot;Failure at /Users/vagrant/git/AppUITests/Extensions/XCUIElement+Additions.swift:30 - Assertion Failure at XCUIElement+Additions.swift:30: Failed to get matching snapshot: No matches found for first query match sequence: `Descendants matching type TextField` -&gt; `Elements matching predicate &#39;\\&quot;input_country_search\\&quot; IN identifiers&#39;`, given input App element pid: 627 (no attribute values faulted in)&quot;,\r\n  &quot;webLink&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/9067272573409626190/details&quot;\r\n}\r\n{\r\n  &quot;@name&quot;: &quot;testWalletDeepLinkMainFlow&quot;,\r\n  &quot;@classname&quot;: &quot;iphone13pro-15.7-en-portrait#.AppUI-Tests.WalletDeepLinkMainFlowTest&quot;,\r\n  &quot;@time&quot;: &quot;50.672&quot;,\r\n  &quot;failure&quot;: &quot;Failure at /Users/vagrant/git/AppUITests/DeepLinks/Wallet/WalletDeepLinkMainFlowTest.swift:17 - Assertion Failure at WalletDeepLinkMainFlowTest.swift:17: XCTAssertTrue failed&quot;,\r\n  &quot;webLink&quot;: &quot;https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/7233833673388432629/details&quot;\r\n}\r\n```\r\nI prepare the github pull request comment with the following method\r\n\r\n```\r\ngenerate_pull_request_payload()\r\n{\r\n  cat &lt;&lt;EOF\r\n{\r\n  &quot;body&quot;: &quot;$FAILED_TESTS&quot;\r\n}\r\nEOF\r\n}\r\n```\r\n\r\nI use xq command line tool to fetch only failed tests and use the output above to post to github with the following curl\r\n\r\n```\r\ncurl -X POST &quot;https://api.github.com/repos/owner/repo/issues/3943/comments&quot; \\\r\n  -H &quot;Authorization: token $GITHUB_TOKEN&quot; \\\r\n  -H &quot;Content-type: text/json; charset=utf-8&quot; \\\r\n  --data &quot;$(generate_pull_request_payload)&quot;\r\n```\r\n\r\nI expected to have the output posted to a comment",
        "link": "https://stackoverflow.com/questions/75624951/how-can-i-post-multiple-json-objects-in-a-single-pull-request-comment-in-curl",
        "title": "How can I post multiple json objects in a single pull request comment in curl?"
    },
    {
        "tags": [
            "json",
            "jq",
            "aws-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": 1,
                "creation_date": 1677865335,
                "post_id": 75630084,
                "comment_id": 133427990,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1677866558,
                "creation_date": 1677866558,
                "answer_id": 75630453,
                "question_id": 75630084,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could concatenate the arrays of two streams (one stream contains a single array, the other stream contains multiple arrays). This builds the cartesian product of both streams.\r\n\r\n```\r\n[.InstanceId] + (.Entries[] | [.ApplicationType, .Name, .Version, .PackageId, .Publisher, .URL, .Summary])\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  &quot;i-0af68a7cf857bd010&quot;,\r\n  &quot;admin&quot;,\r\n  &quot;accountsservice&quot;,\r\n  &quot;0.6.45-1ubuntu1.3&quot;,\r\n  &quot;accountsservice_0.6.45-1ubuntu1.3_amd64.deb&quot;,\r\n  &quot;Ubuntu Developers &lt;ubuntu-devel-discuss@lists.ubuntu.com&gt;&quot;,\r\n  &quot;https://www.freedesktop.org/wiki/Software/AccountsService/&quot;,\r\n  &quot;query and manipulate user account information&quot;\r\n]\r\n```",
                "title": "jq - add element from outside array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677866558,
        "creation_date": 1677863925,
        "question_id": 75630084,
        "body_markdown": "```\r\n{\r\n    &quot;TypeName&quot;: &quot;AWS:Application&quot;,\r\n    &quot;InstanceId&quot;: &quot;i-0af68a7cf857bd010&quot;,\r\n    &quot;SchemaVersion&quot;: &quot;1.1&quot;,\r\n    &quot;CaptureTime&quot;: &quot;2023-03-01T16:28:43Z&quot;,\r\n    &quot;Entries&quot;: [\r\n        {\r\n            &quot;ApplicationType&quot;: &quot;admin&quot;,\r\n            &quot;Architecture&quot;: &quot;x86_64&quot;,\r\n            &quot;Name&quot;: &quot;accountsservice&quot;,\r\n            &quot;PackageId&quot;: &quot;accountsservice_0.6.45-1ubuntu1.3_amd64.deb&quot;,\r\n            &quot;Publisher&quot;: &quot;Ubuntu Developers &lt;ubuntu-devel-discuss@lists.ubuntu.com&gt;&quot;,\r\n            &quot;Summary&quot;: &quot;query and manipulate user account information&quot;,\r\n            &quot;URL&quot;: &quot;https://www.freedesktop.org/wiki/Software/AccountsService/&quot;,\r\n            &quot;Version&quot;: &quot;0.6.45-1ubuntu1.3&quot;\r\n        }\r\n     ]\r\n}\r\n```\r\n\r\nThis is a snippet of a large selection I&#39;m trying to format to eventually export as csv.\r\n\r\n```\r\n.Entries[] | [.ApplicationType, .Name, .Version, .PackageId, .Publisher, .URL, .Summary]\r\n```\r\n\r\n```\r\n[\r\n  &quot;admin&quot;,\r\n  &quot;accountsservice&quot;,\r\n  &quot;0.6.45-1ubuntu1.3&quot;,\r\n  &quot;accountsservice_0.6.45-1ubuntu1.3_amd64.deb&quot;,\r\n  &quot;Ubuntu Developers &lt;ubuntu-devel-discuss@lists.ubuntu.com&gt;&quot;,\r\n  &quot;https://www.freedesktop.org/wiki/Software/AccountsService/&quot;,\r\n  &quot;query and manipulate user account information&quot;\r\n]\r\n```\r\nIs there a way that I can insert the .InstanceId from outside the array into the array, leaving me with:\r\n\r\n```\r\n[\r\n  &quot;i-0af68a7cf857bd010&quot;,\r\n  &quot;admin&quot;,\r\n  &quot;accountsservice&quot;,\r\n  &quot;0.6.45-1ubuntu1.3&quot;,\r\n  &quot;accountsservice_0.6.45-1ubuntu1.3_amd64.deb&quot;,\r\n  &quot;Ubuntu Developers &lt;ubuntu-devel-discuss@lists.ubuntu.com&gt;&quot;,\r\n  &quot;https://www.freedesktop.org/wiki/Software/AccountsService/&quot;,\r\n  &quot;query and manipulate user account information&quot;\r\n]\r\n\r\nThank you so much for the assistance!",
        "link": "https://stackoverflow.com/questions/75630084/jq-add-element-from-outside-array",
        "title": "jq - add element from outside array"
    },
    {
        "tags": [
            "arrays",
            "if-statement",
            "syntax",
            "jq",
            "boolean-operations"
        ],
        "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": 1677869145,
                "post_id": 75630714,
                "comment_id": 133428947,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13992525,
                    "reputation": 57,
                    "user_id": 10106195,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-16hTZVN3n1s/AAAAAAAAAAI/AAAAAAAAEIg/FWrgpqDkV2s/s256-rj/photo.jpg",
                    "display_name": "Max",
                    "link": "https://stackoverflow.com/users/10106195/max"
                },
                "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": 1677870490,
                "post_id": 75630714,
                "comment_id": 133429336,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677869204,
                "last_edit_date": 1677869204,
                "creation_date": 1677869010,
                "answer_id": 75630782,
                "question_id": 75630714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d go with `select` (which emits `empty` if its argument evaluates to `false`, i.e. there is no match), and `test` for regular expressions:\r\n```sh\r\njq &#39;.players[].name | select(test(&quot;ZZZ|temp|Failed&quot;) | not) &#39;\r\n```\r\n```json\r\n&quot;E180TH-426-CIC-008&quot;\r\n&quot;LBRTY-185-CIC-005&quot;\r\n```",
                "title": "Use or operator in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1677869204,
        "creation_date": 1677868527,
        "last_edit_date": 1677868833,
        "question_id": 75630714,
        "body_markdown": "I&#39;m using jq to parse JSON. The JSON has an array called &quot;players[]&quot; which contains a key &quot;name&quot; with the following sample values:\r\n\r\n```\r\nZZZ-104TH-082-ADV-004\r\nZZZ-149TH-435-ADV-WL-006\r\nGDS-123-CIC-007_temp-blocked\r\nLRMR-121-CIC-002_temp-removed\r\nNOS-343-CIC-003_Failed\r\nE180TH-426-CIC-008\r\nLBRTY-185-CIC-005\r\n```\r\n\r\nI have this jq line:\r\n\r\n`jq &#39;.players[] | if .name | contains( &quot;ZZZ&quot; ) then empty else .name end&#39;`\r\n\r\nWhich returns the following names:\r\n\r\n```\r\nGDS-123-CIC-007_temp-blocked\r\nLRMR-121-CIC-002_temp-removed\r\nNOS-343-CIC-003_Failed\r\nE180TH-426-CIC-008\r\nLBRTY-185-CIC-005\r\n```\r\n\r\nI would like to also exclude names that contain &quot;Failed&quot; or &quot;temp&quot; which would return the following:\r\n\r\n```\r\nE180TH-426-CIC-008\r\nLBRTY-185-CIC-005\r\n```\r\n\r\nI tried \r\n\r\n`jq &#39;.players[] | if .name | contains( &quot;ZZZ&quot; ) or contains( &quot;Failed&quot; ) then empty else .name end&#39;`\r\n\r\nBut that only excluded the names containing &quot;ZZZ&quot;. how can I filter out names that contain &quot;ZZZ&quot; or &quot;Failed&quot; or &quot;temp&quot;?",
        "link": "https://stackoverflow.com/questions/75630714/use-or-operator-in-jq",
        "title": "Use or operator in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 18196249,
                    "reputation": 9650,
                    "user_id": 16466946,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8f7b8604465090c303eda95723ccba37?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kikon",
                    "link": "https://stackoverflow.com/users/16466946/kikon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677908265,
                "post_id": 75633690,
                "comment_id": 133434433,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24382013,
                    "reputation": 65,
                    "user_id": 18313400,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GivmraS2ORZ-YMmnqpxQpo624diBbX-ILy_Idee=k-s256",
                    "display_name": "DrGeek",
                    "link": "https://stackoverflow.com/users/18313400/drgeek"
                },
                "reply_to_user": {
                    "account_id": 18196249,
                    "reputation": 9650,
                    "user_id": 16466946,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8f7b8604465090c303eda95723ccba37?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kikon",
                    "link": "https://stackoverflow.com/users/16466946/kikon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677911463,
                "post_id": 75633690,
                "comment_id": 133434736,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18196249,
                    "reputation": 9650,
                    "user_id": 16466946,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8f7b8604465090c303eda95723ccba37?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kikon",
                    "link": "https://stackoverflow.com/users/16466946/kikon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1677914349,
                "post_id": 75633690,
                "comment_id": 133434967,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677915335,
                "creation_date": 1677915335,
                "answer_id": 75634296,
                "question_id": 75633690,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your first version is close; the problem arises at the second filter, i.e., the second `.rulebase[]`.\r\n\r\nMy understanding is that the second `.rulebase` (i.e., `.rulebase.rulebase`) may exist or not; if it exists, it replaces the first `.rulebase` for the source of data (`.rule-number` and `.hits.value`).\r\n\r\nFor this case the simplest solution seems to be the alternative operator `//` from the [Conditionals and comparisons](https://stedolan.github.io/jq/manual/#ConditionalsandComparisons) chapter in the manual.\r\n\r\nAlso, since you have to index the possibly non-existing property `.rulebase`, you&#39;ll need to employ the `.[]?` operator instead of plain `.[]` (described in the [Basic filters](https://stedolan.github.io/jq/manual/#Basicfilters) chapter).\r\n\r\nThe alternative to the missing second `.rulebase[]?` is keeping the original one (the result of the first filter), that makes the second filter `.rulebase[]? // .` and\r\nthe overall solution:\r\n```\r\njq &#39;.rulebase[] | .rulebase[]? // . | &quot;\\(.&quot;rule-number&quot;), \\(.hits.value)&quot;&#39;\r\n```\r\n",
                "title": "Jq parsing to extract rule-number and hits.value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1677915335,
        "creation_date": 1677904897,
        "question_id": 75633690,
        "body_markdown": "I need to extract &quot;rule-number and hits.value&quot; from the below JSON data but I&#39;m unable to fetch complete data using a single command.\r\n\r\nWhen I use below jq command it only gives me the output of 3rd rule.\r\n\r\n**JQ Command:**\r\n```\r\njq  --raw-output &#39;.rulebase[] | .rulebase[] | &quot;\\(.&quot;rule-number&quot;),\\(.hits.value)&quot;&#39; text\r\n```\r\n**Output:**\r\n\r\n```\r\njq: error: Cannot iterate over null\r\njq: error: Cannot iterate over null\r\n3,0\r\n```\r\nThis is happening because the command is parsing twice using &quot;.rulebase&quot; to get the data from the 3rd rule. But by doing this it is unable to extract from the 1st &quot;.rulebase&quot;.\r\n\r\nSimilarly, when I use below command it only extracts 1st 2 data and fails to extract the 3rd one.\r\n\r\n**JQ command:**\r\n\r\n```\r\n jq  --raw-output &#39;.rulebase[] | &quot;\\(.&quot;rule-number&quot;),\\(.hits.value)&quot;&#39; text\r\n```\r\n\r\n**Output:**\r\n```\r\n1,495\r\n2,0\r\nnull,null\r\n```\r\n\r\n2nd command works correctly as per my understanding but now I want to extract all the data using single command.\r\n\r\nSo, help me to get a single command to extract the required data.\r\n\r\n**RAW JSON Data:**\r\n```\r\n{\r\n  &quot;uid&quot; : &quot;38271c2f-ab44-4e25-9aa4-e219cb6e12cf&quot;,\r\n  &quot;name&quot; : &quot;Network&quot;,\r\n  &quot;rulebase&quot; : [ {\r\n    &quot;uid&quot; : &quot;39c3ec50-1936-40c1-a775-f6f382027b31&quot;,\r\n    &quot;type&quot; : &quot;access-rule&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;rule-number&quot; : 1,\r\n    &quot;track&quot; : {\r\n      &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n      &quot;per-session&quot; : false,\r\n      &quot;per-connection&quot; : true,\r\n      &quot;accounting&quot; : false,\r\n      &quot;enable-firewall-session&quot; : false,\r\n      &quot;alert&quot; : &quot;none&quot;\r\n    },\r\n    &quot;source&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;source-negate&quot; : false,\r\n    &quot;destination&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;destination-negate&quot; : false,\r\n    &quot;service&quot; : [ &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot;, &quot;18ec9eaa-1657-4240-ab97-5f234623336b&quot; ],\r\n    &quot;service-negate&quot; : false,\r\n    &quot;service-resource&quot; : &quot;&quot;,\r\n    &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n    &quot;action-settings&quot; : {\r\n      &quot;enable-identity-captive-portal&quot; : false\r\n    },\r\n    &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;content-negate&quot; : false,\r\n    &quot;content-direction&quot; : &quot;any&quot;,\r\n    &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;hits&quot; : {\r\n      &quot;percentage&quot; : &quot;45%&quot;,\r\n      &quot;level&quot; : &quot;medium&quot;,\r\n      &quot;value&quot; : 495,\r\n      &quot;first-date&quot; : {\r\n        &quot;posix&quot; : 1676788067000,\r\n        &quot;iso-8601&quot; : &quot;2023-02-19T11:57+0530&quot;\r\n      },\r\n      &quot;last-date&quot; : {\r\n        &quot;posix&quot; : 1677899191000,\r\n        &quot;iso-8601&quot; : &quot;2023-03-04T08:36+0530&quot;\r\n      }\r\n    },\r\n    &quot;custom-fields&quot; : {\r\n      &quot;field-1&quot; : &quot;&quot;,\r\n      &quot;field-2&quot; : &quot;&quot;,\r\n      &quot;field-3&quot; : &quot;&quot;\r\n    },\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1676788056454,\r\n        &quot;iso-8601&quot; : &quot;2023-02-19T11:57+0530&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;admin&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1676788030368,\r\n        &quot;iso-8601&quot; : &quot;2023-02-19T11:57+0530&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;admin&quot;\r\n    },\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;enabled&quot; : true,\r\n    &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n    &quot;available-actions&quot; : {\r\n      &quot;edit&quot; : &quot;true&quot;,\r\n      &quot;delete&quot; : &quot;true&quot;,\r\n      &quot;clone&quot; : &quot;not_supported&quot;\r\n    }\r\n  }, {\r\n    &quot;uid&quot; : &quot;751ef538-e21b-40ac-a1bf-9562c5bc3eb7&quot;,\r\n    &quot;type&quot; : &quot;access-rule&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;rule-number&quot; : 2,\r\n    &quot;track&quot; : {\r\n      &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n      &quot;per-session&quot; : false,\r\n      &quot;per-connection&quot; : true,\r\n      &quot;accounting&quot; : false,\r\n      &quot;enable-firewall-session&quot; : false,\r\n      &quot;alert&quot; : &quot;none&quot;\r\n    },\r\n    &quot;source&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;source-negate&quot; : false,\r\n    &quot;destination&quot; : [ &quot;411dc962-10b5-463d-84a5-3c29aaf74858&quot; ],\r\n    &quot;destination-negate&quot; : false,\r\n    &quot;service&quot; : [ &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;service-negate&quot; : false,\r\n    &quot;service-resource&quot; : &quot;&quot;,\r\n    &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n    &quot;action-settings&quot; : {\r\n      &quot;enable-identity-captive-portal&quot; : false\r\n    },\r\n    &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;content-negate&quot; : false,\r\n    &quot;content-direction&quot; : &quot;any&quot;,\r\n    &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n    &quot;hits&quot; : {\r\n      &quot;percentage&quot; : &quot;0%&quot;,\r\n      &quot;level&quot; : &quot;zero&quot;,\r\n      &quot;value&quot; : 0\r\n    },\r\n    &quot;custom-fields&quot; : {\r\n      &quot;field-1&quot; : &quot;&quot;,\r\n      &quot;field-2&quot; : &quot;&quot;,\r\n      &quot;field-3&quot; : &quot;&quot;\r\n    },\r\n    &quot;meta-info&quot; : {\r\n      &quot;lock&quot; : &quot;unlocked&quot;,\r\n      &quot;validation-state&quot; : &quot;ok&quot;,\r\n      &quot;last-modify-time&quot; : {\r\n        &quot;posix&quot; : 1677291569962,\r\n        &quot;iso-8601&quot; : &quot;2023-02-25T07:49+0530&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;admin&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1677291560424,\r\n        &quot;iso-8601&quot; : &quot;2023-02-25T07:49+0530&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;admin&quot;\r\n    },\r\n    &quot;comments&quot; : &quot;For 1.1.1.2&quot;,\r\n    &quot;enabled&quot; : true,\r\n    &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n    &quot;available-actions&quot; : {\r\n      &quot;edit&quot; : &quot;true&quot;,\r\n      &quot;delete&quot; : &quot;true&quot;,\r\n      &quot;clone&quot; : &quot;not_supported&quot;\r\n    }\r\n  }, {\r\n    &quot;uid&quot; : &quot;1f4dcd29-dac1-4f65-9aa3-cb0041b68c00&quot;,\r\n    &quot;name&quot; : &quot;internet rules&quot;,\r\n    &quot;type&quot; : &quot;access-section&quot;,\r\n    &quot;from&quot; : 3,\r\n    &quot;to&quot; : 3,\r\n    &quot;rulebase&quot; : [ {\r\n      &quot;uid&quot; : &quot;df594bf8-8eee-422c-8a5f-01722fc71417&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 3,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;14745150-feab-4830-b60b-e0c39cd22758&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n      &quot;action-settings&quot; : {\r\n        &quot;enable-identity-captive-portal&quot; : false\r\n      },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;hits&quot; : {\r\n        &quot;percentage&quot; : &quot;0%&quot;,\r\n        &quot;level&quot; : &quot;zero&quot;,\r\n        &quot;value&quot; : 0\r\n      },\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1677291841727,\r\n          &quot;iso-8601&quot; : &quot;2023-02-25T07:54+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1677291513151,\r\n          &quot;iso-8601&quot; : &quot;2023-02-25T07:48+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;For 1.1.1.1&quot;,\r\n      &quot;enabled&quot; : false,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    } ]\r\n  }, {\r\n    &quot;uid&quot; : &quot;3e6e74ef-5cdd-48b1-adc1-897bfa10974d&quot;,\r\n    &quot;name&quot; : &quot;Cleanup Rule&quot;,\r\n    &quot;type&quot; : &quot;access-section&quot;,\r\n    &quot;from&quot; : 4,\r\n    &quot;to&quot; : 4,\r\n    &quot;rulebase&quot; : [ {\r\n      &quot;uid&quot; : &quot;2b922948-da96-4c9d-a654-063e0183f9ae&quot;,\r\n      &quot;name&quot; : &quot;Cleanup rule&quot;,\r\n      &quot;type&quot; : &quot;access-rule&quot;,\r\n      &quot;domain&quot; : {\r\n        &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n        &quot;name&quot; : &quot;SMC User&quot;,\r\n        &quot;domain-type&quot; : &quot;domain&quot;\r\n      },\r\n      &quot;rule-number&quot; : 4,\r\n      &quot;track&quot; : {\r\n        &quot;type&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n        &quot;per-session&quot; : false,\r\n        &quot;per-connection&quot; : true,\r\n        &quot;accounting&quot; : false,\r\n        &quot;enable-firewall-session&quot; : false,\r\n        &quot;alert&quot; : &quot;none&quot;\r\n      },\r\n      &quot;source&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;source-negate&quot; : false,\r\n      &quot;destination&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;destination-negate&quot; : false,\r\n      &quot;service&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;service-negate&quot; : false,\r\n      &quot;service-resource&quot; : &quot;&quot;,\r\n      &quot;vpn&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;action&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c473&quot;,\r\n      &quot;action-settings&quot; : { },\r\n      &quot;content&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;content-negate&quot; : false,\r\n      &quot;content-direction&quot; : &quot;any&quot;,\r\n      &quot;time&quot; : [ &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot; ],\r\n      &quot;hits&quot; : {\r\n        &quot;percentage&quot; : &quot;55%&quot;,\r\n        &quot;level&quot; : &quot;medium&quot;,\r\n        &quot;value&quot; : 596,\r\n        &quot;first-date&quot; : {\r\n          &quot;posix&quot; : 1676786609000,\r\n          &quot;iso-8601&quot; : &quot;2023-02-19T11:33+0530&quot;\r\n        },\r\n        &quot;last-date&quot; : {\r\n          &quot;posix&quot; : 1677899181000,\r\n          &quot;iso-8601&quot; : &quot;2023-03-04T08:36+0530&quot;\r\n        }\r\n      },\r\n      &quot;custom-fields&quot; : {\r\n        &quot;field-1&quot; : &quot;&quot;,\r\n        &quot;field-2&quot; : &quot;&quot;,\r\n        &quot;field-3&quot; : &quot;&quot;\r\n      },\r\n      &quot;meta-info&quot; : {\r\n        &quot;lock&quot; : &quot;unlocked&quot;,\r\n        &quot;validation-state&quot; : &quot;ok&quot;,\r\n        &quot;last-modify-time&quot; : {\r\n          &quot;posix&quot; : 1676788047995,\r\n          &quot;iso-8601&quot; : &quot;2023-02-19T11:57+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1668629634218,\r\n          &quot;iso-8601&quot; : &quot;2022-11-17T01:43+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;System&quot;\r\n      },\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;enabled&quot; : true,\r\n      &quot;install-on&quot; : [ &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot; ],\r\n      &quot;available-actions&quot; : {\r\n        &quot;edit&quot; : &quot;true&quot;,\r\n        &quot;delete&quot; : &quot;true&quot;,\r\n        &quot;clone&quot; : &quot;not_supported&quot;\r\n      }\r\n    } ]\r\n  } ],\r\n  &quot;objects-dictionary&quot; : [ {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c472&quot;,\r\n    &quot;name&quot; : &quot;Accept&quot;,\r\n    &quot;type&quot; : &quot;RulebaseAction&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Actions/actionsAccept&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;97aeb369-9aea-11d5-bd16-0090272ccb30&quot;,\r\n    &quot;name&quot; : &quot;Any&quot;,\r\n    &quot;type&quot; : &quot;CpmiAnyObject&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;General/globalsAny&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;14745150-feab-4830-b60b-e0c39cd22758&quot;,\r\n    &quot;name&quot; : &quot;BL_1.1.1.1&quot;,\r\n    &quot;type&quot; : &quot;host&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address&quot; : &quot;1.1.1.1&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;411dc962-10b5-463d-84a5-3c29aaf74858&quot;,\r\n    &quot;name&quot; : &quot;BL_1.1.1.2&quot;,\r\n    &quot;type&quot; : &quot;host&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;41e821a0-3720-11e3-aa6e-0800200c9fde&quot;,\r\n      &quot;name&quot; : &quot;SMC User&quot;,\r\n      &quot;domain-type&quot; : &quot;domain&quot;\r\n    },\r\n    &quot;ipv4-address&quot; : &quot;1.1.1.2&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;color&quot; : &quot;black&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c473&quot;,\r\n    &quot;name&quot; : &quot;Drop&quot;,\r\n    &quot;type&quot; : &quot;RulebaseAction&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Actions/actionsDrop&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;97aeb443-9aea-11d5-bd16-0090272ccb30&quot;,\r\n    &quot;name&quot; : &quot;https&quot;,\r\n    &quot;type&quot; : &quot;service-tcp&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;port&quot; : &quot;443&quot;,\r\n    &quot;icon&quot; : &quot;Protocols/HTTP&quot;,\r\n    &quot;color&quot; : &quot;red&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;598ead32-aa42-4615-90ed-f51a5928d41d&quot;,\r\n    &quot;name&quot; : &quot;Log&quot;,\r\n    &quot;type&quot; : &quot;Track&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;Track/tracksLog&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;6c488338-8eec-4103-ad21-cd461ac2c476&quot;,\r\n    &quot;name&quot; : &quot;Policy Targets&quot;,\r\n    &quot;type&quot; : &quot;Global&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;icon&quot; : &quot;General/globalsAny&quot;,\r\n    &quot;color&quot; : &quot;none&quot;\r\n  }, {\r\n    &quot;uid&quot; : &quot;18ec9eaa-1657-4240-ab97-5f234623336b&quot;,\r\n    &quot;name&quot; : &quot;ssh&quot;,\r\n    &quot;type&quot; : &quot;service-tcp&quot;,\r\n    &quot;domain&quot; : {\r\n      &quot;uid&quot; : &quot;a0bbbc99-adef-4ef8-bb6d-defdefdefdef&quot;,\r\n      &quot;name&quot; : &quot;Check Point Data&quot;,\r\n      &quot;domain-type&quot; : &quot;data domain&quot;\r\n    },\r\n    &quot;port&quot; : &quot;22&quot;,\r\n    &quot;icon&quot; : &quot;Services/TCPService&quot;,\r\n    &quot;color&quot; : &quot;red&quot;\r\n  } ],\r\n  &quot;from&quot; : 1,\r\n  &quot;to&quot; : 4,\r\n  &quot;total&quot; : 4\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75633690/jq-parsing-to-extract-rule-number-and-hits-value",
        "title": "Jq parsing to extract rule-number and hits.value"
    },
    {
        "tags": [
            "bash",
            "csv",
            "jq",
            "export-to-csv",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1677960866,
                "post_id": 75638368,
                "comment_id": 133441877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3842961,
                    "reputation": 93062,
                    "user_id": 3185459,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u8EuP.jpg?s=256",
                    "display_name": "RomanPerekhrest",
                    "link": "https://stackoverflow.com/users/3185459/romanperekhrest"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1677960988,
                "post_id": 75638368,
                "comment_id": 133441891,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 198006,
                    "reputation": 101,
                    "user_id": 442430,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/c7b410a97fc21d1063c89abbc46cd9fd?s=256&d=identicon&r=PG",
                    "display_name": "Benjamin",
                    "link": "https://stackoverflow.com/users/442430/benjamin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678042597,
                "post_id": 75638368,
                "comment_id": 133452237,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1677960949,
                "creation_date": 1677960949,
                "answer_id": 75638407,
                "question_id": 75638368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is a stream, therefore, to output the header just once, use the `-n` flag to have a single input to print from, then `inputs` to process all the actual inputs. Using `arrays` and `objects`, you can distinguish between the two cases for `.cpu`.\r\n```sh\r\njq -nr &#39;\r\n  [&quot;unit-type&quot;,&quot;unit-id&quot;,&quot;cpu-id&quot;,&quot;temperature&quot;] as $headers | $headers, (inputs\r\n    | [.[$headers[0,1]]] + (.cpu | arrays[], objects | [.[$headers[2,3]]])\r\n  ) | @csv\r\n&#39;\r\n```\r\n```\r\n&quot;unit-type&quot;,&quot;unit-id&quot;,&quot;cpu-id&quot;,&quot;temperature&quot;\r\n&quot;amp&quot;,&quot;0&quot;,&quot;0&quot;,&quot;64(C)&quot;\r\n&quot;amp&quot;,&quot;0&quot;,&quot;1&quot;,&quot;64(C)&quot;\r\n&quot;bcp&quot;,&quot;1&quot;,&quot;0&quot;,&quot;74(C)&quot;\r\n```\r\n",
                "title": "jq json to csv with all child elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1678059502,
        "creation_date": 1677960457,
        "last_edit_date": 1678059502,
        "question_id": 75638368,
        "body_markdown": "For the following json I extracted from an XML\r\n\r\n    {\r\n      &quot;unit-type&quot;: &quot;amp&quot;,\r\n      &quot;unit-id&quot;: &quot;0&quot;,\r\n      &quot;cpu&quot;: [\r\n        {\r\n          &quot;cpu-id&quot;: &quot;0&quot;,\r\n          &quot;temperature&quot;: &quot;64(C)&quot;\r\n        },\r\n        {\r\n          &quot;cpu-id&quot;: &quot;1&quot;,\r\n          &quot;temperature&quot;: &quot;64(C)&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;unit-type&quot;: &quot;bcp&quot;,\r\n      &quot;unit-id&quot;: &quot;1&quot;,\r\n      &quot;cpu&quot;: {\r\n        &quot;cpu-id&quot;: &quot;0&quot;,\r\n        &quot;temperature&quot;: &quot;74(C)&quot;\r\n      }\r\n    }\r\n\r\nI would like to have the following csv output\r\n\r\nI only can use bash and the tools xq jq and yq\r\n\r\n    unit-type,unit-id,cpu-id,temperature\r\n    amp,0,0,64(C)\r\n    amp,0,1,64(C)\r\n    bcp,1,0,74(C)\r\n\r\nI think my main issue I am running in, is that the 2th cpu element is a object, while the first cpu element is a array in JQ. I am hitting face against the wall for this one.\r\n\r\nThanks in advance!\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75638368/jq-json-to-csv-with-all-child-elements",
        "title": "jq json to csv with all child elements"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "depth"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1678002412,
                "creation_date": 1678002412,
                "answer_id": 75640817,
                "question_id": 75640739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could get all the `paths` of `length &gt; 3` (actually `== 4` would suffice), and delete those using `delpaths`:\r\n```sh\r\njq &#39;delpaths([paths | select(length &gt; 3)])&#39; file.json\r\n```\r\n```json\r\n{\r\n  &quot;Service1&quot;: {\r\n    &quot;Production&quot;: {\r\n      &quot;Location 1&quot;: {},\r\n      &quot;Service2&quot;: {}\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/716K2olHRWB)\r\n\r\nNote that `Service2` is already on third level, so it is cut off immediately (without going down to its own `Location 1` field).",
                "title": "jq get x levels of keys and remove all the rest"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678002851,
                "creation_date": 1678002851,
                "answer_id": 75640839,
                "question_id": 75640739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` none\r\n$ jq &#39;del(.[][][][])&#39; file\r\n{\r\n  &quot;Service1&quot;: {\r\n    &quot;Production&quot;: {\r\n      &quot;Location 1&quot;: {},\r\n      &quot;Service2&quot;: {}\r\n    }\r\n  }\r\n}\r\n$\r\n```",
                "title": "jq get x levels of keys and remove all the rest"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1678007636,
                "creation_date": 1678007636,
                "answer_id": 75641187,
                "question_id": 75640739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the question and example, it&#39;s not too clear how arrays should be handled, so the following may be of interest as it makes a clear distinction between JSON objects and all else:\r\n```\r\n# If the input is an object then:\r\n#   if depth &lt;= 0 then emit {}, otherwise map_values(retain(depth - 1));\r\n#   otherwise echo the input.\r\ndef retain(depth):\r\n  if type == &quot;object&quot;\r\n  then if depth &lt;= 0 then {}\r\n       else map_values(retain(depth - 1))\r\n       end\r\n  else .\r\n  end;\r\n\r\nretain(3)\r\n```\r\nFor the sample input, the output would be:\r\n```\r\n{\r\n  &quot;Service1&quot;: {\r\n    &quot;Production&quot;: {\r\n      &quot;Location 1&quot;: {},\r\n      &quot;Service2&quot;: {}\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq get x levels of keys and remove all the rest"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1678043114,
        "creation_date": 1678001094,
        "last_edit_date": 1678043114,
        "question_id": 75640739,
        "body_markdown": "How can I get the first x levels of depth of an object and remove the rest using jq ? \r\n\r\nI have the following example: \r\n\r\n```json\r\n{\r\n  &quot;Service1&quot;: {\r\n    &quot;Production&quot;: {\r\n      &quot;Location 1&quot;: {\r\n        &quot;b2d1&quot;: {\r\n          &quot;clusters&quot;: {\r\n            &quot;Datacenter2&quot;: []\r\n          },\r\n          &quot;prod&quot;: {\r\n            &quot;clusters&quot;: {\r\n              &quot;Datacenter1&quot;: []\r\n            }\r\n          }\r\n        }\r\n      },\r\n      &quot;Service2&quot;: {\r\n        &quot;Production&quot;: {\r\n          &quot;Location 1&quot;: {\r\n            &quot;dr1&quot;: {\r\n              &quot;clusters&quot;: {\r\n                &quot;Datacenter3&quot;: []\r\n              },\r\n              &quot;prod&quot;: {\r\n                &quot;clusters&quot;: {\r\n                  &quot;Datacenter1&quot;: []\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nIn my case, I want to get the 1st 3 levels (want to remove everything bellow location in all entries. \r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75640739/jq-get-x-levels-of-keys-and-remove-all-the-rest",
        "title": "jq get x levels of keys and remove all the rest"
    },
    {
        "tags": [
            "arrays",
            "json",
            "csv",
            "jq",
            "export-to-csv"
        ],
        "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": 1678099528,
                "post_id": 75649776,
                "comment_id": 133461469,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678110982,
                "last_edit_date": 1678110982,
                "creation_date": 1678101780,
                "answer_id": 75650243,
                "question_id": 75649776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To extract these fields to csv, you can use `jq` with `@csv` filter in a shell script like this:\r\n\r\n    #!/bin/bash\r\n    \r\n    json=$(cat input.json)\r\n    \r\n    fields=$(echo &quot;$json&quot; | jq -r &#39;.results[] | [\r\n        .id,\r\n        .type,\r\n        .summary_fields.related_field_counts.inventories,\r\n        .summary_fields.related_field_counts.teams,\r\n        .summary_fields.related_field_counts.users,\r\n        .summary_fields.related_field_counts.job_templates,\r\n        .summary_fields.related_field_counts.admins,\r\n        .summary_fields.related_field_counts.projects,\r\n        .name,\r\n        .description\r\n    ] | @csv&#39;)\r\n    \r\n    echo &quot;id,type,inventories,teams,users,job_templates,admins,projects,name,description&quot; &gt; output.csv\r\n    echo &quot;$fields&quot; &gt;&gt; output.csv\r\n\r\n\r\n",
                "title": "Convert json file to csv in linux jq command format"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1678172916,
                "last_edit_date": 1678172916,
                "creation_date": 1678117364,
                "answer_id": 75652880,
                "question_id": 75649776,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the JSON provided in the example is valid (actually it&#39;s not, it seems to be truncated). You can get the expected CSV output using the `jq` query:\r\n\r\n```\r\n[&quot;id&quot;, &quot;type&quot;, &quot;inventories&quot;, &quot;teams&quot;, &quot;users&quot;, &quot;job_templates&quot;, &quot;admins&quot;, &quot;projects&quot;, &quot;name&quot;, &quot;description&quot;] as $headers |\r\n($headers,\r\n  (.results[] | [ \r\n    .id,\r\n    .type,\r\n    .summary_fields.related_field_counts.inventories,\r\n    .summary_fields.related_field_counts.teams,\r\n    .summary_fields.related_field_counts.users,\r\n    .summary_fields.related_field_counts.job_templates,\r\n    .summary_fields.related_field_counts.admins,\r\n    .summary_fields.related_field_counts.projects,\r\n    .name,\r\n    .description\r\n  ])\r\n) | @csv\r\n```\r\n\r\nYou can find the working output in this [jqplay snippet][1].\r\n\r\nPutting the query and the `jq` command together (assuming the `input.json` is your JSON contents used in the example):\r\n\r\n    jq --raw-output &#39;[&quot;id&quot;,&quot;type&quot;,&quot;inventories&quot;,&quot;teams&quot;,&quot;users&quot;,&quot;job_templates&quot;,&quot;admins&quot;,&quot;projects&quot;,&quot;name&quot;,&quot;description&quot;] as $headers | ($headers, (.results[] | [ .id, .type, .summary_fields.related_field_counts.inventories, .summary_fields.related_field_counts.teams, .summary_fields.related_field_counts.users, .summary_fields.related_field_counts.job_templates, .summary_fields.related_field_counts.admins, .summary_fields.related_field_counts.projects, .name, .description ])) | @csv&#39; input.json\r\n\r\n\r\n  [1]: https://jqplay.org/s/Err1Ow8HWip",
                "title": "Convert json file to csv in linux jq command format"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1678355059,
        "creation_date": 1678099072,
        "last_edit_date": 1678355059,
        "question_id": 75649776,
        "body_markdown": "I would like to convert json file in csv to a format we want. \r\nI would like to extract only specific variables from json and format it to csv.\r\n\r\nCurrent json file\r\n```\r\n{\r\n  &quot;count&quot;: 86,\r\n  &quot;next&quot;: null,\r\n  &quot;previous&quot;: null,\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;id&quot;: 7,\r\n      &quot;type&quot;: &quot;organization&quot;,\r\n      &quot;url&quot;: &quot;/api/v2/organizations/7/&quot;,\r\n      &quot;related&quot;: {\r\n        &quot;notification_templates&quot;: &quot;/api/v2/organizations/7/notification_templates/&quot;,\r\n        &quot;notification_templates_started&quot;: &quot;/api/v2/organizations/7/notification_templates_started/&quot;,\r\n        &quot;notification_templates_success&quot;: &quot;/api/v2/organizations/7/notification_templates_success/&quot;,\r\n        &quot;notification_templates_error&quot;: &quot;/api/v2/organizations/7/notification_templates_error/&quot;,\r\n        &quot;notification_templates_approvals&quot;: &quot;/api/v2/organizations/7/notification_templates_approvals/&quot;,\r\n        &quot;object_roles&quot;: &quot;/api/v2/organizations/7/object_roles/&quot;,\r\n        &quot;galaxy_credentials&quot;: &quot;/api/v2/organizations/7/galaxy_credentials/&quot;\r\n      },\r\n      &quot;summary_fields&quot;: {\r\n        },\r\n        &quot;modified_by&quot;: {\r\n        },\r\n          },\r\n          &quot;execute_role&quot;: {\r\n            &quot;description&quot;: &quot;May run any executable resources in the organization&quot;,\r\n            &quot;name&quot;: &quot;Execute&quot;,\r\n            &quot;id&quot;: 258\r\n          },\r\n          &quot;project_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all projects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Project Admin&quot;,\r\n            &quot;id&quot;: 263\r\n          &quot;credential_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all credentials of the organization&quot;,\r\n            &quot;name&quot;: &quot;Credential Admin&quot;,\r\n            &quot;id&quot;: 255\r\n          },\r\n          &quot;workflow_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all workflows of the organization&quot;,\r\n            &quot;name&quot;: &quot;Workflow Admin&quot;,\r\n            &quot;id&quot;: 261\r\n          &quot;job_template_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all job templates of the organization&quot;,\r\n            &quot;name&quot;: &quot;Job Template Admin&quot;,\r\n            &quot;id&quot;: 262\r\n          },\r\n          &quot;read_role&quot;: {\r\n            &quot;description&quot;: &quot;May view settings for the organization&quot;,\r\n            &quot;name&quot;: &quot;Read&quot;,\r\n            &quot;id&quot;: 256\r\n          },\r\n          &quot;approval_role&quot;: {\r\n            &quot;description&quot;: &quot;Can approve or deny a workflow approval node&quot;,\r\n            &quot;name&quot;: &quot;Approve&quot;,\r\n            &quot;id&quot;: null\r\n          }\r\n        },\r\n        &quot;user_capabilities&quot;: {\r\n          &quot;edit&quot;: true,\r\n          &quot;delete&quot;: true\r\n        },\r\n        &quot;related_field_counts&quot;: {\r\n          &quot;inventories&quot;: 0,\r\n          &quot;teams&quot;: 0,\r\n          &quot;users&quot;: 1,\r\n          &quot;job_templates&quot;: 0,\r\n          &quot;admins&quot;: 2,\r\n          &quot;projects&quot;: 0\r\n        }\r\n      },\r\n      &quot;custom_virtualenv&quot;: null\r\n    },\r\n    {\r\n      &quot;id&quot;: 36,\r\n      &quot;type&quot;: &quot;organization&quot;,\r\n      &quot;url&quot;: &quot;/api/v2/organizations/36/&quot;,\r\n      &quot;related&quot;: {\r\n        &quot;modified_by&quot;: &quot;/api/v2/users/444/&quot;,\r\n        &quot;users&quot;: &quot;/api/v2/organizations/36/users/&quot;,\r\n        &quot;admins&quot;: &quot;/api/v2/organizations/36/admins/&quot;,\r\n        &quot;teams&quot;: &quot;/api/v2/organizations/36/teams/&quot;,\r\n        &quot;credentials&quot;: &quot;/api/v2/organizations/36/credentials/&quot;,\r\n        &quot;applications&quot;: &quot;/api/v2/organizations/36/applications/&quot;,\r\n        &quot;activity_stream&quot;: &quot;/api/v2/organizations/36/activity_stream/&quot;,\r\n        &quot;notification_templates&quot;: &quot;/api/v2/organizations/36/notification_templates/&quot;,\r\n        &quot;notification_templates_started&quot;: &quot;/api/v2/organizations\r\n        &quot;notification_templates_approvals&quot;: &quot;/api/v2/organizations/36/notification_templates_approvals/&quot;,\r\n        &quot;object_roles&quot;: &quot;/api/v2/organizations/36/object_roles/&quot;,\r\n        &quot;access_list&quot;: &quot;/api/v2/organizations/36/access_list/&quot;,\r\n        },\r\n        &quot;object_roles&quot;: {\r\n          &quot;execute_role&quot;: {\r\n            &quot;description&quot;: &quot;May run any executable resources in the organization&quot;,\r\n            &quot;name&quot;: &quot;Execute&quot;,\r\n            &quot;id&quot;: 26573\r\n          },\r\n          &quot;project_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all projects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Project Admin&quot;,\r\n            &quot;id&quot;: 26574\r\n          },\r\n          &quot;inventory_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all inventories of the organization&quot;,\r\n            &quot;name&quot;: &quot;Inventory Admin&quot;,\r\n            &quot;id&quot;: 26575\r\n          },\r\n          &quot;credential_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all credentials of the organization&quot;,\r\n            &quot;name&quot;: &quot;Credential Admin&quot;,\r\n            &quot;id&quot;: 26576\r\n          &quot;notification_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all notifications of the organization&quot;,\r\n            &quot;name&quot;: &quot;Notification Admin&quot;,\r\n            &quot;id&quot;: 26578\r\n          },\r\n          &quot;job_template_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all job templates of the \r\n          &quot;auditor_role&quot;: {\r\n            &quot;description&quot;: &quot;Can view all aspects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Auditor&quot;,\r\n            &quot;id&quot;: 26580\r\n          &quot;read_role&quot;: {\r\n            &quot;description&quot;: &quot;May view settings for the organization&quot;,\r\n            &quot;name&quot;: &quot;Read&quot;,\r\n            &quot;id&quot;: 26582\r\n          },\r\n          &quot;approval_role&quot;: {\r\n            &quot;description&quot;: &quot;Can approve or deny a workflow approval node&quot;,\r\n            &quot;name&quot;: &quot;Approve&quot;,\r\n            &quot;id&quot;: 26583\r\n    {\r\n      &quot;id&quot;: 21,\r\n      &quot;type&quot;: &quot;organization&quot;,\r\n      &quot;url&quot;: &quot;/api/v2/organizations/21/&quot;,\r\n      &quot;related&quot;: {\r\n        &quot;created_by&quot;: &quot;/api/v2/users/1/&quot;,\r\n        &quot;modified_by&quot;: &quot;/api/v2/users/1/&quot;,\r\n        &quot;projects&quot;: &quot;/api/v2/organizations/21/projects/&quot;,\r\n        &quot;inventories&quot;: &quot;/api/v2/organizations/21/inventories/&quot;,\r\n        &quot;job_templates&quot;: &quot;/api/v2/organizations/21/job_templates/&quot;,\r\n        &quot;workflow_job_templates&quot;: &quot;/api/v2/organizations/21/workflow_job_templates/&quot;,\r\n        &quot;notification_templates_error&quot;: &quot;/api/v2/organizations/21/notification_templates_error/&quot;,\r\n        &quot;notification_templates_approvals&quot;: &quot;/api/v2/organizations/21/notification_templates_approvals/&quot;,\r\n        &quot;object_roles&quot;: &quot;/api/v2/organizations/21/object_roles/&quot;,\r\n        &quot;access_list&quot;: &quot;/api/v2/organizations/21/access_list/&quot;,\r\n        &quot;instance_groups&quot;: &quot;/api/v2/organizations/21/instance_groups/&quot;,\r\n        &quot;galaxy_credentials&quot;: &quot;/api/v2/organizations/21/galaxy_credentials/&quot;\r\n      },\r\n      &quot;summary_fields&quot;: {\r\n        &quot;created_by&quot;: {\r\n          &quot;id&quot;: 1,\r\n          &quot;username&quot;: &quot;admin&quot;,\r\n          &quot;first_name&quot;: &quot;&quot;,\r\n          &quot;last_name&quot;: &quot;&quot;\r\n        },\r\n        &quot;object_roles&quot;: {\r\n          &quot;admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all aspects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Admin&quot;,\r\n            &quot;id&quot;: 4736,\r\n            &quot;user_only&quot;: true\r\n          },\r\n          &quot;execute_role&quot;: {\r\n            &quot;description&quot;: &quot;May run any executable resources in the organization&quot;,\r\n            &quot;name&quot;: &quot;Execute&quot;,\r\n            &quot;id&quot;: 4737\r\n          },\r\n          &quot;project_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all projects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Project Admin&quot;,\r\n            &quot;id&quot;: 4738\r\n          &quot;credential_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all credentials of the organization&quot;,\r\n            &quot;name&quot;: &quot;Credential Admin&quot;,\r\n            &quot;id&quot;: 4740\r\n          },\r\n          &quot;workflow_admin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all workflows of the organization&quot;,\r\n            &quot;name&quot;: &quot;Workflow Admin&quot;,\r\n            &quot;id&quot;: 4741\r\n          },\r\n          &quot;notification_admin_role&quot;: {\r\ndmin_role&quot;: {\r\n            &quot;description&quot;: &quot;Can manage all job templates of the organization&quot;,\r\n            &quot;name&quot;: &quot;Job Template Admin&quot;,\r\n            &quot;id&quot;: 4743\r\n          },\r\n          &quot;auditor_role&quot;: {\r\n            &quot;description&quot;: &quot;Can view all aspects of the organization&quot;,\r\n            &quot;name&quot;: &quot;Auditor&quot;,\r\n            &quot;id&quot;: 4744\r\n          &quot;read_role&quot;: {\r\n            &quot;description&quot;: &quot;May view settings for the organization&quot;,\r\n            &quot;name&quot;: &quot;Read&quot;,\r\n            &quot;id&quot;: 4746\r\n          },\r\n          &quot;approval_role&quot;: {\r\n            &quot;description&quot;: &quot;Can approve or deny a workflow approval node&quot;,\r\n            &quot;name&quot;: &quot;Approve&quot;,\r\n            &quot;id&quot;: null\r\n          }\r\n        },\r\n        &quot;user_capabilities&quot;: {\r\n          &quot;edit&quot;: true,\r\n          &quot;delete&quot;: true\r\n        },\r\n        &quot;related_field_counts&quot;: {\r\n          &quot;inventories&quot;: 6,\r\n    },\r\n```\r\n\r\nThe field that I want to extract and format into csv is \r\n&quot;id&quot;\r\n&quot;type&quot;\r\n\r\nHow do I use linux jq commands to extract those?\r\nExtract specific variables in the json to csv",
        "link": "https://stackoverflow.com/questions/75649776/convert-json-file-to-csv-in-linux-jq-command-format",
        "title": "Convert json file to csv in linux jq command format"
    },
    {
        "tags": [
            "json",
            "bash",
            "yaml",
            "jq",
            "yq"
        ],
        "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": 1678107997,
                "post_id": 75651078,
                "comment_id": 133463699,
                "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": 1678108678,
                "post_id": 75651078,
                "comment_id": 133463893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1575197,
                    "reputation": 31250,
                    "user_id": 1461850,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/7d7a8cd7ff08bbae37ace18cfa057c5b?s=256&d=identicon&r=PG",
                    "display_name": "Lee",
                    "link": "https://stackoverflow.com/users/1461850/lee"
                },
                "reply_to_user": {
                    "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": 1678110676,
                "post_id": 75651078,
                "comment_id": 133464548,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1678108837,
                "creation_date": 1678108837,
                "answer_id": 75651367,
                "question_id": 75651078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not process it directly with `yq`?\r\n\r\n```bash\r\neval $(yq e &#39;.. | select(. == &quot;*&quot;) | {(path | join(&quot;_&quot;)): . style=&quot;double&quot;} &#39; example.yaml | sed -E &#39;s/(.*): (.*)/\\1=\\2/g&#39;)\r\necho $services_pinger_build_dockerfile\r\n```\r\n\r\n`yq` command was taken from [this answer](https://stackoverflow.com/a/69303779/347964), see there for details.\r\n\r\nThe appended `sed` rewrites `a_b: &quot;c&quot;` into `a_b=&quot;c&quot;`, so we can then `eval` it in bash. I do not use the technique you show because it would cause the values to not be quoted in the output, which is bad especially for multi-line strings.\r\n\r\nThe code outputs `nodeapp`.",
                "title": "Read in multi-level YAML / JSON to bash variables"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678264012,
        "creation_date": 1678107054,
        "last_edit_date": 1678264012,
        "question_id": 75651078,
        "body_markdown": "Say I have a yaml file, `example.yaml`:\r\n\r\n    networks:\r\n      net:\r\n        driver: overlay\r\n    dockerfiles:\r\n      nodeapp: |\r\n        FROM node:18-alpine\r\n        WORKDIR /$NAME\r\n    services:\r\n      registry:\r\n        image: registry:2\r\n        ports:\r\n          - &quot;5000:5000&quot;\r\n          - &quot;337:337&quot;\r\n      pinger:\r\n        build:\r\n          context: .\r\n          dockerfile: nodeapp\r\n        deploy:\r\n          replicas: 3\r\n\r\nI can convert to JSON using [`yq`][1], and then set the top level entries as variables with [`jq`][2]:\r\n\r\n    eval $(yq e example.yaml -j | jq -r &#39;..? | to_entries | .[] | .key + &quot;=&quot; + (.value|tostring)&#39;)\r\n\r\n    echo $services\r\n    {registry:{image:registry:2,ports:[5000:5000]},pinger:{build:{context:.,dockerfile:nodeapp},deploy:{replicas:3}}}\r\n\r\n\r\nHowever, I cannot seem to get `jq` to recursively go into the objects and set variables, so that `echo $services_pinger_dockerfile` gives `&quot;nodeapp&quot;` for example.\r\n\r\nI&#39;ve seen in the docs that there is a [recursion operator][3]. Can anyone suggest a way of doing this?\r\n\r\n---\r\n\r\nThere are similar questions. But none that I found dealing with multilevel YAML/JSON to shell variables in this way.\r\n\r\nhttps://stackoverflow.com/questions/33627427/jq-getting-two-levels-of-keys\r\n\r\nhttps://stackoverflow.com/questions/44981265/extract-json-value-to-shell-variable-using-jq\r\n\r\nhttps://unix.stackexchange.com/questions/413878/json-array-to-bash-variables-using-jq\r\n\r\nhttps://unix.stackexchange.com/questions/121718/how-to-parse-json-with-shell-scripting-in-linux\r\n\r\nhttps://stackoverflow.com/questions/1955505/parsing-json-with-unix-tools#1955555\r\n\r\nhttps://stackoverflow.com/questions/5014632/how-can-i-parse-a-yaml-file-from-a-linux-shell-script\r\n\r\nhttps://stackoverflow.com/questions/72001044/how-to-read-yaml-file-into-bash-associative-array\r\n\r\n  [1]: https://mikefarah.gitbook.io/yq/\r\n  [2]: https://stedolan.github.io/jq/\r\n  [3]: https://stedolan.github.io/jq/manual/#RecursiveDescent:..",
        "link": "https://stackoverflow.com/questions/75651078/read-in-multi-level-yaml-json-to-bash-variables",
        "title": "Read in multi-level YAML / JSON to bash variables"
    },
    {
        "tags": [
            "json",
            "bash",
            "gitlab",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678125006,
                "post_id": 75653903,
                "comment_id": 133469000,
                "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": 1678125133,
                "post_id": 75653903,
                "comment_id": 133469042,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678126446,
                "post_id": 75653903,
                "comment_id": 133469385,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1678126800,
                "post_id": 75653903,
                "comment_id": 133469465,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678127016,
                "post_id": 75653903,
                "comment_id": 133469526,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678129480,
                "post_id": 75653903,
                "comment_id": 133470181,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678129556,
                "post_id": 75653903,
                "comment_id": 133470196,
                "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": 1678130382,
                "post_id": 75653903,
                "comment_id": 133470406,
                "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": 1678130428,
                "post_id": 75653903,
                "comment_id": 133470421,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "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": 1678130762,
                "post_id": 75653903,
                "comment_id": 133470498,
                "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": 1678137366,
                "post_id": 75653903,
                "comment_id": 133472098,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "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": 1678137754,
                "post_id": 75653903,
                "comment_id": 133472170,
                "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": 1678137936,
                "post_id": 75653903,
                "comment_id": 133472209,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678138116,
                "post_id": 75653903,
                "comment_id": 133472247,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "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": 1678138371,
                "post_id": 75653903,
                "comment_id": 133472297,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10609381,
                    "reputation": 13,
                    "user_id": 7813739,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iP4fE.jpg?s=256",
                    "display_name": "Bisteccowner",
                    "link": "https://stackoverflow.com/users/7813739/bisteccowner"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678138378,
                "post_id": 75653903,
                "comment_id": 133472299,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1678139222,
                "last_edit_date": 1678139222,
                "creation_date": 1678138280,
                "answer_id": 75656029,
                "question_id": 75653903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This probably calls for two separate copies of jq. Assuming your input file were changed to be valid JSON:\r\n\r\n```\r\njq -r &#39;to_entries[] | [.key, .value.path_to_file] | @tsv&#39; &lt;&quot;$JSON_TO_READ&quot; \\\r\n| while IFS=$&#39;\\t&#39; read -r key value; do\r\n    # comment this next line in your real system\r\n    (( ++http_status )) # stand-in so this can be tested without calling curl\r\n    # uncomment this next line and replace the url in your real system\r\n    #http_status=$(curl -s -o /dev/null -w &quot;%{http_code}&quot; &quot;http://example.com/$key&quot;) || continue\r\n    printf &#39;%s\\t%s\\n&#39; &quot;$key&quot; &quot;$http_status&quot;\r\n  done \\\r\n| jq -Rn --slurpfile input_file &quot;$JSON_TO_READ&quot; &#39;\r\n    reduce inputs as $inline\r\n      ($input_file[0];\r\n       (($inline | split(&quot;\\t&quot;)) as $pieces |\r\n        .[$pieces[0]].http_response = ($pieces[1])))&#39;\r\n```\r\n\r\nBreaking down the shell pipeline:\r\n\r\n - First, we have a copy of jq that emits a tab-separated stream with your key and value. An entry here would look like:\r\n\r\n   ```\r\n   service10&lt;TAB&gt;service10.txt\r\n   ```\r\n - Next, we have a shell pipeline (running a [BashFAQ #1](https://mywiki.wooledge.org/BashFAQ/001) loop) that reads these two variables, and runs curl (or in the example above, just adds an incrementing number as the status code) to determine the HTTP status code:\r\n\r\n   ```\r\n   service10&lt;TAB&gt;200\r\n   ```\r\n- Finally, we have another copy of jq that accepts your input file via `--slurpfile`, and reads the stream of tab-separated service keys and HTTP status codes from stdin, using a reducer to incrementally update the status file as new values come in. (Because `--slurpfile` contains a _list_ of JSON documents found in the file, not just a single document, we&#39;re referring to `$input_file[0]` to refer to the first -- and only -- document in the file).",
                "title": "jq loop over objects and use shell command output to add a field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678183368,
                "last_edit_date": 1678183368,
                "creation_date": 1678175947,
                "answer_id": 75659303,
                "question_id": 75653903,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your file isn&#39;t too big and you don&#39;t mind reading the same input file multiple times, then here is another solution that should work:\r\n\r\n1. Count [the number of key-value-pairs](https://stedolan.github.io/jq/manual/v1.6/#length) in the object\r\n2. Extract single entry by index from object\r\n3. Get `path_to_file` value from entry\r\n4. Call curl\r\n5. Add `http_response` to entry\r\n6. Use `jq -s` ([`--slurp`](https://stedolan.github.io/jq/manual/v1.6/#Invokingjq)) to reconstruct the object from its entries\r\n\r\n```\r\ninput=&#39;input.json&#39;\r\nlength=&quot;$(jq &#39;length&#39; &quot;$input&quot;)&quot;\r\nfor i in $(seq &quot;$length&quot;); do\r\n  entry=&quot;$(jq --argjson idx &quot;$i&quot; &#39;to_entries[$idx-1]&#39; &quot;$input&quot;)&quot;\r\n  path=&quot;$(printf &#39;%s&#39; &quot;$entry&quot; | jq -r &#39;.value.path_to_file&#39;)&quot;\r\n  last_status_code=&quot;$(curl ... &quot;$path&quot;)&quot;\r\n  printf &#39;%s&#39; &quot;$entry&quot; | jq --argjson status &quot;$last_status_code&quot; &#39;.value.http_response = $status&#39;\r\ndone | jq -s &#39;from_entries&#39;\r\n```",
                "title": "jq loop over objects and use shell command output to add a field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1678183368,
        "creation_date": 1678123238,
        "last_edit_date": 1678139499,
        "question_id": 75653903,
        "body_markdown": "I&#39;m trying to iterate over a JSON and add a field to each object in the JSON.\r\nI&#39;m doing this in a Gitlab pipeline stage but I don&#39;t think is important.\r\n\r\nThe JSON is this:\r\n\r\n```\r\n{\r\n &quot;service10&quot;: {\r\n     &quot;path_to_file&quot; : &quot;service10.txt&quot;\r\n     },\r\n&quot;service192&quot;: {\r\n     &quot;path_to_file&quot; : &quot;service192.txt&quot;\r\n     }\r\n}\r\n     \r\n```\r\n\r\nWhat I&#39;m doing is using the `path_to_file` to check in a Gitlab repo if that file exists and I need to save the http response, the code now looks as follows:\r\n\r\n\r\n```\r\ncheck_files_existence:\r\n  stage: update-external-repo\r\n  script:\r\n    - apt-get update --fix-missing\r\n    - apt-get install jq -y\r\n    - HTTP_RESPONSE_CODES=()\r\n\r\n    # Check for file\r\n    - |-\r\n      for FILE_TO_CHECK in $(jq -r &#39;.[].path_to_file &#39; $JSON_TO_READ); do\r\n        \r\n        last_status_code=($(curl [omitted]))\r\n        \r\n        HTTP_RESPONSE_CODES+=($last_status_code)      \r\n        \r\n       done\r\n\r\n   # Write array of responses into artifact\r\n    - echo &quot;${HTTP_RESPONSE_CODES[@]}&quot; &gt;&gt; ./http_response_code.txt\r\n\r\n  artifacts:\r\n    paths:\r\n      - ./http_response_code.txt\r\n    expire_in: 10 min\r\n\r\n```\r\n\r\nThis generates a .txt file with the http responses separated by a whitespace.\r\n\r\nWhat I want to do is add a field to each service while I loop over them with the http_response, so the JSON will be like:\r\n\r\n\r\n```\r\n{\r\n &quot;service10&quot;: {\r\n     &quot;path_to_file&quot; : &quot;service10.txt&quot;,\r\n     &quot;http_response&quot;: 200\r\n     },\r\n&quot;service192&quot;: {\r\n     &quot;path_to_file&quot; : &quot;service192.txt&quot;,\r\n     &quot;http_response&quot;: 404\r\n     }\r\n}\r\n```\r\n\r\nAnd then I&#39;m going to export this an artifact to use it in another stage in my Gitlab Pipeline.\r\n\r\nUsing the above for loop I can get the file path but then it looks like I cannot update the JSON, if I use something like \r\n\r\n```\r\nfor OBJECT in $(jq -r &#39;.[] &#39; $JSON_TO_READ)\r\n```\r\n\r\nI cannot read the file path because using \r\n\r\n```\r\njq &#39;.path_to_file $OBJECT&#39; \r\n```\r\n\r\nreturns an error.\r\n\r\n\r\nIs there a way to do this? \r\n\r\nThanks.",
        "link": "https://stackoverflow.com/questions/75653903/jq-loop-over-objects-and-use-shell-command-output-to-add-a-field",
        "title": "jq loop over objects and use shell command output to add a field"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678132103,
                "post_id": 75655062,
                "comment_id": 133470822,
                "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": 1678132722,
                "post_id": 75655062,
                "comment_id": 133470976,
                "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": 1678133990,
                "post_id": 75655062,
                "comment_id": 133471310,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1678150699,
                "last_edit_date": 1678150699,
                "creation_date": 1678133769,
                "answer_id": 75655448,
                "question_id": 75655062,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @OguzIsmail suggested, it&#39;s a bug. I believe it&#39;s already been reported as https://github.com/stedolan/jq/issues/1859\r\n\r\nSee in particular the first contribution by ravron in April 2019 (!), and the followup by nicowilliams.\r\n\r\nRecall that `E?` is shorthand for `try E catch empty`, hence the title of the bug report:\r\n&quot;try/catch catches more than it should&quot;\r\n\r\nIt&#39;s as though the `catch` clause is misplaced:\r\n\r\n    try (select(has(&quot;a&quot;)) | .a[]) catch empty\r\n\r\nIn cases like this, comparing the results with those obtained using gojq can be helpful.",
                "title": "Getting a generator on a null value after select gives no error"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1678150699,
        "creation_date": 1678131090,
        "question_id": 75655062,
        "body_markdown": "Consider this example:\r\n\r\n    echo null | jq &#39;[{&quot;a&quot;: null}, {&quot;a&quot;: [1]}][] | select(has(&quot;a&quot;)?) | .a[]&#39;\r\n\r\nIt gives no error on the first value, but this one does:\r\n\r\n    echo null | jq &#39;[{&quot;a&quot;: null}, {&quot;a&quot;: [1]}][] | .a[]&#39;\r\n\r\nIt seems that nothing should change, because all values in the array satisfy the filter in the `select` expression.\r\n\r\nWhat is the reason for this behavior?",
        "link": "https://stackoverflow.com/questions/75655062/getting-a-generator-on-a-null-value-after-select-gives-no-error",
        "title": "Getting a generator on a null value after select gives no error"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1678185235,
                "last_edit_date": 1678185235,
                "creation_date": 1678183541,
                "answer_id": 75660526,
                "question_id": 75660442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can make the comparison using `IN` (or `any` for jq &lt; 1.6), for example:\r\n```sh\r\n# jq 1.6\r\njq --arg names &#39;a c&#39; &#39;.[] | select(IN(.name; ($names / &quot; &quot;)[]))&#39;\r\n\r\n# jq 1.5\r\njq --arg names &#39;a c&#39; &#39;.[] | select(any(.name == ($names / &quot; &quot;)[]; .))&#39;\r\n```\r\n\r\nIf your search keys are unique, you could also build up an `INDEX`, and lookup the fields:\r\n```sh\r\n# jq 1.6\r\njq --arg names &#39;a c&#39; &#39;INDEX(.name)[($names / &quot; &quot;)[]]&#39;\r\n\r\n# jq 1.5\r\njq --arg names &#39;a c&#39; &#39;map({key:.name, value:.}) | from_entries[($names / &quot; &quot;)[]]&#39;\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;name&quot;: &quot;a&quot;\r\n}\r\n{\r\n  &quot;c&quot;: 3,\r\n  &quot;name&quot;: &quot;c&quot;\r\n}\r\n```",
                "title": "How to filter any array elements if they contains other array elements?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678184542,
                "last_edit_date": 1678184542,
                "creation_date": 1678183848,
                "answer_id": 75660568,
                "question_id": 75660442,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easiest is probably to split your `names` into an array first, then use [`IN`](https://stedolan.github.io/jq/manual/v1.6/#SQL-StyleOperators) to filter your stream:\r\n\r\n```\r\njq -r --arg names &#39;a c&#39; &#39;($names/&quot; &quot;) as $names\r\n| .[] | select(.name | IN($names[]))&#39;\r\n```\r\n\r\nOr using [`any`](https://stedolan.github.io/jq/manual/v1.6/#any,any(condition),any(generator;condition)):\r\n\r\n```\r\njq -r --arg names &#39;a c&#39; &#39;($names/&quot; &quot;) as $names\r\n| .[] | select(any(.name == $names[]; .))&#39;\r\n```\r\n\r\n(the latter simply inlines `IN`: `def IN(s): any(s == .; .);`)",
                "title": "How to filter any array elements if they contains other array elements?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678186233,
        "creation_date": 1678183112,
        "last_edit_date": 1678186233,
        "question_id": 75660442,
        "body_markdown": "Consider the following json:\r\n\r\n    [\r\n      {\r\n        &quot;val&quot;: 1,\r\n        &quot;name&quot;: &quot;a&quot;\r\n      },\r\n      {\r\n        &quot;val&quot;: 2,\r\n        &quot;name&quot;: &quot;b&quot;\r\n      },\r\n      {\r\n        &quot;val&quot;: 3,\r\n        &quot;name&quot;: &quot;c&quot;\r\n      }\r\n    ]\r\n\r\nI want to pass an argument of space separated elements to jq and filter only these elements that have names matching to one of the argument elements. The following does not work, and I do not understand why - it only filters the first element. I suspect that `$input` is not updated. I do not know how to &quot;join streams&quot; to make it possible to use both streams at the same time - I have one stream the input and another is `$names | split(&quot; &quot;)`.\r\n\r\n    $ jq -r --arg names &#39;a c&#39; &#39;.[] | select(. as $input | $names | split(&quot; &quot;) | index($input.name) == 0)&#39; 1.json \r\n    {\r\n      &quot;val&quot;: 1,\r\n      &quot;name&quot;: &quot;a&quot;\r\n    }\r\n\r\nI have jq-1.5 available.\r\n",
        "link": "https://stackoverflow.com/questions/75660442/how-to-filter-any-array-elements-if-they-contains-other-array-elements",
        "title": "How to filter any array elements if they contains other array elements?"
    },
    {
        "tags": [
            "java",
            "json",
            "prometheus",
            "jq",
            "metrics"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 27803721,
                    "reputation": 216,
                    "user_id": 21227665,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e7e1f6c15cd5c02d60909d2c3de98741?s=256&d=identicon&r=PG",
                    "display_name": "hrystynaKb",
                    "link": "https://stackoverflow.com/users/21227665/hrystynakb"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678184901,
                "post_id": 75660722,
                "comment_id": 133480304,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1682772048,
                "creation_date": 1682772048,
                "answer_id": 76136278,
                "question_id": 75660722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Maybe something like this?\r\n\r\n```jq\r\npaths(scalars) as $p \r\n| &quot;\\($p|join(&quot;_&quot;)|gsub(&quot;[^\\\\w_.-]&quot;;&quot;&quot;))=\\(getpath($p)|@sh)&quot;\r\n```\r\n\r\n```shell-session\r\n$ jq -r &#39;paths(scalars) as $p | &quot;\\($p|join(&quot;_&quot;)|gsub(&quot;[^\\\\w_.-]&quot;;&quot;&quot;))=\\(getpath($p)|@sh)&quot;&#39; file.json \r\n\r\nversion=&#39;3.0.0&#39;\r\ngauges_gc.G1-Old-Generation.count_value=0\r\ngauges_gc.G1-Old-Generation.time_value=0\r\ngauges_gc.G1-Young-Generation.count_value=30\r\ngauges_gc.G1-Young-Generation.time_value=427\r\ngauges_jvm.name_value=&#39;7@hubstorage&#39;\r\ngauges_jvm.uptime_value=44799\r\ngauges_jvm.vendor_value=&#39;Azul Systems, Inc. OpenJDK 64-Bit Server VM 11.0.8+10-LTS (11)&#39;\r\ngauges_memory.heap.committed_value=208666624\r\ngauges_memory.heap.init_value=65011712\r\ngauges_memory.heap.max_value=1035993088\r\ngauges_memory.heap.usage_value=0.11967882164094129\r\ngauges_memory.heap.used_value=123986432\r\ngauges_memory.non-heap.committed_value=114434048\r\ngauges_memory.non-heap.init_value=7667712\r\ngauges_memory.non-heap.max_value=-1\r\ngauges_memory.non-heap.usage_value=-108223704\r\ngauges_memory.non-heap.used_value=108223704\r\ngauges_memory.pools.CodeHeap-non-nmethods.committed_value=2555904\r\ngauges_memory.pools.CodeHeap-non-nmethods.init_value=2555904\r\ngauges_memory.pools.CodeHeap-non-nmethods.max_value=5832704\r\ngauges_memory.pools.CodeHeap-non-nmethods.usage_value=0.23114905196629212\r\ngauges_memory.pools.CodeHeap-non-nmethods.used_value=1348224\r\ngauges_memory.pools.CodeHeap-non-profiled-nmethods.committed_value=3670016\r\ngauges_memory.pools.CodeHeap-non-profiled-nmethods.init_value=2555904\r\ngauges_memory.pools.CodeHeap-non-profiled-nmethods.max_value=122912768\r\ngauges_memory.pools.CodeHeap-non-profiled-nmethods.usage_value=0.029816007398027193\r\ngauges_memory.pools.CodeHeap-non-profiled-nmethods.used_value=3664768\r\ngauges_memory.pools.CodeHeap-profiled-nmethods.committed_value=12517376\r\ngauges_memory.pools.CodeHeap-profiled-nmethods.init_value=2555904\r\ngauges_memory.pools.CodeHeap-profiled-nmethods.max_value=122912768\r\ngauges_memory.pools.CodeHeap-profiled-nmethods.usage_value=0.10141253998933618\r\ngauges_memory.pools.CodeHeap-profiled-nmethods.used_value=12464896\r\ngauges_memory.pools.Compressed-Class-Space.committed_value=12267520\r\ngauges_memory.pools.Compressed-Class-Space.init_value=0\r\ngauges_memory.pools.Compressed-Class-Space.max_value=1073741824\r\ngauges_memory.pools.Compressed-Class-Space.usage_value=0.010960675776004791\r\ngauges_memory.pools.Compressed-Class-Space.used_value=11768936\r\ngauges_memory.pools.G1-Eden-Space.committed_value=118489088\r\ngauges_memory.pools.G1-Eden-Space.init_value=15728640\r\ngauges_memory.pools.G1-Eden-Space.max_value=-1\r\ngauges_memory.pools.G1-Eden-Space.usage_value=0.6548672566371682\r\ngauges_memory.pools.G1-Eden-Space.used_value=77594624\r\ngauges_memory.pools.G1-Old-Gen.committed_value=82837504\r\ngauges_memory.pools.G1-Old-Gen.init_value=49283072\r\ngauges_memory.pools.G1-Old-Gen.max_value=1035993088\r\ngauges_memory.pools.G1-Old-Gen.usage_value=0.0376950159729251\r\ngauges_memory.pools.G1-Old-Gen.used_value=39051776\r\ngauges_memory.pools.G1-Survivor-Space.committed_value=7340032\r\ngauges_memory.pools.G1-Survivor-Space.init_value=0\r\ngauges_memory.pools.G1-Survivor-Space.max_value=-1\r\ngauges_memory.pools.G1-Survivor-Space.usage_value=1\r\ngauges_memory.pools.G1-Survivor-Space.used_value=7340032\r\ngauges_memory.pools.Metaspace.committed_value=83423232\r\ngauges_memory.pools.Metaspace.init_value=0\r\ngauges_memory.pools.Metaspace.max_value=-1\r\ngauges_memory.pools.Metaspace.usage_value=0.9467012738130309\r\ngauges_memory.pools.Metaspace.used_value=78976880\r\ngauges_memory.total.committed_value=323100672\r\ngauges_memory.total.init_value=72679424\r\ngauges_memory.total.max_value=1035993087\r\ngauges_memory.total.used_value=232210136\r\ngauges_threads.blocked.count_value=0\r\ngauges_threads.count_value=34\r\ngauges_threads.daemon.count_value=14\r\ngauges_threads.deadlock.count_value=0\r\ngauges_threads.new.count_value=0\r\ngauges_threads.runnable.count_value=11\r\ngauges_threads.terminated.count_value=0\r\ngauges_threads.timed_waiting.count_value=17\r\ngauges_threads.waiting.count_value=6\r\ncounters_counter_count=1\r\nhistograms_histogram_count=3\r\nhistograms_histogram_max=100\r\nhistograms_histogram_mean=41.66666666666666\r\nhistograms_histogram_min=5\r\nhistograms_histogram_p50=20\r\nhistograms_histogram_p75=100\r\nhistograms_histogram_p95=100\r\nhistograms_histogram_p98=100\r\nhistograms_histogram_p99=100\r\nhistograms_histogram_p999=100\r\nhistograms_histogram_stddev=41.69998667732268\r\nmeters_meter_count=201\r\nmeters_meter_m15_rate=38.666674566183616\r\nmeters_meter_m1_rate=22.433012859955905\r\nmeters_meter_m5_rate=35.77324719371856\r\nmeters_meter_mean_rate=4.944024762580441\r\nmeters_meter_units=&#39;events/second&#39;\r\n\r\n```",
                "title": "Convert JSON to prometheus readable format"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1682772048,
        "creation_date": 1678184673,
        "last_edit_date": 1678185746,
        "question_id": 75660722,
        "body_markdown": "This is my API response in JSON format. Not able to convert it to Prometheus format using jq or any other better approach to capture the metrics on Prometheus UI.\r\n```json\r\n{\r\n  &quot;version&quot;: &quot;3.0.0&quot;,\r\n  &quot;gauges&quot;: {\r\n    &quot;gc.G1-Old-Generation.count&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;gc.G1-Old-Generation.time&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;gc.G1-Young-Generation.count&quot;: {\r\n      &quot;value&quot;: 30\r\n    },\r\n    &quot;gc.G1-Young-Generation.time&quot;: {\r\n      &quot;value&quot;: 427\r\n    },\r\n    &quot;jvm.name&quot;: {\r\n      &quot;value&quot;: &quot;7@hubstorage&quot;\r\n    },\r\n    &quot;jvm.uptime&quot;: {\r\n      &quot;value&quot;: 44799\r\n    },\r\n    &quot;jvm.vendor&quot;: {\r\n      &quot;value&quot;: &quot;Azul Systems, Inc. OpenJDK 64-Bit Server VM 11.0.8+10-LTS (11)&quot;\r\n    },\r\n    &quot;memory.heap.committed&quot;: {\r\n      &quot;value&quot;: 208666624\r\n    },\r\n    &quot;memory.heap.init&quot;: {\r\n      &quot;value&quot;: 65011712\r\n    },\r\n    &quot;memory.heap.max&quot;: {\r\n      &quot;value&quot;: 1035993088\r\n    },\r\n    &quot;memory.heap.usage&quot;: {\r\n      &quot;value&quot;: 0.11967882164094129\r\n    },\r\n    &quot;memory.heap.used&quot;: {\r\n      &quot;value&quot;: 123986432\r\n    },\r\n    &quot;memory.non-heap.committed&quot;: {\r\n      &quot;value&quot;: 114434048\r\n    },\r\n    &quot;memory.non-heap.init&quot;: {\r\n      &quot;value&quot;: 7667712\r\n    },\r\n    &quot;memory.non-heap.max&quot;: {\r\n      &quot;value&quot;: -1\r\n    },\r\n    &quot;memory.non-heap.usage&quot;: {\r\n      &quot;value&quot;: -108223704\r\n    },\r\n    &quot;memory.non-heap.used&quot;: {\r\n      &quot;value&quot;: 108223704\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-nmethods&#39;.committed&quot;: {\r\n      &quot;value&quot;: 2555904\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-nmethods&#39;.init&quot;: {\r\n      &quot;value&quot;: 2555904\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-nmethods&#39;.max&quot;: {\r\n      &quot;value&quot;: 5832704\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-nmethods&#39;.usage&quot;: {\r\n      &quot;value&quot;: 0.23114905196629212\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-nmethods&#39;.used&quot;: {\r\n      &quot;value&quot;: 1348224\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-profiled-nmethods&#39;.committed&quot;: {\r\n      &quot;value&quot;: 3670016\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-profiled-nmethods&#39;.init&quot;: {\r\n      &quot;value&quot;: 2555904\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-profiled-nmethods&#39;.max&quot;: {\r\n      &quot;value&quot;: 122912768\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-profiled-nmethods&#39;.usage&quot;: {\r\n      &quot;value&quot;: 0.029816007398027193\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;non-profiled-nmethods&#39;.used&quot;: {\r\n      &quot;value&quot;: 3664768\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;profiled-nmethods&#39;.committed&quot;: {\r\n      &quot;value&quot;: 12517376\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;profiled-nmethods&#39;.init&quot;: {\r\n      &quot;value&quot;: 2555904\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;profiled-nmethods&#39;.max&quot;: {\r\n      &quot;value&quot;: 122912768\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;profiled-nmethods&#39;.usage&quot;: {\r\n      &quot;value&quot;: 0.10141253998933618\r\n    },\r\n    &quot;memory.pools.CodeHeap-&#39;profiled-nmethods&#39;.used&quot;: {\r\n      &quot;value&quot;: 12464896\r\n    },\r\n    &quot;memory.pools.Compressed-Class-Space.committed&quot;: {\r\n      &quot;value&quot;: 12267520\r\n    },\r\n    &quot;memory.pools.Compressed-Class-Space.init&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;memory.pools.Compressed-Class-Space.max&quot;: {\r\n      &quot;value&quot;: 1073741824\r\n    },\r\n    &quot;memory.pools.Compressed-Class-Space.usage&quot;: {\r\n      &quot;value&quot;: 0.010960675776004791\r\n    },\r\n    &quot;memory.pools.Compressed-Class-Space.used&quot;: {\r\n      &quot;value&quot;: 11768936\r\n    },\r\n    &quot;memory.pools.G1-Eden-Space.committed&quot;: {\r\n      &quot;value&quot;: 118489088\r\n    },\r\n    &quot;memory.pools.G1-Eden-Space.init&quot;: {\r\n      &quot;value&quot;: 15728640\r\n    },\r\n    &quot;memory.pools.G1-Eden-Space.max&quot;: {\r\n      &quot;value&quot;: -1\r\n    },\r\n    &quot;memory.pools.G1-Eden-Space.usage&quot;: {\r\n      &quot;value&quot;: 0.6548672566371682\r\n    },\r\n    &quot;memory.pools.G1-Eden-Space.used&quot;: {\r\n      &quot;value&quot;: 77594624\r\n    },\r\n    &quot;memory.pools.G1-Old-Gen.committed&quot;: {\r\n      &quot;value&quot;: 82837504\r\n    },\r\n    &quot;memory.pools.G1-Old-Gen.init&quot;: {\r\n      &quot;value&quot;: 49283072\r\n    },\r\n    &quot;memory.pools.G1-Old-Gen.max&quot;: {\r\n      &quot;value&quot;: 1035993088\r\n    },\r\n    &quot;memory.pools.G1-Old-Gen.usage&quot;: {\r\n      &quot;value&quot;: 0.0376950159729251\r\n    },\r\n    &quot;memory.pools.G1-Old-Gen.used&quot;: {\r\n      &quot;value&quot;: 39051776\r\n    },\r\n    &quot;memory.pools.G1-Survivor-Space.committed&quot;: {\r\n      &quot;value&quot;: 7340032\r\n    },\r\n    &quot;memory.pools.G1-Survivor-Space.init&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;memory.pools.G1-Survivor-Space.max&quot;: {\r\n      &quot;value&quot;: -1\r\n    },\r\n    &quot;memory.pools.G1-Survivor-Space.usage&quot;: {\r\n      &quot;value&quot;: 1\r\n    },\r\n    &quot;memory.pools.G1-Survivor-Space.used&quot;: {\r\n      &quot;value&quot;: 7340032\r\n    },\r\n    &quot;memory.pools.Metaspace.committed&quot;: {\r\n      &quot;value&quot;: 83423232\r\n    },\r\n    &quot;memory.pools.Metaspace.init&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;memory.pools.Metaspace.max&quot;: {\r\n      &quot;value&quot;: -1\r\n    },\r\n    &quot;memory.pools.Metaspace.usage&quot;: {\r\n      &quot;value&quot;: 0.9467012738130309\r\n    },\r\n    &quot;memory.pools.Metaspace.used&quot;: {\r\n      &quot;value&quot;: 78976880\r\n    },\r\n    &quot;memory.total.committed&quot;: {\r\n      &quot;value&quot;: 323100672\r\n    },\r\n    &quot;memory.total.init&quot;: {\r\n      &quot;value&quot;: 72679424\r\n    },\r\n    &quot;memory.total.max&quot;: {\r\n      &quot;value&quot;: 1035993087\r\n    },\r\n    &quot;memory.total.used&quot;: {\r\n      &quot;value&quot;: 232210136\r\n    },\r\n    &quot;threads.blocked.count&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;threads.count&quot;: {\r\n      &quot;value&quot;: 34\r\n    },\r\n    &quot;threads.daemon.count&quot;: {\r\n      &quot;value&quot;: 14\r\n    },\r\n    &quot;threads.deadlock.count&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;threads.deadlocks&quot;: {\r\n      &quot;value&quot;: []\r\n    },\r\n    &quot;threads.new.count&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;threads.runnable.count&quot;: {\r\n      &quot;value&quot;: 11\r\n    },\r\n    &quot;threads.terminated.count&quot;: {\r\n      &quot;value&quot;: 0\r\n    },\r\n    &quot;threads.timed_waiting.count&quot;: {\r\n      &quot;value&quot;: 17\r\n    },\r\n    &quot;threads.waiting.count&quot;: {\r\n      &quot;value&quot;: 6\r\n    }\r\n  },\r\n  &quot;counters&quot;: {\r\n    &quot;counter&quot;: {\r\n      &quot;count&quot;: 1\r\n    }\r\n  },\r\n  &quot;histograms&quot;: {\r\n    &quot;histogram&quot;: {\r\n      &quot;count&quot;: 3,\r\n      &quot;max&quot;: 100,\r\n      &quot;mean&quot;: 41.66666666666666,\r\n      &quot;min&quot;: 5,\r\n      &quot;p50&quot;: 20,\r\n      &quot;p75&quot;: 100,\r\n      &quot;p95&quot;: 100,\r\n      &quot;p98&quot;: 100,\r\n      &quot;p99&quot;: 100,\r\n      &quot;p999&quot;: 100,\r\n      &quot;stddev&quot;: 41.69998667732268\r\n    }\r\n  },\r\n  &quot;meters&quot;: {\r\n    &quot;meter&quot;: {\r\n      &quot;count&quot;: 201,\r\n      &quot;m15_rate&quot;: 38.666674566183616,\r\n      &quot;m1_rate&quot;: 22.433012859955905,\r\n      &quot;m5_rate&quot;: 35.77324719371856,\r\n      &quot;mean_rate&quot;: 4.944024762580441,\r\n      &quot;units&quot;: &quot;events/second&quot;\r\n    }\r\n  },\r\n  &quot;timers&quot;: {}\r\n}\r\n```\r\nGetting the following error on Prometheus:\r\n&quot;INVALID&quot; is not a valid start token\r\n",
        "link": "https://stackoverflow.com/questions/75660722/convert-json-to-prometheus-readable-format",
        "title": "Convert JSON to prometheus readable format"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678190897,
                "post_id": 75661161,
                "comment_id": 133481825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6886800,
                    "reputation": 1160,
                    "user_id": 5291611,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/21e356690b1071eb3f81ce47cc14c84b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "alturkovic",
                    "link": "https://stackoverflow.com/users/5291611/alturkovic"
                },
                "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": 1678193574,
                "post_id": 75661161,
                "comment_id": 133482501,
                "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": 1678194125,
                "post_id": 75661161,
                "comment_id": 133482651,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6886800,
                    "reputation": 1160,
                    "user_id": 5291611,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://www.gravatar.com/avatar/21e356690b1071eb3f81ce47cc14c84b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "alturkovic",
                    "link": "https://stackoverflow.com/users/5291611/alturkovic"
                },
                "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": 1678194571,
                "post_id": 75661161,
                "comment_id": 133482767,
                "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": 1678197253,
                "post_id": 75661161,
                "comment_id": 133483520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678194851,
                "last_edit_date": 1678194851,
                "creation_date": 1678191090,
                "answer_id": 75661821,
                "question_id": 75661161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not possible directly from jq (jq cannot call external programs from within a jq program). But if your input only contains a single object with those two properties, the following should work in POSIX shells:\r\n\r\n```\r\n{\r\n  jq &#39;{url}&#39; input.json;\r\n  jq -r &#39;.html&#39; input.json | pup ... | jq -Rs &#39;{scripts: .}&#39;;\r\n} | jq -s &#39;add&#39;\r\n```\r\n\r\nIt&#39;s also possible to invoke `jq` with `--arg` – which still invokes jq 2 times and reads your input twice:\r\n\r\n```\r\njq --arg scripts &quot;$(jq -r &#39;.html&#39; input.json | pup ... )&quot; \\\r\n&#39;{url, $scripts}&#39; input.json\r\n```\r\n\r\nSample output:\r\n\r\n```json\r\n{\r\n  &quot;url&quot;: &quot;http://example.com&quot;,\r\n  &quot;scripts&quot;: &quot;....&quot;\r\n}\r\n```",
                "title": "How can I invoke external command to transform json using jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678192357,
                "creation_date": 1678192357,
                "answer_id": 75662009,
                "question_id": 75661161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `json{}` instead of `text{}` to enable post-processing with jq. For example:\r\n```sh\r\njsonfile=&#39;example.json&#39;\r\njq &#39;.scripts = (input | map(.text // empty))&#39; &quot;$jsonfile&quot; &lt;(\r\n  jq -r &#39;.html&#39; &quot;$jsonfile&quot; | pup &#39;script[type=text/javascript] json{}&#39;\r\n)\r\n```",
                "title": "How can I invoke external command to transform json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1678194851,
        "creation_date": 1678186998,
        "question_id": 75661161,
        "body_markdown": "I have the following json input:\r\n```\r\n{\r\n  &quot;url&quot;: &quot;https://www.example.com&quot;, \r\n  &quot;html&quot;: &quot;&lt;html&gt;...&lt;/html&gt;&quot;\r\n}\r\n```\r\n\r\nHow can I use `jq` to extract all JavaScript `&lt;script&gt;` tags from `html` using `pup`?\r\n\r\nFor an example, I can extract all `script`s I want from a single html using a pipe call: \r\n```\r\ncat example.json | jq -r .html | pup &#39;script[type=&quot;text/javascript&quot;] text{}&#39;\r\n```\r\n\r\nI would like to put all of these extracted scripts in a new resulting json:\r\n```\r\n{\r\n  &quot;url&quot;: &quot;https://www.example.com&quot;,\r\n  &quot;scripts&quot;: [\r\n    &quot;&lt;script&gt;...&quot;,\r\n    &quot;&lt;script&gt;...&quot;\r\n  ]\r\n}\r\n```\r\n\r\nIf I try using:\r\n```\r\njq -c &#39;{url: .url, scripts: [.html | pup &quot;script[type=text/javascript] text{}&quot;]}&#39;\r\n```\r\nit will not work because `pup` is an external command and not part of `jq`.\r\n\r\nHow can I achieve this?",
        "link": "https://stackoverflow.com/questions/75661161/how-can-i-invoke-external-command-to-transform-json-using-jq",
        "title": "How can I invoke external command to transform json using jq?"
    },
    {
        "tags": [
            "bash",
            "shell",
            "filter",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1678191064,
                "creation_date": 1678191064,
                "answer_id": 75661817,
                "question_id": 75661787,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply delete that field using `del`:\r\n```sh\r\n… | jq &#39;.builds[] | select(.displayName | contains(&quot;NAME&quot;)) | del(._class)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;displayName&quot;: &quot;NAME-(#1498)&quot;,\r\n  &quot;number&quot;: 1498\r\n}\r\n```\r\nNote: If you output JSON, the `-r` flag isn&#39;t doing anything.",
                "title": "jq exclude key for output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678191064,
        "creation_date": 1678190885,
        "question_id": 75661787,
        "body_markdown": "I need to exclude field `_class` from this output:\r\n\r\n```json\r\n{\r\n  &quot;_class&quot;: &quot;hudson.model.FreeStyleBuild&quot;,\r\n  &quot;displayName&quot;: &quot;NAME-(#1498)&quot;,\r\n  &quot;number&quot;: 1498\r\n}\r\n```\r\n\r\nWhat I use for get this json\r\n\r\n```bash\r\ncurl -gn http://&lt;jenkins-site&gt;/job/&lt;build-name&gt;/api/json?tree=builds[displayName,number]&amp;pretty=true | jq -r &#39;.builds[] | select(.displayName | contains(&quot;NAME&quot;))&#39;\r\n```\r\n\r\nResult must be just:\r\n\r\n```json\r\n{\r\n  &quot;displayName&quot;: &quot;NAME-(#1498)&quot;,\r\n  &quot;number&quot;: 1498\r\n}\r\n```\r\n\r\nI tried using `|not` and `del`, but that didn&#39;t work for me.",
        "link": "https://stackoverflow.com/questions/75661787/jq-exclude-key-for-output",
        "title": "jq exclude key for output"
    },
    {
        "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": 0,
                "creation_date": 1678227024,
                "post_id": 75667634,
                "comment_id": 133491868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1640952,
                    "reputation": 7501,
                    "user_id": 1513388,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/a235aa59e48586dcab866c685d042874?s=256&d=identicon&r=PG",
                    "display_name": "user1513388",
                    "link": "https://stackoverflow.com/users/1513388/user1513388"
                },
                "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": 1678227749,
                "post_id": 75667634,
                "comment_id": 133492049,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678396424,
                "last_edit_date": 1678396424,
                "creation_date": 1678242992,
                "answer_id": 75668975,
                "question_id": 75667634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On the one hand, it looks like you want:\r\n\r\n    .cells[] | .title = .source[0]\r\n\r\nOn the other hand, the sample input shown in the Q does not seem to match up with the sample output.\r\n\r\nOr, in accordance with your comment:\r\n\r\n    {commands: [.cells[] | .title = .source[0]]}",
                "title": "Duplicate output from jq when processing JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678302978,
                "last_edit_date": 1678302978,
                "creation_date": 1678275088,
                "answer_id": 75672459,
                "question_id": 75667634,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want to iterate your `cells` array only once. You have at least 3 options that will all produce the same output:\r\n\r\n#### Assignment operator [`=`](https://stedolan.github.io/jq/manual/v1.6/#Plainassignment:=)\r\n\r\nSee [peak&#39;s answer](https://stackoverflow.com/a/75668975/112968)\r\n\r\n```\r\n.cells[] | .title = .source[0]\r\n```\r\n\r\nIt will assign the first item in `.source` to the (new) property `.title` of each cell\r\n\r\n#### Merging objects [`+`](https://stedolan.github.io/jq/manual/v1.6/#Addition:+)\r\n\r\nConstruct a new object by merging in a new object with a single property into the existing cell:\r\n\r\n```\r\n.cells[] = . + {title: .source[0]}\r\n```\r\n\r\nThis is useful if you want to add several new properties\r\n\r\n#### Reconstructing result objects from scratch [`{}`](https://stedolan.github.io/jq/manual/v1.6/#ObjectConstruction:{})\r\n\r\nSince your objects only contains a single property, you can reconstruct the result object from scratch, listing all old and new properties:\r\n\r\n```\r\n.cells[] | {source, title: .source[0]}\r\n```\r\n\r\nUseful if the result structure does not resemble the input structure or uses only a few properties of the input.\r\n\r\n*****\r\n\r\nThe output for all 3 programs is:\r\n\r\n```json\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the files in a directory \\n&quot;,\r\n    &quot;ls -l \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the files in a directory \\n&quot;\r\n}\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the working directory \\n&quot;,\r\n    &quot;pwd \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the working directory \\n&quot;\r\n}\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the network config \\n&quot;,\r\n    &quot;ipconfig \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the network config \\n&quot;\r\n}\r\n```",
                "title": "Duplicate output from jq when processing JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678396424,
        "creation_date": 1678226743,
        "question_id": 75667634,
        "body_markdown": "I have a JSON data structure the looks like this&quot; \r\n\r\n```\r\n{\r\n    &quot;cells&quot;: [\r\n     {\r\n      &quot;source&quot;: [\r\n       &quot;# Get the files in a directory \\n&quot;,\r\n       &quot;ls -l \\n&quot;\r\n      ]\r\n     },\r\n     {\r\n      &quot;source&quot;: [\r\n        &quot;# Get the working directory \\n&quot;,\r\n        &quot;pwd \\n&quot;\r\n      ]\r\n     },\r\n     {\r\n      &quot;source&quot;: [\r\n       &quot;# Get the network config \\n&quot;,\r\n       &quot;ipconfig \\n&quot;\r\n      ]\r\n     }\r\n    ],\r\n    &quot;metadata&quot;: {\r\n     &quot;kernelspec&quot;: {\r\n      &quot;display_name&quot;: &quot;Bash&quot;,\r\n      &quot;language&quot;: &quot;bash&quot;,\r\n      &quot;name&quot;: &quot;bash&quot;\r\n     }\r\n    }\r\n}\r\n```\r\n\r\nI want to create a new structure from it that looks like this: \r\n\r\n```\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the files in a directory \\n&quot;,\r\n    &quot;ls -l \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the files in a directory \\n&quot;\r\n}\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the files in a directory \\n&quot;,\r\n    &quot;ls -l \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the working directory \\n&quot;\r\n}\r\n{\r\n  &quot;source&quot;: [\r\n    &quot;# Get the files in a directory \\n&quot;,\r\n    &quot;ls -l \\n&quot;\r\n  ],\r\n  &quot;title&quot;: &quot;# Get the network config \\n&quot;\r\n}\r\n```\r\n\r\nMy jq command looks like this: \r\n\r\n```\r\ncat test.json | jq &#39;{source: .cells[].source, title: .cells[].source[0] }&#39;\r\n```\r\n\r\nHowever I&#39;m getting duplicate records in the output. I know it has something to do with the way that jq is processing the input data. Is there a way handle this scenario ? ",
        "link": "https://stackoverflow.com/questions/75667634/duplicate-output-from-jq-when-processing-json",
        "title": "Duplicate output from jq when processing JSON"
    },
    {
        "tags": [
            "json",
            "shell",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678322454,
                "creation_date": 1678322454,
                "answer_id": 75679455,
                "question_id": 75679431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `transpose` the arrays to align their items:\r\n```sh\r\njq -r &#39;[.Defaults.Timestamps, .MetricDataForAccount[].Values] | transpose[] | @csv&#39;\r\n```\r\nOr iterate manually (e.g. using `to_entries` to access the indices as `.key`):\r\n```sh\r\njq -r &#39;\r\n  .Defaults.Timestamps as $timestamps\r\n  | .MetricDataForAccount[].Values\r\n  | to_entries[] | [$timestamps[.key], .value]\r\n  | @csv\r\n&#39;\r\n```\r\nOutput:\r\n```\r\n1677801540,2920126.416862745\r\n1677801480,2920285.9993725484\r\n1677801420,2920305.409303922\r\n```",
                "title": "Query values in two arrays and merge them together"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1678429116,
        "creation_date": 1678322018,
        "last_edit_date": 1678429116,
        "question_id": 75679431,
        "body_markdown": "I&#39;m trying to query 2 separate arrays in a JSON using a ```shell``` script and merge them together to potentially open as a .csv in excel.\r\n\r\nHere is a sample of the JSON:\r\n\r\n``` json\r\n{\r\n  &quot;Defaults&quot;: {\r\n    &quot;Timestamps&quot;: [\r\n      1677801540,\r\n      1677801480,\r\n      1677801420\r\n    ]\r\n  },\r\n  &quot;MetricDataForAccount&quot;: [\r\n    {\r\n      &quot;Values&quot;: [\r\n        2920126.416862745,\r\n        2920285.9993725484,\r\n        2920305.409303922\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nCurrently the following ```jq``` query is working for me but not in the intended format:\r\n\r\n``` shell\r\njq -r &#39;. | &quot;\\(.Defaults.Timestamps) \\(.MetricDataForAccount[].Values)&quot;&#39;\r\n```\r\n\r\n&gt; Output ```[1677801540,1677801480,1677801420] [2920126.416862745,2920285.9993725484,2920305.409303922] ```\r\n\r\nThe intended goal would be for the output to looks as follows:\r\n\r\n``` csv\r\n1677801540, 2920126.416862745\r\n1677801480, 2920285.9993725484\r\n1677801420, 2920305.409303922\r\n```\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75679431/query-values-in-two-arrays-and-merge-them-together",
        "title": "Query values in two arrays and merge them together"
    },
    {
        "tags": [
            "json",
            "object",
            "jq",
            "depth"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678326137,
                "last_edit_date": 1678326137,
                "creation_date": 1678325722,
                "answer_id": 75679682,
                "question_id": 75679671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to set all items on second level to an empty object, use:\r\n```sh\r\njq &#39;.[][] = {}&#39; some.json\r\n```\r\n```json\r\n{\r\n  &quot;a1&quot;: {\r\n    &quot;b1&quot;: {},\r\n    &quot;b2&quot;: {}\r\n  },\r\n  &quot;a2&quot;: {\r\n    &quot;b3&quot;: {},\r\n    &quot;b4&quot;: {}\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/6BPL98nYdnv)\r\n\r\nNote: `map_values` is [defined](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L33) as `def map_values(f): .[] |= f;`, so `.[][] = {}` is effectively the same as `map_values(map_values({}))`.",
                "title": "jq: select top two level of the object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678409243,
        "creation_date": 1678325517,
        "last_edit_date": 1678409243,
        "question_id": 75679671,
        "body_markdown": "I have some json data that looks like:\r\n\r\n```json\r\n{\r\n    &quot;a1&quot;: {\r\n        &quot;b1&quot;: {\r\n            &quot;c1&quot;: {...},\r\n            &quot;c2&quot;: [...]\r\n        },\r\n        &quot;b2&quot;: {\r\n            &quot;c3&quot;: {...},\r\n            &quot;c4&quot;: [...]\r\n        }\r\n    },\r\n    &quot;a2&quot;: {\r\n        &quot;b3&quot;: {\r\n            &quot;c5&quot;: {...},\r\n            &quot;c6&quot;: [...]\r\n        },\r\n        &quot;b4&quot;: {\r\n            &quot;c7&quot;: {...},\r\n            &quot;c8&quot;: [...]\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nI want to convert it to:\r\n\r\n```json\r\n{\r\n    &quot;a1&quot;: {\r\n        &quot;b1&quot;: {},\r\n        &quot;b2&quot;: {}\r\n    },\r\n    &quot;a2&quot;: {\r\n        &quot;b3&quot;: {},\r\n        &quot;b4&quot;: {}\r\n    }\r\n}\r\n```\r\n\r\nNote that `b`s are empty objects. I can get a list of `b`s as arrays:\r\n```bash\r\ncat testjq.json | jq &#39;. | map_values(keys)&#39;\r\n```\r\nBut can&#39;t figure out how to map it to objects.",
        "link": "https://stackoverflow.com/questions/75679671/jq-select-top-two-level-of-the-object",
        "title": "jq: select top two level of the object"
    },
    {
        "tags": [
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678401202,
                "creation_date": 1678401202,
                "answer_id": 75690657,
                "question_id": 75690570,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Drop the inner dot:\r\n\r\n    jq --arg v1 &quot;$VAR1&quot; --arg v2 &quot;$VAR2&quot; &#39;.[$v1][$v2]&#39; data.json",
                "title": "jq - how to use multiple env variables to get data from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678409300,
        "creation_date": 1678400271,
        "last_edit_date": 1678409300,
        "question_id": 75690570,
        "body_markdown": "So, if I have a JSON object like this in a data.json file:\r\n\r\n    {\r\n      &quot;a1&quot;: {\r\n        &quot;b1&quot;: {\r\n          &quot;key1&quot;: &quot;value1&quot;,\r\n          &quot;key2&quot;: &quot;value2&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI can do something like:\r\n\r\n    VAR1=&quot;a1&quot;\r\n    jq --arg v1 &quot;$VAR1&quot; &#39;.[$v1].&quot;b1&quot;&#39; data.json\r\n\r\nand get those key1 and key2.\r\n\r\nI want to do the same thing like above but with using two variables:\r\n\r\n    VAR1=&quot;a1&quot;\r\n    VAR2=&quot;b1&quot;\r\n\r\nAnd something like below is not working:\r\n\r\n    jq --arg v1 &quot;$VAR1&quot; --arg v2 &quot;$VAR2&quot; &#39;.[$v1].[$v2]&#39; data.json\r\n\r\n\r\nYour help will be greatly appreciated.  Thank you.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/75690570/jq-how-to-use-multiple-env-variables-to-get-data-from-json",
        "title": "jq - how to use multiple env variables to get data from JSON"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5048345,
                    "reputation": 551,
                    "user_id": 4053633,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/A2Tu3gV8.jpg?s=256",
                    "display_name": "dangarbri",
                    "link": "https://stackoverflow.com/users/4053633/dangarbri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678422538,
                "post_id": 75692242,
                "comment_id": 133533242,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20016493,
                    "reputation": 45,
                    "user_id": 14672363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/22a2a8e485c864ebe204fe43615d28df?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ayman.1302",
                    "link": "https://stackoverflow.com/users/14672363/ayman-1302"
                },
                "reply_to_user": {
                    "account_id": 5048345,
                    "reputation": 551,
                    "user_id": 4053633,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/A2Tu3gV8.jpg?s=256",
                    "display_name": "dangarbri",
                    "link": "https://stackoverflow.com/users/4053633/dangarbri"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678422813,
                "post_id": 75692242,
                "comment_id": 133533272,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678425149,
                "last_edit_date": 1678425149,
                "creation_date": 1678423979,
                "answer_id": 75692380,
                "question_id": 75692242,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `.query.compare` array to select from `.results` like this:\r\n\r\n```bash\r\n$ cat example.json | jq &#39;.results[.query.compare[]]&#39;\r\n0.54\r\n0.93\r\n```\r\n\r\nTo show the compare and results separately, we can use the syntax from above:\r\n\r\n```bash\r\n$ cat example.json | jq &#39;{compare: .query.compare, results: [.results[.query.compare[]]]}&#39;\r\n{\r\n  &quot;compare&quot;: [\r\n    &quot;10006&quot;,\r\n    &quot;10007&quot;\r\n  ],\r\n  &quot;results&quot;: [\r\n    0.54,\r\n    0.93\r\n  ]\r\n}\r\n```\r\n\r\n(I saved the json given in the question in example.json)",
                "title": "How can I use part of the JSON response to fetch certain outputs in the same JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678425149,
        "creation_date": 1678422133,
        "last_edit_date": 1678422440,
        "question_id": 75692242,
        "body_markdown": "I am trying to use JQ to parse the values from the **compare** list (.query.compare[]) and the results. Getting the results has been an issue as the key values are the same parameters as the values in the **compare** list.\r\n\r\nHow do I use the values from the compare list to perform a match that can be used to extract the values from the respective keys in the **results** section?\r\n\r\n```\r\n{\r\n  &quot;query&quot;: {\r\n    &quot;unit&quot;: &quot;km&quot;,\r\n    &quot;code&quot;: &quot;10005&quot;,\r\n    &quot;country&quot;: &quot;us&quot;,\r\n    &quot;compare&quot;: [\r\n      &quot;10006&quot;,\r\n      &quot;10007&quot;\r\n    ]\r\n  },\r\n  &quot;results&quot;: {\r\n    &quot;10006&quot;: 0.54,\r\n    &quot;10007&quot;: 0.93\r\n  }\r\n}\r\n```\r\n\r\nBased on the JSON above, I should be able to get the **compare** list values (10006, 10007) and **results** (0.54, 0.93) separately",
        "link": "https://stackoverflow.com/questions/75692242/how-can-i-use-part-of-the-json-response-to-fetch-certain-outputs-in-the-same-jso",
        "title": "How can I use part of the JSON response to fetch certain outputs in the same JSON?"
    },
    {
        "tags": [
            "json",
            "filter",
            "bigdata",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678463796,
                "post_id": 75694540,
                "comment_id": 133543183,
                "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": 1,
                "creation_date": 1678484619,
                "post_id": 75694540,
                "comment_id": 133548280,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678447359,
                "last_edit_date": 1678447359,
                "creation_date": 1678445420,
                "answer_id": 75695175,
                "question_id": 75694540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `--stream` flag parses the input by breaking it down into a stream of arrays, which can be processes before reading the entire input has ended. These arrays contain either one or two items. The first one is the current path of the parser (also represented as array of strings for field names, or numbers for array indices), and the second one if present is the scalar value at the current path. The arrays where the second item is missing can be used for backtracking on the document tree, if you want to keep track with the parser.\r\n\r\nTypically, you want to use two more functions in combination with `--stream`:\r\n\r\nOne is `truncate_stream` which simply cuts off a given number (provided as input) of items from the current path array. This enables you to process starting from a given depth, which you can use with `1` instead of iterating through the top level array using `.[]`.\r\n\r\nThe other one is `fromstream` which takes a stream of such broken-down arrays, and each time it reads a backtracking item on top level (which will occur more often if the input was truncated) it re-assembles its current buffer to a (truncated) item from the original structure.\r\n\r\nThat said, if a single item of your original input array *does* fit into your memory, you can use `fromstream(1|truncate_stream(inputs))` using `--stream` and the `-n` flag (for `inputs`), followed by your original filter (after `.[] |`) on the unstripped input array to access its items as you did before but without loading the whole document into memory:\r\n```sh\r\njq -rn --stream &#39;fromstream(1|truncate_stream(inputs)) | select(…) | … | @tsv&#39;\r\n```\r\n\r\nIf a single item is still too big for your memory, you can further optimize the reduction by processing the broken-down items as they come in, thus after `truncate_stream` but before (i.e. still inside) `fromstream`. Typically, these steps include filters using `select` on either the path item or the value item (including tests if the current input *has* a value item, see above), as well as using `truncate_stream` more often and/or with higher depth values. To this end, you could look at what the (streamed) input looks like using just `jq -cn --stream &#39;1|truncate_stream(inputs)&#39;` (preferably with a pager like `less`), and examine which of these items unnecessarily blow up your input, then identify their features, and cut them off before re-assembling the items with `fromstream`.\r\n```sh\r\njq -rn --stream &#39;fromstream(1|truncate_stream(inputs) | select(… .[0] … .[1] …)) | …&#39;\r\n```",
                "title": "jq performance for very large file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1678464743,
        "creation_date": 1678441698,
        "last_edit_date": 1678464743,
        "question_id": 75694540,
        "body_markdown": "I&#39;m trying to use jq to parse the wikidata dump, which is approximately 1.5Tb of a single JSON array (each item within the array is separated by a newline though). I have some complex filtering operations to extract the data I want, but it takes a loooooong time to process and I&#39;m wondering if there&#39;s a better way to speed it up, either if my filter below can be optimized, or if I should change the way I&#39;m running jq.\r\n\r\nFrom what I can tell I have a couple options, but I&#39;m limited by memory\r\n- strip away the outer [] and treat it like ndjson file, stream one at a time into jq (or batch them)\r\n- pass it in using the `--stream` flag, however I can&#39;t really grok how that changes the filter and it states it runs slower but saves memory\r\n\r\nGiven a single item looking like this (as an example):\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;Q60&quot;,\r\n  &quot;type&quot;: &quot;item&quot;,\r\n  &quot;aliases&quot;: {\r\n    &quot;en&quot;: [\r\n      {\r\n        &quot;language&quot;: &quot;en&quot;,\r\n        &quot;value&quot;: &quot;NYC&quot;\r\n      },\r\n      {\r\n        &quot;language&quot;: &quot;en&quot;,\r\n        &quot;value&quot;: &quot;New York&quot;\r\n      }\r\n    ],\r\n    &quot;fr&quot;: [\r\n      {\r\n        &quot;language&quot;: &quot;fr&quot;,\r\n        &quot;value&quot;: &quot;New York City&quot;\r\n      },\r\n      {\r\n        &quot;language&quot;: &quot;fr&quot;,\r\n        &quot;value&quot;: &quot;NYC&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;labels&quot;: {\r\n    &quot;en&quot;: {\r\n      &quot;language&quot;: &quot;en&quot;,\r\n      &quot;value&quot;: &quot;New York City&quot;\r\n    }\r\n  },\r\n  &quot;claims&quot;: {\r\n    &quot;P625&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;q60$f00c56de-4bac-e259-b146-254897432868&quot;,\r\n        &quot;mainsnak&quot;: {\r\n          &quot;snaktype&quot;: &quot;value&quot;,\r\n          &quot;property&quot;: &quot;P625&quot;,\r\n          &quot;datatype&quot;: &quot;globe-coordinate&quot;,\r\n          &quot;datavalue&quot;: {\r\n            &quot;value&quot;: {\r\n              &quot;latitude&quot;: 40.67,\r\n              &quot;longitude&quot;: -73.94,\r\n              &quot;altitude&quot;: null,\r\n              &quot;precision&quot;: 0.00027777777777778,\r\n              &quot;globe&quot;: &quot;http://www.wikidata.org/entity/Q2&quot;\r\n            },\r\n            &quot;type&quot;: &quot;globecoordinate&quot;\r\n          }\r\n        },\r\n        &quot;type&quot;: &quot;statement&quot;,\r\n        &quot;rank&quot;: &quot;normal&quot;,\r\n        &quot;references&quot;: [\r\n          {\r\n            &quot;hash&quot;: &quot;7eb64cf9621d34c54fd4bd040ed4b61a88c4a1a0&quot;,\r\n            &quot;snaks&quot;: {\r\n              &quot;P143&quot;: [\r\n                {\r\n                  &quot;snaktype&quot;: &quot;value&quot;,\r\n                  &quot;property&quot;: &quot;P143&quot;,\r\n                  &quot;datatype&quot;: &quot;wikibase-item&quot;,\r\n                  &quot;datavalue&quot;: {\r\n                    &quot;value&quot;: {\r\n                      &quot;entity-type&quot;: &quot;item&quot;,\r\n                      &quot;id&quot;: &quot;Q328&quot;,\r\n                      &quot;numeric-id&quot;: 328\r\n                    },\r\n                    &quot;type&quot;: &quot;wikibase-entityid&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            &quot;snaks-order&quot;: [\r\n              &quot;P143&quot;\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI&#39;m interesting in:\r\n- extracting the id as a number\r\n- only elements with type = &quot;item&quot;\r\n- only if they have an English label\r\n- also extract any English aliases\r\n- only those that don&#39;t have a claim of key &quot;P31&quot; which contains a datavalue of Q13442814\r\n- output as tsv\r\n\r\nMy current filter looks like this:\r\n\r\n`.[] | select((.type == &quot;item&quot;) and (.labels | has(&quot;en&quot;)) and (.claims.P31 // [] | map(.mainsnak.datavalue.value.id != &quot;Q13442814&quot;) | all)) | (.id|ltrimstr(&quot;Q&quot;)) as $id | .labels[&quot;en&quot;].value, (.aliases[&quot;en&quot;] // [] | map(.value))[] | [$id, .] | @tsv`\r\n\r\nWhich returns\r\n\r\n```\r\n60\\tNew York City\r\n60\\tNYC\r\n60\\tNew York\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75694540/jq-performance-for-very-large-file",
        "title": "jq performance for very large file"
    },
    {
        "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": 1678468050,
                "post_id": 75699001,
                "comment_id": 133544468,
                "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": 1678468118,
                "post_id": 75699001,
                "comment_id": 133544478,
                "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": 1678468205,
                "post_id": 75699001,
                "comment_id": 133544496,
                "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": 1678468256,
                "post_id": 75699001,
                "comment_id": 133544507,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3610036,
                    "reputation": 3771,
                    "user_id": 3187995,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/5105b098a9b76010a808089e22ea3d7c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "o.o",
                    "link": "https://stackoverflow.com/users/3187995/o-o"
                },
                "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": 1678480231,
                "post_id": 75699001,
                "comment_id": 133547274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678469807,
                "creation_date": 1678469807,
                "answer_id": 75699332,
                "question_id": 75699001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `test()` function and `if ... then ... else` statement:\r\n\r\n    &lt;file jq -r --arg w &quot;$workspace&quot; --arg e &quot;$environment&quot; --arg n &quot;$name&quot; \\\r\n          &#39;.items[] | if ((.name | test($n; &quot;i&quot;)) and (.workspace.name == $w) and (.workspace.environment.name == $e)) then .id else empty end&#39;\r\n\r\nThe insensitive search is done with the flag `&quot;i&quot;` given to `test`.",
                "title": "jq select compare case insensitive"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1678504413,
                "last_edit_date": 1678504413,
                "creation_date": 1678491016,
                "answer_id": 75701859,
                "question_id": 75699001,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To use `test/1` to check for equality ignoring case, you would have to anchor the\r\nregex string.  Assuming $name has no special regex characters:\r\n```\r\njq -r --arg w &quot;$workspace&quot; --arg e &quot;$environment&quot; --arg n &quot;$name&quot; &#39;\r\n  .items[]\r\n  | select( (.name | test(&quot;^\\($n)$&quot;; &quot;i&quot;)) and\r\n            (.workspace.name == $w) and\r\n            (.workspace.environment.name == $e)) \r\n  | .id&#39;\r\n```\r\n\r\nThe point of using `test/1` of course is that it handles typographical case outside the ASCII range, e.g.\r\n```\r\n$ jq &#39;test(&quot;Å&quot;;&quot;i&quot;)&#39; &lt;&lt;&lt; &#39;&quot;&#229;&quot;&#39;\r\ntrue\r\n```\r\n---\r\nAs pointed out by @OguzIsmail, if you wish to use `test` even if `$name` might contain regex-special characters, you could use the `\\Q...\\E` escape mechanism, as in:\r\n\r\n```\r\n$ jq &#39;test(&quot;\\\\Q.\\\\E&quot;)&#39; &lt;&lt;&lt; &#39;&quot;a&quot;&#39;\r\nfalse\r\n```",
                "title": "jq select compare case insensitive"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1678504413,
        "creation_date": 1678467614,
        "question_id": 75699001,
        "body_markdown": "I have a json file that looks like the following:\r\n\r\n```json\r\n{\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;some_id_1&quot;,\r\n            &quot;name&quot;: &quot;job_get_re_Log&quot;,\r\n            &quot;type&quot;: &quot;standard&quot;,\r\n            &quot;workspace&quot;: {\r\n                &quot;id&quot;: &quot;some_id_2&quot;,\r\n                &quot;name&quot;: &quot;Shared&quot;,\r\n                &quot;description&quot;: &quot;&quot;,\r\n                &quot;type&quot;: &quot;custom&quot;,\r\n                &quot;environment&quot;: {\r\n                    &quot;id&quot;: &quot;some_id_3&quot;,\r\n                    &quot;name&quot;: &quot;DEV&quot;\r\n                }\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nTo get the id (some_id_1), I run the following command:\r\n\r\n```bash\r\nname=&quot;job_get_re_log&quot;\r\nworkspace=&quot;Shared&quot;\r\nenvironment=&quot;DEV&quot;\r\n\r\nid=$(echo $jsonFile | jq -r &quot;.items[] | select(.name == \\&quot;$name\\&quot; and .workspace.name == \\&quot;$workspace\\&quot; and .workspace.environment.name == \\&quot;$environment\\&quot;).id&quot;)\r\n\r\necho &quot;$id&quot;\r\n```\r\n\r\nAs you can see the name variable is &quot;job_get_re_log&quot; but the name in the json is &quot;job_get_re_Log&quot; (capital L). This ends up failing and returning nothing because it&#39;s looking for an exact match.\r\n\r\nHow can I modify the select command so it compares without considering the case (case insensitive)? ",
        "link": "https://stackoverflow.com/questions/75699001/jq-select-compare-case-insensitive",
        "title": "jq select compare case insensitive"
    },
    {
        "tags": [
            "json",
            "jq",
            "racket"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678556093,
                "post_id": 75706374,
                "comment_id": 133557775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678702387,
                "post_id": 75706374,
                "comment_id": 133578195,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678702202,
                "last_edit_date": 1678702202,
                "creation_date": 1678562564,
                "answer_id": 75708960,
                "question_id": 75706374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re correct in that using `system` is pretty fragile and error-prone if the string to pass to a shell to run isn&#39;t properly sanitized. It&#39;s better to use [`subprocess`][1] to run `jq` and have a pair of pipes connected to its standard input and output. You can then write your JSON text to the input put and read the formatted data from the output end. You do have to account for large chunks of data possibly causing deadlocks because of one of the pipes filling up if you try to write it all and only then read it - using [threads][2] to do both the reading and writing asynchronously is a robust approach.\r\n\r\nAn example Racket module (Call it `jq-format.rkt`):\r\n\r\n```scheme\r\n#lang racket/base\r\n\r\n(require racket/contract racket/function racket/port json)\r\n\r\n(provide\r\n (contract-out\r\n  [jsexpr-&gt;pretty-json (-&gt; jsexpr? string?)]\r\n  [format-json (-&gt; string? string?)]\r\n  [pretty-print-jsexpr (-&gt;* (jsexpr?) (output-port?) void?)]\r\n  [pretty-print-json (-&gt;* (string?) (output-port?) void?)]))\r\n\r\n; Like jsexpr-&gt;string but nicely formatted output\r\n(define (jsexpr-&gt;pretty-json js)\r\n  (format-json (jsexpr-&gt;string js)))\r\n\r\n; Reformat JSON text into nicely formatted JSON\r\n(define (format-json json)\r\n  (call-with-output-string (curry pretty-print-json json)))\r\n\r\n; Pretty-print a jsexpr to the given port\r\n(define (pretty-print-jsexpr js [out-port (current-output-port)])\r\n  (pretty-print-json (jsexpr-&gt;string js) out-port))\r\n\r\n; Pretty print a JSON text string to the given port\r\n(define (pretty-print-json json [out-port (current-output-port)])\r\n  ; Start a jq child process to format the JSON.\r\n  (let*-values ([(jq-process jq-out jq-in jq-err)\r\n                 (subprocess #f #f &#39;stdout (find-executable-path &quot;jq&quot;) &quot;--unbuffered&quot; &quot;.&quot;)]\r\n                [(writer) ; One thread to write the JSON to jq and close the input pipe when done\r\n                 (thread (thunk\r\n                          (call-with-input-string\r\n                           json\r\n                           (lambda (json-port)\r\n                             (copy-port json-port jq-in)\r\n                             (close-output-port jq-in)))))]\r\n                [(reader) ; Thread to read the formatted JSON from jq and send it to the output port\r\n                 (thread (thunk\r\n                          (copy-port jq-out out-port)\r\n                          (close-input-port jq-out)))])\r\n    ; Wait for the threads to end and then for the jq subprocess to exit\r\n    (thread-wait writer)\r\n    (thread-wait reader)\r\n    (subprocess-wait jq-process)))\r\n```\r\n\r\nExample usage:\r\n\r\n```scheme\r\nWelcome to Racket, version 8.8 [cs].\r\n&gt; (require &quot;jq-format.rkt&quot;)\r\n&gt; (pretty-print-jsexpr &#39;(1 2 3 4))\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  4\r\n]\r\n&gt; \r\n```\r\n\r\n---\r\n\r\nNow available in improved form as part of [my `json-format` package](https://docs.racket-lang.org/json-format/index.html).\r\n\r\n\r\n  [1]: https://docs.racket-lang.org/reference/subprocess.html#%28def._%28%28quote._~23~25kernel%29._subprocess%29%29\r\n  [2]: https://docs.racket-lang.org/reference/threads.html",
                "title": "racket pretty print json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1678702202,
        "creation_date": 1678552374,
        "question_id": 75706374,
        "body_markdown": "This is what I&#39;m using to pretty-print json (calling the jq command):\r\n```racket\r\n#lang racket\r\n(require racket/string)\r\n(require racket/system)\r\n\r\n(define (pretty-print-json json_str)\r\n  ; for escaping &#39;\\&#39; and &#39;&quot;&#39; characters in bash\r\n  (define str_clean (string-replace json_str &quot;\\&quot;&quot; &quot;\\\\\\&quot;&quot;))\r\n  (system (string-append &quot;echo \\&quot;&quot; str_clean &quot;\\&quot; | jq .&quot;)))\r\n```\r\n\r\nIt&#39;s ugly and I don&#39;t think that it&#39;s secure. Do you know a better way to do it ?\r\n\r\nIdeally I would like to not have to depend on jq, I just want to be able to display a json with indentation and spaces.",
        "link": "https://stackoverflow.com/questions/75706374/racket-pretty-print-json",
        "title": "racket pretty print json"
    },
    {
        "tags": [
            "javascript",
            "jq",
            "webassembly"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7671050,
                    "reputation": 316,
                    "user_id": 5813279,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/570846843064491/picture?type=large",
                    "display_name": "Clode Morales Pampanga III",
                    "link": "https://stackoverflow.com/users/5813279/clode-morales-pampanga-iii"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678674422,
                "post_id": 75717572,
                "comment_id": 133573695,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12114329,
                    "reputation": 732,
                    "user_id": 8865030,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-wAnmH_NJHQk/AAAAAAAAAAI/AAAAAAAAAAs/KZAtq6CI-R0/s256-rj/photo.jpg",
                    "display_name": "Sergey",
                    "link": "https://stackoverflow.com/users/8865030/sergey"
                },
                "reply_to_user": {
                    "account_id": 7671050,
                    "reputation": 316,
                    "user_id": 5813279,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/570846843064491/picture?type=large",
                    "display_name": "Clode Morales Pampanga III",
                    "link": "https://stackoverflow.com/users/5813279/clode-morales-pampanga-iii"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678674771,
                "post_id": 75717572,
                "comment_id": 133573731,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1678674680,
                "last_edit_date": 1678674680,
                "creation_date": 1678674268,
                "answer_id": 75717590,
                "question_id": 75717572,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The -M command-line option suppresses the kind of extra characters you mention.  If you want complete control over the STDOUT output, consider using the -c and -j command-line options, which together suppress everything that isn&#39;t explicitly sent to STDOUT. (But see the manual for details.)",
                "title": "How to get jq output without extra characters?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678674680,
        "creation_date": 1678673834,
        "question_id": 75717572,
        "body_markdown": "When i can get result in jq with this input data\r\n```\r\nawait CLI.mount({\r\n\tname: &quot;test.json&quot;,\r\n\tdata: JSON.stringify([{some:{data: {test: &#39;data&#39;}}}, {some: {data: &quot;there&quot;}}])\r\n});\r\n\r\n```\r\nI am getting correct output but with characters not recognized by the system.\r\n\r\n```\r\nOutput of jq:\r\n\u001b[1;39m{\r\n  \u001b[0m\u001b[34;1m&quot;test&quot;\u001b[0m\u001b[1;39m: \u001b[0m\u001b[0;32m&quot;data&quot;\u001b[0m\u001b[1;39m\r\n\u001b[1;39m}\u001b[0m\r\n```\r\n\r\n\r\nHow can I get an output file without extra characters ?\r\n\r\n\r\nI looked at all the flags in the manual but did not find what would help me.",
        "link": "https://stackoverflow.com/questions/75717572/how-to-get-jq-output-without-extra-characters",
        "title": "How to get jq output without extra characters?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "openai-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678686996,
                "post_id": 75718295,
                "comment_id": 133574937,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1678698626,
                "last_edit_date": 1678698626,
                "creation_date": 1678687528,
                "answer_id": 75718486,
                "question_id": 75718295,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could ask ChapGPT :-)\r\n\r\nI believe you can get a JSON responSE by specifying the &quot;Content-Type&quot;\r\nheader as &quot;application/json&quot; in the API request.\r\n\r\nFor example, if you are using the OpenAI GPT-3 API:\r\n\r\n```\r\n\r\ncurl https://api.openai.com/v1/engines/davinci-codex/completions \\\r\n-H &quot;Content-Type: application/json&quot; \\\r\n-H &quot;Authorization: Bearer API_KEY&quot; \\\r\n-d &#39;{&quot;prompt&quot;: &quot;Hello, World!&quot;, &quot;max_tokens&quot;: 5}&#39;\r\n\r\n\r\n```",
                "title": "&quot;Invalid numeric literal&quot; using jq and openai api"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1678698626,
        "creation_date": 1678685173,
        "question_id": 75718295,
        "body_markdown": "I&#39;m quite new to programming, so forgive me if my question is silly.\r\n\r\nI&#39;m working on a bash script to translate copied text using xclip and openai.\r\nI&#39;m trying to pipe openai&#39;s response (not including the prompt).\r\n\r\nHere&#39;s the relevant part of the script:\r\n```\r\n\r\nxdotool key ctrl+a\r\nxdotool key ctrl+c\r\nexport OPENAI_API_KEY=&#39;XXXXXXXXXXXXXXXXXXXXXX&#39;    \r\ntrans=$(openai api completions.create -m text-davinci-003 -p &#39;Translate &#39;&quot;$(xclip -o -sel c)&quot;&#39; into English.&#39; | jq -r &#39;.choices[0].text&#39;)\r\n```\r\n\r\n\r\necho &quot;$trans&quot; always returns the following error: &quot;parse error: Invalid numeric literal at line 1, column 10&quot;\r\n\r\n\r\nI&#39;ve looked into jq a little, and it seems that the problem could be with the use of single versus double quotes, or that the json output from openai is causing an issue, but I&#39;m not sure how to test that.",
        "link": "https://stackoverflow.com/questions/75718295/invalid-numeric-literal-using-jq-and-openai-api",
        "title": "&quot;Invalid numeric literal&quot; using jq and openai api"
    },
    {
        "tags": [
            "bash",
            "if-statement",
            "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": 5,
                "creation_date": 1678703386,
                "post_id": 75720639,
                "comment_id": 133578516,
                "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": 2,
                "creation_date": 1678706393,
                "post_id": 75720639,
                "comment_id": 133579397,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678716505,
                "creation_date": 1678716505,
                "answer_id": 75722993,
                "question_id": 75720639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can perform the comparison in `jq` itself.\r\n\r\n    if curl ... | jq -e &#39;[.[].settings.bucket][1] == &quot;staging-opens-snap&quot;&#39;; then\r\n        echo &quot;is same&quot;\r\n    else\r\n        echo &quot;is different&quot;\r\n    fi\r\n\r\n(I&#39;m assuming the strings are for the example, but if not, you can have `jq` generate them as well without having to care about the exit status:\r\n\r\n    result=$(curl ... | \r\n              jq -r &#39;if [.[].settings.bucket][1] == &quot;staging-opens-snap&quot; \r\n                     then &quot;is same&quot;\r\n                     else &quot;is different&quot;\r\n                     end&#39;)",
                "title": "Unable to perform if equal by using a jq output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1678716505,
        "creation_date": 1678703302,
        "question_id": 75720639,
        "body_markdown": "I have an issue with my condition if by using a jq output.\r\n\r\nSo, \r\n\r\nI have a curl to find es snapshot\r\n\r\n    $get_snap=$(curl -s &quot;https://opens.endpoint.com/_snapshot&quot; | jq -e &#39;[.[].settings.bucket][1]&#39;)\r\nAnd output :\r\n\r\n    echo $get_snap \r\n    &quot;staging-opens-snap&quot;\r\n    \r\nSo, I want to perform a condition to check if $get_snap is equal to &quot;staging-opens-snap&quot; : \r\n\r\n    if [ &quot;$get_snap&quot; = &quot;staging-opens-snap&quot; ]; then\r\n        echo &quot;is same&quot;\r\n    else \r\n        echo &quot;is different&quot;\r\n    fi\r\n    is different\r\nAnd I always have the result `is different`, anyway.\r\n\r\nI tried by using `|tostring` and other stuff, but same result. My if doesn&#39;t works.\r\n\r\nI don&#39;t understand what I miss to be done. \r\n\r\nThanks for your lights :)\r\n\r\n                                                                                                                                             ",
        "link": "https://stackoverflow.com/questions/75720639/unable-to-perform-if-equal-by-using-a-jq-output",
        "title": "Unable to perform if equal by using a jq output"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "base64",
            "jq",
            "etcd"
        ],
        "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": 1678706899,
                "post_id": 75721086,
                "comment_id": 133579529,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1678707001,
                "creation_date": 1678707001,
                "answer_id": 75721293,
                "question_id": 75721086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the encoded data is a string and not binary data, you can decode it to a UTF-8 string using the `@base64d` filter. This should be available in jq 1.6.\r\n\r\n```\r\n$ ./etcdctl ... | jq &#39;.[][] | (.key, .value) |= @base64d&#39;\r\n{\r\n  &quot;key&quot;: &quot;by-dev/meta/snapshots/root-coord/partitions/440047424618365170/440047424618365171_ts440049489891819524&quot;,\r\n  &quot;create_revision&quot;: 44536,\r\n  &quot;mod_revision&quot;: 44536,\r\n  &quot;version&quot;: 1,\r\n  &quot;value&quot;: &quot;\\b���љ׍\\u0006\\u0012\\b_default\\u0018������׍\\u0006 ���љ׍\\u0006&quot;\r\n}\r\n```\r\n\r\nIt appears the value is not a UTF-8 string in your example so beware. Unfortunately, it doesn&#39;t return a byte array so it may not be very useful for these cases.\r\n\r\n[jqplay](https://jqplay.org/s/HV4PtqYSnPi)",
                "title": "ETCD export as json and decode from base64 all key/values to human readable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1718534145,
                "last_edit_date": 1718534145,
                "creation_date": 1718533288,
                "answer_id": 78628834,
                "question_id": 75721086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this one command work for me in etcd v3:\r\n\r\n```shell\r\netcdctl get &quot;&quot; --prefix -w json | jq -r &#39;\r\n  .kvs[] |\r\n  {key: (.key | @base64d), value: (.value | @base64d)}\r\n&#39;\r\n```\r\n\r\n[demo](https://jqplay.org/s/ogNDXWilU-gqBR4)",
                "title": "ETCD export as json and decode from base64 all key/values to human readable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1718534145,
        "creation_date": 1678705796,
        "last_edit_date": 1678738647,
        "question_id": 75721086,
        "body_markdown": "Is there any easy command line option to export my entire ETCD database to json file but also  decode the keys and values automatically from base64?\r\n\r\nWhat I succeeded to the moment is this(example show 1x key/value):\r\n\r\n       ./etcdctl get &quot;&quot; --prefix -w json | jq -r &quot;.[] | .[]  &quot;\r\n     {\r\n     &quot;key&quot;: &quot;YnktZGV2L21ldGEvc25hcHNob3RzL3Jvb3QtY29vcmQvcGFydGl0aW9ucy80NDAwNDc0MjQ2MTgzNjUxNzAvNDQwMDQ3NDI0NjE4MzY1MTcxX3RzNDQwMDQ5NDg5ODkxODE5NTI0&quot;,\r\n    &quot;create_revision&quot;: 44536,\r\n    &quot;mod_revision&quot;: 44536,\r\n    &quot;version&quot;: 1,\r\n    &quot;value&quot;: &quot;CPOB0OXRmdeNBhIIX2RlZmF1bHQYhIDgxN/V140GIPKB0OXRmdeNBg==&quot;\r\n    }\r\n\r\nBut I need to decode the entire database keys and values to human readable format?\r\n\r\nThanks\r\n\r\nP.S.\r\nFinal solution after @Jeff Mercado help:\r\n\r\n    1. /etcdctl get &quot;&quot; --prefix -w json | jq &#39;.[]&#39; &gt; etcd_filter.txt\r\n    2. Clear output to form array of objects [{},{} ...{}]\r\n    3. cat etcd_filter.txt | jq &#39;.[] | (.key, .value) |= @base64d&#39;\r\n\r\n [jq playground][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/rglpDglWHNB",
        "link": "https://stackoverflow.com/questions/75721086/etcd-export-as-json-and-decode-from-base64-all-key-values-to-human-readable",
        "title": "ETCD export as json and decode from base64 all key/values to human readable"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "text",
            "jq",
            "data-cleaning"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1678720612,
                "creation_date": 1678720612,
                "answer_id": 75723764,
                "question_id": 75723659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` to decompose the nested objects into `.key` and `.value`, then rearrange and update using `|=`:\r\n```sh\r\n&lt;file.json jq &#39;.models |= map(to_entries[] | {&quot;model name&quot;: .key} + .value)\r\n  | .models[].attacks |= map(to_entries[] | {&quot;attack name&quot;: .key} + .value)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Reeve Hunter&quot;,\r\n  &quot;edition&quot;: 3,\r\n  &quot;revision&quot;: &quot;2021 v1&quot;,\r\n  &quot;keywords&quot;: [\r\n    &quot;Circle&quot;,\r\n    &quot;Wolf Sworn&quot;,\r\n    &quot;Reeve of Orboros&quot;,\r\n    &quot;Solo&quot;\r\n  ],\r\n  &quot;point cost&quot;: 4,\r\n  &quot;field allowance&quot;: 2,\r\n  &quot;models&quot;: [\r\n    {\r\n      &quot;model name&quot;: &quot;Hunter&quot;,\r\n      &quot;spd&quot;: 6,\r\n      &quot;str&quot;: 6,\r\n      &quot;mat&quot;: 6,\r\n      &quot;rat&quot;: 7,\r\n      &quot;def&quot;: 13,\r\n      &quot;arm&quot;: 13,\r\n      &quot;cmd&quot;: 7,\r\n      &quot;boxes&quot;: 5,\r\n      &quot;advantages&quot;: [\r\n        &quot;Advance Deploy&quot;,\r\n        &quot;Assault&quot;,\r\n        &quot;Pathfinder&quot;\r\n      ],\r\n      &quot;base size&quot;: 30,\r\n      &quot;attacks&quot;: [\r\n        {\r\n          &quot;attack name&quot;: &quot;Double Crossbow&quot;,\r\n          &quot;type&quot;: &quot;ranged&quot;,\r\n          &quot;rng&quot;: 12,\r\n          &quot;rof&quot;: 2,\r\n          &quot;pow&quot;: 10\r\n        },\r\n        {\r\n          &quot;attack name&quot;: &quot;Battle Blade&quot;,\r\n          &quot;type&quot;: &quot;melee&quot;,\r\n          &quot;rng&quot;: 0.5,\r\n          &quot;pow&quot;: 3,\r\n          &quot;p+s&quot;: 9\r\n        },\r\n        {\r\n          &quot;attack name&quot;: &quot;Cleft Sword&quot;,\r\n          &quot;type&quot;: &quot;melee&quot;,\r\n          &quot;rng&quot;: 1,\r\n          &quot;pow&quot;: 5,\r\n          &quot;p+s&quot;: 11,\r\n          &quot;weapon qualities&quot;: [\r\n            &quot;Weapon Master&quot;\r\n          ],\r\n          &quot;abilities&quot;: [\r\n            &quot;Powerful Charge&quot;\r\n          ]\r\n        }\r\n      ],\r\n      &quot;abilities&quot;: [\r\n        &quot;Hunter&quot;,\r\n        &quot;Leadership [Reeves of Orboros]&quot;,\r\n        &quot;Quickwork&quot;,\r\n        &quot;Sprint&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/pmtNzu1sYFQ)\r\n\r\n",
                "title": "Data Cleaning Badly Designed JSON Data -- Need advice on best strategy"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1678721966,
                "last_edit_date": 1678721966,
                "creation_date": 1678721707,
                "answer_id": 75723966,
                "question_id": 75723659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have these JSON as files, then `jq` would be one of the best tools, I assume. However, if you have stored them in a MongoDB, then I would propose this update:\r\n\r\n    db.collection.updateMany(\r\n       {},\r\n       [\r\n          {\r\n             $set: {\r\n                models: {\r\n                   $map: {\r\n                      input: &quot;$models&quot;,\r\n                      in: {\r\n                         $let: {\r\n                            vars: { model: { $objectToArray: &quot;$$this&quot; } },\r\n                            in: {\r\n                               $mergeObjects: [\r\n                                  { &quot;model name&quot;: { $first: &quot;$$model.k&quot; } },\r\n                                  { $first: &quot;$$model.v&quot; }\r\n                               ]\r\n                            }\r\n                         }\r\n                      }\r\n                   }\r\n                }\r\n             }\r\n          },\r\n          {\r\n             $set: {\r\n                models: {\r\n                   $map: {\r\n                      input: &quot;$models&quot;,\r\n                      as: &quot;model&quot;,\r\n                      in: {\r\n                         $mergeObjects: [\r\n                            &quot;$$model&quot;,\r\n                            {\r\n                               attacks: {\r\n                                  $map: {\r\n                                     input: &quot;$$model.attacks&quot;,\r\n                                     in: {\r\n                                        $let: {\r\n                                           vars: { attack: { $objectToArray: &quot;$$this&quot; } },\r\n                                           in: {\r\n                                              $mergeObjects: [\r\n                                                 { &quot;attack name&quot;: { $first: &quot;$$attack.k&quot; } },\r\n                                                 { $first: &quot;$$attack.v&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             }\r\n          }\r\n       ]\r\n    )\r\n\r\n",
                "title": "Data Cleaning Badly Designed JSON Data -- Need advice on best strategy"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1678721966,
        "creation_date": 1678719991,
        "question_id": 75723659,
        "body_markdown": "I have over 1,000 JSON files representing game elements. This is a typical example:\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;Reeve Hunter&quot;,\r\n    &quot;edition&quot;: 3,\r\n    &quot;revision&quot;: &quot;2021 v1&quot;,\r\n    &quot;keywords&quot;: [\r\n        &quot;Circle&quot;,\r\n        &quot;Wolf Sworn&quot;,\r\n        &quot;Reeve of Orboros&quot;,\r\n        &quot;Solo&quot;\r\n    ],\r\n    &quot;point cost&quot;: 4,\r\n    &quot;field allowance&quot;: 2,\r\n    &quot;models&quot;: [\r\n        {\r\n            &quot;Hunter&quot;: {\r\n                &quot;spd&quot;: 6,\r\n                &quot;str&quot;: 6,\r\n                &quot;mat&quot;: 6,\r\n                &quot;rat&quot;: 7,\r\n                &quot;def&quot;: 13,\r\n                &quot;arm&quot;: 13,\r\n                &quot;cmd&quot;: 7,\r\n                &quot;boxes&quot;: 5,\r\n                &quot;advantages&quot;: [\r\n                    &quot;Advance Deploy&quot;,\r\n                    &quot;Assault&quot;,\r\n                    &quot;Pathfinder&quot;\r\n                ],\r\n                &quot;base size&quot;: 30,\r\n                &quot;attacks&quot;: [\r\n                    {\r\n                        &quot;Double Crossbow&quot;: {\r\n                            &quot;type&quot;: &quot;ranged&quot;,\r\n                            &quot;rng&quot;: 12,\r\n                            &quot;rof&quot;: 2,\r\n                            &quot;pow&quot;: 10\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;Battle Blade&quot;: {\r\n                            &quot;type&quot;: &quot;melee&quot;,\r\n                            &quot;rng&quot;: 0.5,\r\n                            &quot;pow&quot;: 3,\r\n                            &quot;p+s&quot;: 9\r\n                        }\r\n                    },\r\n                    {\r\n                        &quot;Cleft Sword&quot;: {\r\n                            &quot;type&quot;: &quot;melee&quot;,\r\n                            &quot;rng&quot;: 1,\r\n                            &quot;pow&quot;: 5,\r\n                            &quot;p+s&quot;: 11,\r\n                            &quot;weapon qualities&quot;: [&quot;Weapon Master&quot;],\r\n                            &quot;abilities&quot;: [&quot;Powerful Charge&quot;]\r\n                        }\r\n                    }\r\n                ],\r\n                &quot;abilities&quot;: [\r\n                    &quot;Hunter&quot;,\r\n                    &quot;Leadership [Reeves of Orboros]&quot;,\r\n                    &quot;Quickwork&quot;,\r\n                    &quot;Sprint&quot;\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nWhile the above is valid JSON, once I got all the JSON files into a MongoDB database I realized I couldn&#39;t analyze my data properly because every sub-document in the `models` and `attacks` arrays had a unique name as the key.\r\n\r\nI want to transform each JSON document like this:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Reeve Hunter&quot;,\r\n  &quot;edition&quot;: 3,\r\n  &quot;revision&quot;: &quot;2021 v1&quot;,\r\n  &quot;keywords&quot;: [\r\n    &quot;Circle&quot;,\r\n    &quot;Wolf Sworn&quot;,\r\n    &quot;Reeve of Orboros&quot;,\r\n    &quot;Solo&quot;\r\n  ],\r\n  &quot;point cost&quot;: 4,\r\n  &quot;field allowance&quot;: 2,\r\n  &quot;models&quot;: [\r\n    {\r\n      &quot;model name&quot;: &quot;Hunter&quot;,\r\n      &quot;spd&quot;: 6,\r\n      &quot;str&quot;: 6,\r\n      &quot;mat&quot;: 6,\r\n      &quot;rat&quot;: 7,\r\n      &quot;def&quot;: 13,\r\n      &quot;arm&quot;: 13,\r\n      &quot;cmd&quot;: 7,\r\n      &quot;boxes&quot;: 5,\r\n      &quot;advantages&quot;: [\r\n        &quot;Advance Deploy&quot;,\r\n        &quot;Assault&quot;,\r\n        &quot;Pathfinder&quot;\r\n      ],\r\n      &quot;base size&quot;: 30,\r\n      &quot;attacks&quot;: [\r\n        {\r\n          &quot;attack name&quot;: &quot;Double Crossbow&quot;,\r\n          &quot;type&quot;: &quot;ranged&quot;,\r\n          &quot;rng&quot;: 12,\r\n          &quot;rof&quot;: 2,\r\n          &quot;pow&quot;: 10\r\n        },\r\n        {\r\n          &quot;attack name&quot;: &quot;Battle Blade&quot;,\r\n          &quot;type&quot;: &quot;melee&quot;,\r\n          &quot;rng&quot;: 0.5,\r\n          &quot;pow&quot;: 3,\r\n          &quot;p+s&quot;: 9\r\n        },\r\n        {\r\n          &quot;attack name&quot;: &quot;Cleft Sword&quot;,\r\n          &quot;type&quot;: &quot;melee&quot;,\r\n          &quot;rng&quot;: 1,\r\n          &quot;pow&quot;: 5,\r\n          &quot;p+s&quot;: 11,\r\n          &quot;weapon qualities&quot;: [\r\n            &quot;Weapon Master&quot;\r\n          ],\r\n          &quot;abilities&quot;: [\r\n            &quot;Powerful Charge&quot;\r\n          ]\r\n        }\r\n      ],\r\n      &quot;abilities&quot;: [\r\n        &quot;Hunter&quot;,\r\n        &quot;Leadership [Reeves of Orboros]&quot;,\r\n        &quot;Quickwork&quot;,\r\n        &quot;Sprint&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m an old hat at using `awk` and `sed` for cleaning up text, but this transformation is complex and features enough &quot;gotchas&quot; that I feel like I need a different strategy.\r\n\r\nI&#39;ve been using the wonderful tool `jq` to manipulate and query JSON files, and I feel like there has to be a way to leverage its power to do what I need.\r\n\r\nDoes anyone have any advice on the best strategy to write a script that can transform all of my data into the cleaner format I require?",
        "link": "https://stackoverflow.com/questions/75723659/data-cleaning-badly-designed-json-data-need-advice-on-best-strategy",
        "title": "Data Cleaning Badly Designed JSON Data -- Need advice on best strategy"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonpath"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678745759,
                "creation_date": 1678745759,
                "answer_id": 75727395,
                "question_id": 75727365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By using the filters `objects` and `arrays`, you can handle different types differently, like here using `.[]` only on arrays. Then, using `-n` and `inputs` lets you access multiple input objects at once, thus collect their values into a single final array.\r\n```sh\r\njq -n &#39;[inputs.CVE | objects, arrays[] | .ID]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/Hj6gkztXGE3)",
                "title": "How do I parse a single record or an array of records in a json field using JsonPath"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678746227,
                "creation_date": 1678746227,
                "answer_id": 75727442,
                "question_id": 75727365,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use a recursive descent `..`:\r\n\r\n```jsonpath\r\n$.CVE..ID\r\n```\r\n\r\nNote, however, that if your objects contain nested `ID` properties, this will pick up those as well.\r\n\r\nTry it out at https://json-everything.net/json-path",
                "title": "How do I parse a single record or an array of records in a json field using JsonPath"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678746227,
        "creation_date": 1678745491,
        "question_id": 75727365,
        "body_markdown": "I have a json value that can contain a single record or an array, I need to extract the ID field of these records and gather them in an array. The resulting element should be an array with 1 or more ID values. \r\n\r\nInput 1  Single record\r\n\r\n    {\r\n      &quot;CVE&quot;: {\r\n        &quot;ID&quot;: &quot;CVE-2022-26138&quot;,&quot;URL&quot;: &quot;foo.bar&quot; }\r\n    }\r\n    \r\nInput 2  An array of two records\r\n\r\n    {\r\n      &quot;CVE&quot;: [\r\n         { &quot;ID&quot;: &quot;CVE-2019-2969&quot;,&quot;URL&quot;: &quot;foo.com&quot; },\r\n         { &quot;ID&quot;: &quot;CVE-2019-3030&quot;,&quot;URL&quot;: &quot;bar.com&quot; }\r\n      ]\r\n    }\r\n\r\nI tried the JSONPath expression `$.CVE.ID` which results in `[&quot;CVE-2022-26138&quot;]` for Input 1 but returns empty array on the Input 2. \r\n\r\nThen I tried the JSONPath expression `$.CVE.*.ID` which results in empty array [] for Input 1 but gives me correct output for Input 2 `[&quot;CVE-2019-2969&quot;, &quot;CVE-2019-3030&quot;]`\r\n\r\n\r\nMy question is, is there a single JSONPath expression I can use that gives me non-empty result in either input?",
        "link": "https://stackoverflow.com/questions/75727365/how-do-i-parse-a-single-record-or-an-array-of-records-in-a-json-field-using-json",
        "title": "How do I parse a single record or an array of records in a json field using JsonPath"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678779612,
                "last_edit_date": 1678779612,
                "creation_date": 1678778399,
                "answer_id": 75730079,
                "question_id": 75730078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution was to apply this filter:\r\n\r\n```bash\r\njq &#39;.mylist = (.mylist[:N])&#39;\r\n```\r\n\r\nThis filter:\r\n- creates a copy of `mylist` from the input, taking the first `N` elements\r\n- assigns this to the `mylist` field in the input\r\n- outputs the result",
                "title": "jq: output structure, shortening array, preserving the other fields in the input"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678778656,
                "creation_date": 1678778656,
                "answer_id": 75730108,
                "question_id": 75730078,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of re-creating the whole object again, you could just update `|=` that one field:\r\n```sh\r\njq &#39;.mylist |= .[:N]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/c68B44YbJ4V)",
                "title": "jq: output structure, shortening array, preserving the other fields in the input"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678779612,
        "creation_date": 1678778399,
        "question_id": 75730078,
        "body_markdown": "For a JSON file like this:\r\n\r\n```json\r\n{\r\n  &quot;mylist&quot;: [...],\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nwith `mylist` containing many elements, how can I output the same JSON structure, but with only the first N elements in `mylist`?\r\n\r\nI was trying to use `jq &#39;.mylist[:N]&#39;`, but this prints the first N elements of `mylist` without the other fields such as `foo`.",
        "link": "https://stackoverflow.com/questions/75730078/jq-output-structure-shortening-array-preserving-the-other-fields-in-the-input",
        "title": "jq: output structure, shortening array, preserving the other fields in the input"
    },
    {
        "tags": [
            "json",
            "substring",
            "jq",
            "case-insensitive"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1678793273,
                "creation_date": 1678793273,
                "answer_id": 75732528,
                "question_id": 75732475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `inside` (the reverse operation to `contains`) on strings with unified case (e.g. `ascii_downcase`). `any` will evaluate to `true` if at least one item matches.\r\n\r\n```sh\r\njq --arg x &#39;ThiS.FIle.is.HeRe&#39; &#39;any(.[] | ascii_downcase; inside($x | ascii_downcase))&#39;\r\n```\r\n```json\r\ntrue\r\n```",
                "title": "Reverse substring match in jq array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1678815530,
        "creation_date": 1678792947,
        "last_edit_date": 1678815530,
        "question_id": 75732475,
        "body_markdown": "Let&#39;s say I have an array from file `/some/file.json`:\r\n```\r\n[\r\n    &quot;This.FilE&quot;,\r\n    &quot;That.file&quot;,\r\n    &quot;Another.FIle&quot;\r\n]\r\n```\r\n\r\nThen I have a string `x` with value `ThiS.FIle.is.HeRe`, now I wanted to know whether any of the string in the array matched the substring in `x`, case-insensitive (`true`/`false` result). Is there any clever way to do this with `jq` one-liner?",
        "link": "https://stackoverflow.com/questions/75732475/reverse-substring-match-in-jq-array",
        "title": "Reverse substring match in jq array"
    },
    {
        "tags": [
            "json",
            "google-cloud-platform",
            "jq",
            "nested-json"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678878461,
                "post_id": 75740548,
                "comment_id": 133617288,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678857227,
                "creation_date": 1678857227,
                "answer_id": 75740780,
                "question_id": 75740548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on your basic description of the problem, it looks like this would suffice:\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;defaultLimit&quot;) \r\n     then select(.defaultLimit != .effectiveLimit) else . end)\r\n```\r\nHowever, based on your example, you might want to extend the pipeline by adding:\r\n```\r\n| walk(if type == &quot;object&quot; then select(.quota != []) else . end)\r\n```\r\n",
                "title": "Conditional parsing of Nested Jsons with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1678865887,
                "creation_date": 1678865887,
                "answer_id": 75741714,
                "question_id": 75740548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could first select all quotas with a non-default limit and then drop any metric without remaining quotas/keep only metrics with at least one quota:\r\n\r\n```\r\nmap(.quota |= map(select(.defaultLimit != .effectiveLimit)) | select(.quota | length &gt; 0))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n    &quot;quota&quot;: [\r\n      {\r\n        &quot;defaultLimit&quot;: &quot;12&quot;,\r\n        &quot;dimensions&quot;: {\r\n          &quot;region&quot;: &quot;asia-east1&quot;\r\n        },\r\n        &quot;effectiveLimit&quot;: &quot;13&quot;,\r\n        &quot;producerOverride&quot;: {\r\n          &quot;dimensions&quot;: {\r\n            &quot;region&quot;: &quot;asia-east1&quot;\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nTo keep only the limits and dimensions (dropping producerOverride and any other additional properties):\r\n\r\n```\r\nmap(.quota |= map(select(.defaultLimit != .effectiveLimit) | {defaultLimit, effectiveLimit, dimensions}) | select(.quota | length &gt; 0))\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n    &quot;quota&quot;: [\r\n      {\r\n        &quot;defaultLimit&quot;: &quot;12&quot;,\r\n        &quot;effectiveLimit&quot;: &quot;13&quot;,\r\n        &quot;dimensions&quot;: {\r\n          &quot;region&quot;: &quot;asia-east1&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "Conditional parsing of Nested Jsons with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678868154,
                "creation_date": 1678868154,
                "answer_id": 75742039,
                "question_id": 75740548,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A possible solution:\r\n\r\n```jq\r\nmap(\r\n  .quota |=\r\n    map(\r\n      select(.defaultLimit != .effectiveLimit)\r\n      | del(.producerOverride)\r\n    )\r\n  | select(.quota | length &gt; 0)\r\n)\r\n```\r\n\r\n### How it works\r\n\r\n* `map(...)` - because the input is an array, `map(...)` applies the expression passed as argument to each item of the array and yields a new array that contains the results of the expression applied to each argument; all subsequent steps described below operate on one object (each item of the array).\r\n* `.quota |= map(...)` - the value of property `.quota` (which is an array) is passed to `map()` (which yields a new array) and the resulting array is stored back in `.quota`; this is the same thing as `.quota = (.quota | map(...))` but it&#39;s shorter and easier to read.\r\n* `map(select(...) | del(...))` - for each item of the `.quota` array run `select(.defaultLimit != .effectiveLimit)` then remove (`del`) the property `.producerOverride` from the returned object (if it exists). The result is an array that contains only the quota entries that non-default values.\r\n* `select(.defaultLimit != .effectiveLimit)` - if the condition is met then this yields the input object, otherwise it does not yield anything. This is how the quota items that have non-default values are filtered.\r\n* `del(.producerOverride`) - this filter is here because the property `.producerOverride` is not displayed in your expected output. If the input object may contain other properties, not listed here, and you want to keep only a known set of properties in the output then use this filter instead:\r\n   ```jq\r\n   | { defaultLimit, dimensions, effectiveLimit }\r\n   ```\r\n  But be aware that this one produces objects that always have these three properties, even when not all of them are in the input (`dimensions` is not present in all `quota` items in the input). In this case, the value of those properties is `null`.\r\n* `| select(.quota | length &gt; 0)` - this filter gets at input the objects of the input array after their `.quota` property is processed as described above. It keeps from its input only the objects that have non-empty `.quota` property. The previous filters produce from the first input item an item that looks like this:\r\n   ```jq\r\n   {\r\n     &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n     &quot;quota&quot;: []\r\n   }\r\n   ```\r\n   This filter removes such items.\r\n\r\n### `jq` documentation\r\n\r\nRead the [`jq` tutorial](https://stedolan.github.io/jq/tutorial/) and the [`jq` manual](https://stedolan.github.io/jq/manual/) for more information.",
                "title": "Conditional parsing of Nested Jsons with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1678868154,
        "creation_date": 1678854392,
        "last_edit_date": 1678867933,
        "question_id": 75740548,
        "body_markdown": "Need help parsing the below nested Json. The end goal is to get the `quota limits` from GCP that have non-default values. Below is the sample data for one of the services (compute APIs for a given CPU type)\r\n\r\nI am struggling to be able to compare \r\nI came up with the below but it doesn&#39;t work and returns an error \r\n`.[]|select (.quota[].defaultLimit|tonumber != .quota[].effectiveLimit|tonumber)`\r\n\r\n```\r\n[\r\n  {\r\n    &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n    &quot;quota&quot;: [\r\n      {\r\n        &quot;defaultLimit&quot;: &quot;-1&quot;,\r\n        &quot;effectiveLimit&quot;: &quot;-1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n    &quot;quota&quot;: [\r\n      {\r\n        &quot;defaultLimit&quot;: &quot;12&quot;,\r\n        &quot;effectiveLimit&quot;: &quot;12&quot;\r\n      },\r\n      {\r\n        &quot;defaultLimit&quot;: &quot;12&quot;,\r\n        &quot;dimensions&quot;: {\r\n          &quot;region&quot;: &quot;asia-east1&quot;\r\n        },\r\n        &quot;effectiveLimit&quot;: &quot;13&quot;,\r\n        &quot;producerOverride&quot;: {\r\n          &quot;dimensions&quot;: {\r\n            &quot;region&quot;: &quot;asia-east1&quot;\r\n          }\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nthe expected output would be something like this\r\n\r\n```\r\n[\r\n  {\r\n    &quot;metric&quot;: &quot;compute.googleapis.com/a2_cpus&quot;,\r\n    &quot;quota&quot;: [    \r\n      {\r\n        &quot;defaultLimit&quot;: &quot;12&quot;,\r\n        &quot;dimensions&quot;: {\r\n          &quot;region&quot;: &quot;asia-east1&quot;\r\n        },\r\n        &quot;effectiveLimit&quot;: &quot;13&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nAny help is appreciated. ",
        "link": "https://stackoverflow.com/questions/75740548/conditional-parsing-of-nested-jsons-with-jq",
        "title": "Conditional parsing of Nested Jsons with jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1678883693,
                "creation_date": 1678883693,
                "answer_id": 75744772,
                "question_id": 75744676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are checking if `.Name` contains the literal string `$e`; the variable does not need to be quoted.\r\n\r\n    ... select(.Name|contains($e)) | ...",
                "title": "Bash script using jq: --arg value not utilized with script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679057467,
        "creation_date": 1678883217,
        "last_edit_date": 1679057467,
        "question_id": 75744676,
        "body_markdown": "I have a bash script where a parameter is passed in which I am trying to use in a subsequent jq query, but I cannot get it to work. The command works when using manual inputs in cli, but not when passing the parameter to a script. Any suggestions on where I&#39;m going wrong would be greatly appreciated! \r\n\r\n````\r\n#!/bin/bash\r\nACCOUNT=123456789\r\nENTITY=$1\r\nDASHBOARDS=$(aws quicksight list-dashboards --aws-account-id ${ACCOUNT} | jq -r --arg e &quot;$ENTITY&quot; &#39;.DashboardSummaryList[] | select(.Name|contains(&quot;$e&quot;)) | .DashboardId&#39;)\r\n````\r\n\r\n\r\nAnother problem I ran into is that select contains is case sensitive. To solve it I first made sure the parameter is translated into full lowercase to be caught in a if statement. This statement handles full uppercase exceptions (such as &quot;UK&quot;), or returns a default value of first character being uppercase and the rest lowercase\r\n\r\n````\r\nENTITY=$(echo &quot;$1&quot; | tr &#39;[A-Z]&#39; &#39;[a-z]&#39;)  #Set parameter all lowercase\r\n\r\nif [ &quot;$ENTITY&quot; = &quot;uk&quot; ] || [ &quot;$ENTITY&quot; = &quot;exception2&quot; ]; then\r\n  ENTITY=$(echo ${ENTITY^^}) #All uppercase\r\nelse\r\n  ENTITY=$(echo ${ENTITY^}) #First char uppercase\r\nfi\r\n````",
        "link": "https://stackoverflow.com/questions/75744676/bash-script-using-jq-arg-value-not-utilized-with-script",
        "title": "Bash script using jq: --arg value not utilized with script"
    },
    {
        "tags": [
            "bash",
            "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": 2,
                "creation_date": 1678955585,
                "post_id": 75753671,
                "comment_id": 133633941,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5508017,
                    "reputation": 6494,
                    "user_id": 4375327,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/Td5kp.png?s=256",
                    "display_name": "Amessihel",
                    "link": "https://stackoverflow.com/users/4375327/amessihel"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678955836,
                "post_id": 75753671,
                "comment_id": 133634000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14723908,
                    "reputation": 1574,
                    "user_id": 10633596,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9959f2f3bd7b43968dedd19f46a165fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vinod827",
                    "link": "https://stackoverflow.com/users/10633596/vinod827"
                },
                "reply_to_user": {
                    "account_id": 5508017,
                    "reputation": 6494,
                    "user_id": 4375327,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/Td5kp.png?s=256",
                    "display_name": "Amessihel",
                    "link": "https://stackoverflow.com/users/4375327/amessihel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678956002,
                "post_id": 75753671,
                "comment_id": 133634051,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678956160,
                "post_id": 75753671,
                "comment_id": 133634097,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14723908,
                    "reputation": 1574,
                    "user_id": 10633596,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9959f2f3bd7b43968dedd19f46a165fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vinod827",
                    "link": "https://stackoverflow.com/users/10633596/vinod827"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678956422,
                "post_id": 75753671,
                "comment_id": 133634167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14723908,
                    "reputation": 1574,
                    "user_id": 10633596,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9959f2f3bd7b43968dedd19f46a165fa?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "vinod827",
                    "link": "https://stackoverflow.com/users/10633596/vinod827"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678956502,
                "post_id": 75753671,
                "comment_id": 133634181,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5508017,
                    "reputation": 6494,
                    "user_id": 4375327,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://i.sstatic.net/Td5kp.png?s=256",
                    "display_name": "Amessihel",
                    "link": "https://stackoverflow.com/users/4375327/amessihel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678958226,
                "post_id": 75753671,
                "comment_id": 133634635,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1678956590,
                "creation_date": 1678956590,
                "answer_id": 75753836,
                "question_id": 75753671,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want `$jobs_to_copy` to be substituted with the variable value, don&#39;t use single quotes but rather double quotes.\r\n\r\nIn your case, that&#39;d look like this:\r\n```bash\r\nJOBS=$(cat jobs.json | jq &#39;.[] | select(([.name] | inside(&#39;&quot;$jobs_to_copy&quot;&#39;)) and .artifacts_file != null) | .id&#39;)\r\n```\r\nThis first closes the literal, then substitutes in the variable value (in double quotes to prevent having it break out of that area), and finally, starts the literal again",
                "title": "Unable to resolve an array in bash using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678956590,
        "creation_date": 1678955379,
        "question_id": 75753671,
        "body_markdown": "I&#39;m trying to put an array in the `inside()` function. If I hard code like this `inside([&quot;test, coverage&quot;])` then my code works fine. However if I try to put it dynamically using variable called jobs_to_copy then it throws error. If you see the echo statement (`echo $jobs_to_copy`), it does print in this required format [&quot;test&quot;,&quot;coverage&quot;] but not sure why this error is still coming then.\r\n\r\nThis is my Bash shell script:-\r\n\r\n    #!/bin/sh\r\n    \r\n    CI_JOBS=&quot;test, coverage&quot;\r\n    \r\n    jobs_to_copy=$(echo $CI_JOBS | sed &#39;s/, /,/g&#39; | jq -Rc &#39;split(&quot;,&quot;)&#39;)\r\n    echo $jobs_to_copy\r\n    \r\n    JOBS=$(cat jobs.json | jq &#39;.[] | select(([.name] | inside($jobs_to_copy)) and .artifacts_file != null) | .id&#39;)\r\n    echo $JOBS\r\n\r\n\r\n\r\n**Error:-**\r\n\r\n    [&quot;test&quot;,&quot;coverage&quot;]\r\n    jq: error: jobs_to_copy/0 is not defined at &lt;top-level&gt;, line 1:\r\n    .[] | select(([.name] | inside($jobs_to_copy)) and .artifacts_file != null) | .id                               \r\n    jq: 1 compile error\r\n\r\n\r\nI had debugged a lot but I&#39;m really stuck on this and never thought it is going to be so tricky.\r\nKindly let me know its fix\r\n",
        "link": "https://stackoverflow.com/questions/75753671/unable-to-resolve-an-array-in-bash-using-jq",
        "title": "Unable to resolve an array in bash using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678977316,
                "post_id": 75757712,
                "comment_id": 133640547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678977342,
                "post_id": 75757712,
                "comment_id": 133640553,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1678977609,
                "post_id": 75757712,
                "comment_id": 133640658,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 219211,
                    "reputation": 3163,
                    "user_id": 475982,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/4e40d2b9e1a762949a25b958762aa10d?s=256&d=identicon&r=PG",
                    "display_name": "mac389",
                    "link": "https://stackoverflow.com/users/475982/mac389"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678977615,
                "post_id": 75757712,
                "comment_id": 133640664,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 219211,
                    "reputation": 3163,
                    "user_id": 475982,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://www.gravatar.com/avatar/4e40d2b9e1a762949a25b958762aa10d?s=256&d=identicon&r=PG",
                    "display_name": "mac389",
                    "link": "https://stackoverflow.com/users/475982/mac389"
                },
                "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": 1678977643,
                "post_id": 75757712,
                "comment_id": 133640676,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1678980548,
                "post_id": 75757712,
                "comment_id": 133641684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1678980769,
                "post_id": 75757712,
                "comment_id": 133641750,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1678980959,
                "last_edit_date": 1678980959,
                "creation_date": 1678980492,
                "answer_id": 75758316,
                "question_id": 75757712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you say you\r\n\r\n&gt; can load each file with jq by typing jq &#39;.&#39; FILENAME\r\n\r\nyou could use the anti-pattern:\r\n\r\n    jq . $(find ……)\r\n\r\nHowever you would have to be a bit more ingenious to handle more tricky filenames. See e.g. solutions proposed in comments by @CharlesDuffy, https://stackoverflow.com/questions/34983843/how-do-i-store-the-output-from-a-find-command-in-an-array-bash, etc etc.",
                "title": "How do I pass a list of filenames from find to jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1678982270,
                "last_edit_date": 1678982270,
                "creation_date": 1678981827,
                "answer_id": 75758560,
                "question_id": 75757712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let `find` do it, instead of having the shell stick its nose in the middle.\r\n\r\n    find . -name &#39;reddit.*.flattened.json&#39; -exec jq &#39;.&#39; {} \\;\r\n\r\nThis avoids issues with names that contain any whitespace (and especially names that contain newline characters) or glob metacharacters.\r\n\r\n(For most filters and combinations of arguments, you can safely reduce the number of times `jq` is called by letting it read from multiple files per invocation with\r\n\r\n    find ... -exec jq &#39;.&#39; {} +\r\n)",
                "title": "How do I pass a list of filenames from find to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1678982270,
        "creation_date": 1678977244,
        "question_id": 75757712,
        "body_markdown": "The command `find . -name &#39;reddit.*.flattened.json&#39; | jq &#39;.&#39;` gives the error `parse error: Invalid numeric literal at line 2, column 0`. \r\n\r\nMotivated by [this question][1], I tried `jq --arg`. \r\n\r\nBut, `find . -name &#39;reddit.*.flattened.json&#39; | jq --arg filename $1 &#39;. $filename&#39;` gives the same error. \r\n\r\nOutput of `find` query:\r\n    \r\n    ./reddit.opiates.flattened.json\r\n    ./reddit.OurOverUsedVeins.flattened.json\r\n    ./reddit.microdosing.flattened.json\r\n    ./reddit.naloxone.flattened.json\r\n    ./reddit.suboxone.flattened.json\r\n    ./reddit.heroin.flattened.json\r\n    ./reddit.OpiatesRecovery.flattened.json\r\n    ./reddit.fentanyl.flattened.json\r\n\r\nI can load each file with `jq` by typing `jq &#39;.&#39; FILENAME` so there is no error in the files. \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/52959216/passing-bash-shell-variable-to-jq-filter",
        "link": "https://stackoverflow.com/questions/75757712/how-do-i-pass-a-list-of-filenames-from-find-to-jq",
        "title": "How do I pass a list of filenames from find to jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "distinct-values"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678992227,
                "creation_date": 1678992227,
                "answer_id": 75760453,
                "question_id": 75760433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`unique_by` lets you obtain higher-level items (the objects in this case) staisfying a lower-level condition (uniqueness in this case). But you only want the unique array itself, so `unique` already does the job:\r\n```sh\r\njq &#39;.Items | map(.LOCATION.NAME) | unique&#39;\r\n```\r\n```json\r\n[\r\n  &quot;Dallas&quot;,\r\n  &quot;New York&quot;\r\n]\r\n```",
                "title": "How to flatten array of objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1678995472,
        "creation_date": 1678992130,
        "last_edit_date": 1678995472,
        "question_id": 75760433,
        "body_markdown": "I have an array of objects in a json file:\r\n\r\n```json\r\n{\r\n  &quot;Items&quot;: [\r\n    {\r\n      &quot;LOCATION&quot;: {\r\n        &quot;NAME&quot;: &quot;Dallas&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;LOCATION&quot;: {\r\n        &quot;NAME&quot;: &quot;New York&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;LOCATION&quot;: {\r\n        &quot;NAME&quot;: &quot;Dallas&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to to iterate over the objects and get a **unique list** of names. \r\n\r\n**In this example, the desired output** would be `[&quot;Dallas&quot;, &quot;New York&quot;]` \r\n\r\nHow do I do this? I have tried the following but it fails:\r\n\r\n```sh\r\njq &#39;.Items | map({LOCATION}) | .unique_by(.NAME)&#39; file.json\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75760433/how-to-flatten-array-of-objects-in-jq",
        "title": "How to flatten array of objects in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1678997650,
                "last_edit_date": 1678997650,
                "creation_date": 1678996932,
                "answer_id": 75761155,
                "question_id": 75761115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your attempt has only two issues: First, you need [`select`](https://stedolan.github.io/jq/manual/#select%28boolean_expression%29) to filter out certain items. Second, there are two (confusingly named) functions: The one called [`in`](https://stedolan.github.io/jq/manual/#in) tests for the existence of keys in objects, the other one called [`IN`](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) searches for occurrence in a stream or array. You need the latter.\r\n```sh\r\n.[0] as $tn | .[1][] | select(.name | IN($tn[])) | .found = true\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;test1&quot;,\r\n  &quot;data&quot;: &quot;four&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n{\r\n  &quot;name&quot;: &quot;test2&quot;,\r\n  &quot;data&quot;: &quot;three&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n{\r\n  &quot;name&quot;: &quot;test3&quot;,\r\n  &quot;data&quot;: &quot;six&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/RyZrXcof-Ke)\r\n\r\nIf, however, you wanted to retain the original structure, you need to retain the top-level context until the end of your filter, while manipulating parts of it using updates `|=` as in:\r\n```sh\r\n.[0] as $tn | (.[1][] | select(.name | IN($tn[]))).found = true\r\n```\r\n```json\r\n[\r\n  [\r\n    &quot;test1&quot;,\r\n    &quot;test2&quot;,\r\n    &quot;test3&quot;\r\n  ],\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;test5&quot;,\r\n      &quot;data&quot;: &quot;five&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;,\r\n      &quot;data&quot;: &quot;four&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;data&quot;: &quot;three&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test3&quot;,\r\n      &quot;data&quot;: &quot;six&quot;,\r\n      &quot;found&quot;: true\r\n    }\r\n  ]\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/0BlQiBKSjk5)\r\n\r\nAnd to set the boolean flag on all items, just assign, don&#39;t select:\r\n```sh\r\n.[0] as $tn | .[1][] |= (.found = (.name | IN($tn[])))\r\n```\r\n```json\r\n[\r\n  [\r\n    &quot;test1&quot;,\r\n    &quot;test2&quot;,\r\n    &quot;test3&quot;\r\n  ],\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;test5&quot;,\r\n      &quot;data&quot;: &quot;five&quot;,\r\n      &quot;found&quot;: false\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;,\r\n      &quot;data&quot;: &quot;four&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;data&quot;: &quot;three&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test3&quot;,\r\n      &quot;data&quot;: &quot;six&quot;,\r\n      &quot;found&quot;: true\r\n    }\r\n  ]\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/NeqCUFX7hli)",
                "title": "Edit objects in json array based on strings in another array with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1678997466,
                "last_edit_date": 1678997466,
                "creation_date": 1678997088,
                "answer_id": 75761180,
                "question_id": 75761115,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Close enough. Use `IN` to check for items in a stream and then assign the new property:\r\n\r\n```\r\nfirst as $names\r\n| .[1][] | select(.name|IN($names[]))\r\n| .found = true\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;test1&quot;,\r\n  &quot;data&quot;: &quot;four&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n{\r\n  &quot;name&quot;: &quot;test2&quot;,\r\n  &quot;data&quot;: &quot;three&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n{\r\n  &quot;name&quot;: &quot;test3&quot;,\r\n  &quot;data&quot;: &quot;six&quot;,\r\n  &quot;found&quot;: true\r\n}\r\n```\r\n\r\nIf you want to keep the input structure and only add `found` to the matching elements in the nested array, use parentheses:\r\n\r\n```\r\nfirst as $names\r\n| (.[1][] | select(.name|IN($names[]))).found = true\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  [\r\n    &quot;test1&quot;,\r\n    &quot;test2&quot;,\r\n    &quot;test3&quot;\r\n  ],\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;test5&quot;,\r\n      &quot;data&quot;: &quot;five&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test1&quot;,\r\n      &quot;data&quot;: &quot;four&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;data&quot;: &quot;three&quot;,\r\n      &quot;found&quot;: true\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test3&quot;,\r\n      &quot;data&quot;: &quot;six&quot;,\r\n      &quot;found&quot;: true\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nAnd finally to transform and extract only the second array (as array):\r\n\r\n```\r\nfirst as $names\r\n| (.[1] | map(select(.name|IN($names[])).found = true))\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;test5&quot;,\r\n    &quot;data&quot;: &quot;five&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test1&quot;,\r\n    &quot;data&quot;: &quot;four&quot;,\r\n    &quot;found&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test2&quot;,\r\n    &quot;data&quot;: &quot;three&quot;,\r\n    &quot;found&quot;: true\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;test3&quot;,\r\n    &quot;data&quot;: &quot;six&quot;,\r\n    &quot;found&quot;: true\r\n  }\r\n]\r\n```\r\n\r\nTo keep only the matching elements (note the `|` before assignment of `.found`):\r\n\r\n```\r\nfirst as $names\r\n| (.[1] | map(select(.name|IN($names[])) | .found = true))\r\n```",
                "title": "Edit objects in json array based on strings in another array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1678997650,
        "creation_date": 1678996698,
        "question_id": 75761115,
        "body_markdown": "For some reason I just can&#39;t wrap my head around jq. I&#39;ve been going around in circles for hours trying to accomplish what I think is not too difficult a task. \r\nWith json consisting of two arrays as input, I want to search for objects in the second array whereby the `name` field value is an element of the first array, and then add a field, say `&quot;found&quot;: true`, to those objects. \r\n```\r\n[\r\n    [\r\n        &quot;test1&quot;,\r\n        &quot;test2&quot;,\r\n        &quot;test3&quot;\r\n    ],\r\n    [\r\n        {\r\n            &quot;name&quot;: &quot;test5&quot;,\r\n            &quot;data&quot;: &quot;five&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;test1&quot;,\r\n            &quot;data&quot;: &quot;four&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;test2&quot;,\r\n            &quot;data&quot;: &quot;three&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;test3&quot;,\r\n            &quot;data&quot;: &quot;six&quot;\r\n        }\r\n    ]\r\n]\r\n```\r\n\r\nMy best guess so far starts with...\r\n`.[0] as $tn | (.[1] | .[] | .name | in($tn[]))`\r\nbut that is not getting me close to where i want to go. ",
        "link": "https://stackoverflow.com/questions/75761115/edit-objects-in-json-array-based-on-strings-in-another-array-with-jq",
        "title": "Edit objects in json array based on strings in another array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679070566,
                "creation_date": 1679070566,
                "answer_id": 75770006,
                "question_id": 75769972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not directly, but you can descend to that level, and use `has` for the last one:\r\n```sh\r\njq &#39;(.a | has(&quot;b&quot;))&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;:{&quot;b&quot;:&quot;hello&quot;}}&#39;\r\n```\r\n\r\nAlternatively, search the `paths` for the one you are looking for, converted to array notation:\r\n```sh\r\njq &#39;IN(paths; [&quot;a&quot;,&quot;b&quot;])&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;:{&quot;b&quot;:&quot;hello&quot;}}&#39;\r\n```\r\n",
                "title": "Possible to use has() with nested keys?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679082571,
                "creation_date": 1679082571,
                "answer_id": 75771665,
                "question_id": 75769972,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since computing `paths` can be quite time-consuming, it’s worth knowing that if you simply want to know whether .a.b is defined and non-null, you could use `getpath/1`, either by itself or wrapped in an `if`, e.g.\r\n\r\n    getpath([&quot;a&quot;,&quot;b&quot;]) | if . == null then false else true end",
                "title": "Possible to use has() with nested keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 5,
        "last_activity_date": 1747303669,
        "creation_date": 1679070337,
        "last_edit_date": 1747303669,
        "question_id": 75769972,
        "body_markdown": "Is it possible to use the jq has() function with nested keys?\r\n```lang-bash\r\njq -r -c &#39;has(&quot;a.b&quot;)&#39; &lt;&lt;&lt; &#39;{&quot;a&quot;:{&quot;b&quot;:&quot;hello&quot;}}&#39;\r\n```\r\nthis returns `false`, I have also tried\r\n```lang-bash\r\nhas(&quot;a|b&quot;)\r\nhas(&quot;a[b]&quot;)\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/75769972/possible-to-use-has-with-nested-keys",
        "title": "Possible to use has() with nested keys?"
    },
    {
        "tags": [
            "json",
            "string",
            "replace",
            "conditional-statements",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679072975,
                "creation_date": 1679072975,
                "answer_id": 75770358,
                "question_id": 75770289,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Traverse to the desired locations using `select` to filter (I added `// empty` to ignore fields producing `null`), then update `|=` to your desired value using `sub` for a regex substitution.\r\n```sh\r\njq --arg name bob --arg prefix newprefix &#39;\r\n  (.people[] | select(.name == $name).clients[]\r\n  | select(.instance != &quot;0&quot;) | (.stringA, .stringB) // empty)\r\n  |= sub(&quot;^.*/&quot;; $prefix + &quot;/&quot;)\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/M8CzBLqp34S)\r\n",
                "title": "jq: modify string values based on values of keys in parents"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679088032,
                "creation_date": 1679088032,
                "answer_id": 75772323,
                "question_id": 75770289,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following has the advantage of being portable, e.g. it works with jaq as well as jq:\r\n```\r\n.people |= map(\r\n   if .name == $name\r\n   then .clients |= map(\r\n      if .instance != &quot;0&quot;\r\n      then if .stringA then .stringA |= sub(&quot;prefix[^/]*&quot;; $prefix) else . end\r\n      | if .stringB then .stringB |= sub(&quot;prefix[^/]*&quot;; $prefix) else . end\r\n      else . end)\r\n   else . end) \r\n```",
                "title": "jq: modify string values based on values of keys in parents"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1679175350,
        "creation_date": 1679072459,
        "last_edit_date": 1679175350,
        "question_id": 75770289,
        "body_markdown": "I have a JSON structure like this:\r\n\r\n\r\n```\r\n{\r\n    &quot;misc&quot;: {\r\n        &quot;color&quot;: &quot;blue&quot;,\r\n        &quot;id&quot;: &quot;yyyy-12345&quot;,\r\n        &quot;birthdate&quot;: &quot;2020-12-25&quot;,\r\n        &quot;tools&quot;: [\r\n            {\r\n                &quot;type&quot;: &quot;power&quot;,\r\n                &quot;name&quot;: &quot;hammer&quot;\r\n            },\r\n            {\r\n                &quot;type&quot;: &quot;manual&quot;,\r\n                &quot;name&quot;: &quot;grinder&quot;\r\n            }\r\n        ]\r\n    },\r\n    &quot;people&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;bob&quot;,\r\n            &quot;profession&quot;: &quot;analyst&quot;,\r\n            &quot;clients&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;alice&quot;,\r\n                    &quot;instance&quot;: &quot;3&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;richard&quot;,\r\n                    &quot;instance&quot;: &quot;2&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-lkasjdlflsd&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-lllaksjllsdkf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix2/suffix-stuff-jhfhklasldj&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;melanie&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-lkalalajskljlklj&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-aljksdljsd&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;sarah&quot;,\r\n            &quot;profession&quot;: &quot;developer&quot;,\r\n            &quot;clients&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;george&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-xx-klasjdlk&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-yy-lkajsldf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix3/suffix-stuff-lkklkl-lkasjdl&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;anna&quot;,\r\n                    &quot;instance&quot;: &quot;4&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-aa-lkadslkjjj&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix3/suffix-stuff-bb-lkasdjfl&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix2/suffix-stuff-cc-lkasjdf&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;michael&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-ttlkajlksdfsd&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-rrklajsdlf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix3/suffix-stuff-lkljlkjxx&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nThis is obviously a contrived example but it exactly matches my JSON structure.\r\n\r\nMy goal is to modify values for &quot;stringA&quot; and &quot;stringB&quot; but only for &quot;people&quot; with name == &quot;bob&quot; and only for &quot;clients&quot; with &quot;instance&quot; != &quot;0&quot;. \r\n\r\nI&#39;ve read dozens of stackoverflow posts and other google search results, and I&#39;ve tried dozens (maybe 100&#39;s) of variations of jq commands but no luck--not even close. I&#39;ve tried &#39;..&#39; and walk, and various recursive functions that others have written (written prior to the availability of &#39;..&#39; and walk, I think). My difficulty seems to be related to needing the entire JSON printed out but with conditional changes based on .people[].name and .people[].clients[].instance.\r\n\r\nI really have no idea how this works, I guess.\r\n\r\nIf I run the above JSON data through a command such as\r\n\r\n`jq --arg name bob --arg prefix newprefix &#39;some-mysterious-jq-statements&#39;`\r\n\r\nI want the output to be this:\r\n\r\n\r\n```\r\n{\r\n    &quot;misc&quot;: {\r\n        &quot;color&quot;: &quot;blue&quot;,\r\n        &quot;id&quot;: &quot;yyyy-12345&quot;,\r\n        &quot;birthdate&quot;: &quot;2020-12-25&quot;,\r\n        &quot;tools&quot;: [\r\n            {\r\n                &quot;type&quot;: &quot;power&quot;,\r\n                &quot;name&quot;: &quot;hammer&quot;\r\n            },\r\n            {\r\n                &quot;type&quot;: &quot;manual&quot;,\r\n                &quot;name&quot;: &quot;grinder&quot;\r\n            }\r\n        ]\r\n    },\r\n    &quot;people&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;bob&quot;,\r\n            &quot;profession&quot;: &quot;analyst&quot;,\r\n            &quot;clients&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;alice&quot;,\r\n                    &quot;instance&quot;: &quot;3&quot;,\r\n                    &quot;stringA&quot;: &quot;newprefix/suffix-stuff-xyz-aksdjf&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;richard&quot;,\r\n                    &quot;instance&quot;: &quot;2&quot;,\r\n                    &quot;stringA&quot;: &quot;newprefix/suffix-stuff-lkasjdlflsd&quot;,\r\n                    &quot;stringB&quot;: &quot;newprefix/suffix-stuff-lllaksjllsdkf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix3/suffix-stuff-jhfhklasldj&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;melanie&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-lkalalajskljlklj&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-aljksdljsd&quot;\r\n                }\r\n            ]\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;sarah&quot;,\r\n            &quot;profession&quot;: &quot;developer&quot;,\r\n            &quot;clients&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;george&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-xx-klasjdlk&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-yy-lkajsldf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix3/suffix-stuff-lkklkl-lkasjdl&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;anna&quot;,\r\n                    &quot;instance&quot;: &quot;4&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-aa-lkadslkjjj&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix3/suffix-stuff-bb-lkasdjfl&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix2/suffix-stuff-cc-lkasjdf&quot;\r\n                },\r\n                {\r\n                    &quot;name&quot;: &quot;michael&quot;,\r\n                    &quot;instance&quot;: &quot;0&quot;,\r\n                    &quot;stringA&quot;: &quot;prefix1/suffix-stuff-ttlkajlksdfsd&quot;,\r\n                    &quot;stringB&quot;: &quot;prefix2/suffix-stuff-rrklajsdlf&quot;,\r\n                    &quot;stringC&quot;: &quot;prefix3/suffix-stuff-lkljlkjxx&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nNotice that the person &quot;bob&quot; has had modifications to the values for stringA and stringB for two of his clients, &quot;alice&quot; and &quot;richard&quot;.  Nothing else has changed.\r\n\r\nThank you for your time and assistance! :)",
        "link": "https://stackoverflow.com/questions/75770289/jq-modify-string-values-based-on-values-of-keys-in-parents",
        "title": "jq: modify string values based on values of keys in parents"
    },
    {
        "tags": [
            "json",
            "jq",
            "data-cleaning"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1679180853,
                "last_edit_date": 1679180853,
                "creation_date": 1679180474,
                "answer_id": 75779157,
                "question_id": 75778883,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one of many ways:\r\n```\r\n.[&quot;team size&quot;] |=\r\n  (add\r\n   | [ ({size: &quot;min&quot;} + (.min | add)),\r\n       ({size: &quot;max&quot;} + (.max | add)) ] )\r\n```\r\n\r\nor more DRYly:\r\n```\r\n.[&quot;team size&quot;] |=\r\n  (add\r\n   | . as $in\r\n   | reduce keys_unsorted[] as $k ([];\r\n       . + [{size: $k} + ($in[$k]|add) ] ))\r\n```",
                "title": "Trying to transform over-complicated array of objects in JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1679180853,
        "creation_date": 1679176353,
        "question_id": 75778883,
        "body_markdown": "I&#39;ve got a JSON document that looks like this:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;My Team&quot;,\r\n  &quot;team size&quot;: [\r\n    {\r\n      &quot;min&quot;: [\r\n        {\r\n          &quot;Leader&quot;: 1\r\n        },\r\n        {\r\n          &quot;Followers&quot;: 5\r\n        },\r\n        {\r\n          &quot;point cost&quot;: 7\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;max&quot;: [\r\n        {\r\n          &quot;Leader&quot;: 1\r\n        },\r\n        {\r\n          &quot;Followers&quot;: 9\r\n        },\r\n        {\r\n          &quot;point cost&quot;: 11\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want it to look like this:\r\n\r\n```\r\n{\r\n    &quot;name&quot;: &quot;My Team&quot;,\r\n    &quot;team size&quot;: [\r\n        {\r\n            &quot;size&quot;: &quot;min&quot;,\r\n            &quot;Leader&quot;: 1,\r\n            &quot;Followers&quot;: 5,\r\n            &quot;point cost&quot;: 7\r\n        },\r\n        {\r\n            &quot;size&quot;: &quot;max&quot;,\r\n            &quot;Leader&quot;: 1,\r\n            &quot;Followers&quot;: 9,\r\n            &quot;point cost&quot;: 11\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nBut I&#39;m having a hard time with it. I know it&#39;s something like `jq . &#39;&quot;team size&quot; |= map(to_entries[] | .key + .values)`, but I&#39;m not getting the syntax right. Any help would be greatly appreciated.",
        "link": "https://stackoverflow.com/questions/75778883/trying-to-transform-over-complicated-array-of-objects-in-json-using-jq",
        "title": "Trying to transform over-complicated array of objects in JSON using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679191362,
                "last_edit_date": 1679191362,
                "creation_date": 1679190203,
                "answer_id": 75779654,
                "question_id": 75779596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the content of your JSON is trustworthy:\r\n\r\n    eval $(jq -r &#39;to_entries|map(&quot;export \\(.key)=\\&quot;\\(.value|tostring)\\&quot;&quot;)|.[]&#39; file.json)\r\n    echo &quot;$a&quot;\r\n    echo &quot;$b&quot;\r\nOutput:\r\n&lt;pre&gt;\r\n1\r\nx y\r\n&lt;/pre&gt;\r\n\r\nSee: [Why should eval be avoided in Bash, and what should I use instead?](https://stackoverflow.com/q/17529220/3776858)",
                "title": "How to extract multiple properties from a single level JSON and assign them to the respective bash variables in the most concise manner?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679218519,
                "last_edit_date": 1679218519,
                "creation_date": 1679213963,
                "answer_id": 75780807,
                "question_id": 75779596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the input is valid JSON (as with your second input - the first one lacked quoting the `a` key), and the keys are valid identifiers for shell variables (with no special characters like `=` or whitespace etc.), and the values don&#39;t contain newlines (special characters like `=` or other whitespace are covered, though), then you could use `read` on a single jq filter as follows:\r\n\r\nFor the two item version just name them directly:\r\n```sh\r\n$ { read -r a; read -r b; } &lt; &lt;(jq -r &#39;.a, .b&#39; file.json)\r\n\r\n$ echo &quot;$a&quot;\r\n1\r\n\r\n$ echo &quot;$b&quot;\r\nx y\r\n```\r\n\r\nFor more items you could `declare` them in a `while` loop based on the output of a `to_entries` iteration (in the shell, use variable names (here `$key` and `$value`) that are not affected by the extraction):\r\n```sh\r\n$ { while read -r key; read -r value; do declare &quot;$key&quot;=&quot;$value&quot;; done; } &lt; &lt;(jq -r &#39;to_entries[][]&#39; file.json)\r\n\r\n$ echo &quot;$a&quot;\r\n1\r\n\r\n$ echo &quot;$b&quot;\r\nx y\r\n```\r\n\r\nFor conciseness, you can have jq also generate the `=` between key and value, so only one variable (here `$dec`) is needed:\r\n```sh\r\n$ { while read -r dec; do declare &quot;$dec&quot;; done; } &lt; &lt;(jq -r &#39;to_entries[] | join(&quot;=&quot;)&#39; file.json)\r\n\r\n$ echo &quot;$a&quot;\r\n1\r\n\r\n$ echo &quot;$b&quot;\r\nx y\r\n```",
                "title": "How to extract multiple properties from a single level JSON and assign them to the respective bash variables in the most concise manner?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679218624,
                "creation_date": 1679218624,
                "answer_id": 75781132,
                "question_id": 75779596,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ source &lt;(jq -r &#39;to_entries[]|&quot;export \\(.key)=\\&quot;\\(.value)\\&quot;&quot;&#39; &lt;&lt;&lt;&#39;{&quot;a&quot;:1,&quot;b&quot;:&quot;x y z&quot;}&#39;)\r\n    \r\n    $ echo $a\r\n    1\r\n    $ echo $b\r\n    x y z\r\n    $ bash -c &#39;echo $b&#39;\r\n    x y z",
                "title": "How to extract multiple properties from a single level JSON and assign them to the respective bash variables in the most concise manner?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1679218624,
        "creation_date": 1679188845,
        "last_edit_date": 1679213047,
        "question_id": 75779596,
        "body_markdown": "Suppose we have the following JSON - `{a:1,b:&quot;x&quot;}`. I want to extract the properties `a` and `b` and assign them to the respective bash variables.\r\n\r\nHere is how I do it today:\r\n```\r\n/c/Temp$ export $(jq -n &#39;{a:1,b:&quot;x&quot;}&#39; | sed -n &#39;s,:,=,p&#39; | tr -d &#39;, &quot;&#39;) &amp;&amp; echo $a &amp;&amp; echo $b\r\n1\r\nx\r\n\r\n/c/Temp$\r\n```\r\n\r\nHowever, this only works when the values do not contain spaces, therefore my solution is incorrect.\r\n\r\nI can also invoke `jq` one by one like this:\r\n```\r\n/c/Temp$ b=$(jq -n &#39;{a:1,b:&quot;x&quot;}&#39; | jq -r .b) &amp;&amp; echo $b\r\nx\r\n\r\n/c/Temp$ a=$(jq -n &#39;{a:1,b:&quot;x&quot;}&#39; | jq -r .a) &amp;&amp; echo $a\r\n1\r\n\r\n/c/Temp$\r\n```\r\nBut I feel it is not the most concise solution.\r\n\r\nWhat is the most concise solution? \r\n\r\nFor the purpose of this post, use this json:\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: &quot;x y&quot;\r\n}\r\n```\r\nBut the solution should work equally well for a JSON with 50 top level properties.",
        "link": "https://stackoverflow.com/questions/75779596/how-to-extract-multiple-properties-from-a-single-level-json-and-assign-them-to-t",
        "title": "How to extract multiple properties from a single level JSON and assign them to the respective bash variables in the most concise manner?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1679745450,
                "last_edit_date": 1679745450,
                "creation_date": 1679234944,
                "answer_id": 75782561,
                "question_id": 75782530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `join()` function in JQ to join the key/value pairs with a space instead of a new line.\r\n\r\n```\r\njq -r &quot;. | to_entries | map(\\&quot;-var=\\\\\\&quot;\\(.key)=\\(.value)\\\\\\&quot;\\&quot;) | join(\\&quot; \\&quot;)&quot;\r\n```",
                "title": "JQ Map to String"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679343793,
                "last_edit_date": 1679343793,
                "creation_date": 1679255547,
                "answer_id": 75784581,
                "question_id": 75782530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the output given, it seems you want to pass the result to another command, you can try this:\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nmapfile -d &#39;&#39; -t options &lt; &lt;(jq -j -r &#39;to_entries[]|&quot;-var=\\(.key)=\\(.value)\\u0000&quot;&#39; input.json)\r\n\r\necho another-command &quot;${options[@]}&quot;\r\n# Output : another-command -var=foo=bar -var=baz=qux\r\n```",
                "title": "JQ Map to String"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679335898,
                "last_edit_date": 1679335898,
                "creation_date": 1679331717,
                "answer_id": 75793220,
                "question_id": 75782530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want `[ ... ] | join( &quot; &quot; )`.\r\n\r\n```sh\r\njq -r &#39;to_entries | map( &quot;-var=\\&quot;\\( .key + &quot;=&quot; + .value )\\&quot;&quot; ) | join( &quot; &quot; )&#39;\r\n```\r\n\r\nBut it looks like you&#39;re building a shell command, so you should also use `@sh` (or whatever&#39;s appropriate for the shell you use) to properly quote the values.\r\n\r\n```sh\r\njq -r &#39;to_entries | map( @sh &quot;-var=\\( .key + &quot;=&quot; + .value )&quot; ) | join( &quot; &quot; )&#39;\r\n```\r\n\r\nFor example,\r\n\r\n```json\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: &quot;qux&quot;,\r\n  &quot;moo&quot;: &quot;a&#39;b\\&quot;c&quot;\r\n}\r\n```\r\n\r\nresults in\r\n\r\n```none\r\n-var=&#39;foo=bar&#39; -var=&#39;baz=qux&#39; -var=&#39;moo=a&#39;\\&#39;&#39;b&quot;c&#39;\r\n```\r\n\r\n[Demo](https://jqplay.org/s/U4AU_riD7pt) on jqplay.\r\n\r\nYou&#39;d run the command using\r\n\r\n```sh\r\neval &quot;mycommand $( ... | jq ... )&quot;\r\n```\r\n\r\nNotes:\r\n\r\n* No code injection bugs.\r\n* Works in all sh-like shells.\r\n* Even works with values containing Line Feeds.\r\n",
                "title": "JQ Map to String"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1679745450,
        "creation_date": 1679234628,
        "question_id": 75782530,
        "body_markdown": "I&#39;m trying to transform a map to a string of key/value pairs with JQ.\r\n\r\nI&#39;d like to transform this:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;baz&quot;: &quot;qux&quot;\r\n}\r\n```\r\n\r\nInto this:\r\n```\r\n-var=&quot;foo=bar&quot; -var=&quot;baz=qux&quot;\r\n```\r\n\r\nI&#39;ve managed to get it close with this:\r\n```\r\njq -r &quot;. | to_entries | .[] | (\\&quot;-var=\\\\\\&quot;\\&quot; + .key + \\&quot;=\\&quot; + .value + \\&quot;\\\\\\&quot;\\&quot;)&quot;\r\n```\r\n\r\nWhich gives me:\r\n```\r\n-var=&quot;foo=bar&quot;\r\n-var=&quot;baz=qux&quot;\r\n```\r\n\r\nBut I can&#39;t figure out the last step to have it join them with a space instead of a new line.",
        "link": "https://stackoverflow.com/questions/75782530/jq-map-to-string",
        "title": "JQ Map to String"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679269084,
                "post_id": 75785532,
                "comment_id": 133686245,
                "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": 1679269804,
                "post_id": 75785532,
                "comment_id": 133686302,
                "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": 1679382711,
                "post_id": 75785532,
                "comment_id": 133707133,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679271570,
                "last_edit_date": 1679271570,
                "creation_date": 1679270924,
                "answer_id": 75785712,
                "question_id": 75785532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems that is a bug in jq 1.6. I compiled master version which gives correct result :\r\n\r\n```\r\n$ jq --version\r\njq-1.6-159-gcff5336\r\n$ jq -n &#39;[2,2] | any( [1,2][]|. == .) &#39;\r\ntrue\r\n$ jq -n &#39;[2,2] | any( [2,1][]|. == .) &#39;\r\ntrue\r\n$ jq -n &#39;[2,2] | any( [1,2][] == .) &#39;\r\ntrue\r\n$ jq -n &#39;[2,2] | any( [2,1][] == .) &#39;\r\ntrue\r\n```",
                "title": "jq: how does any() real work in array context?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679367851,
                "creation_date": 1679367851,
                "answer_id": 75797002,
                "question_id": 75785532,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a bug in version 1.6 that has been fixed long ago:\r\n\r\n```\r\n\r\n$jq -n &#39;[2,2]|any([2,1][]|(.==.)|debug)&#39; \r\n[&quot;DEBUG:&quot;,true]\r\n[&quot;DEBUG:&quot;,true]\r\nfalse\r\n\r\n\r\n$ jqMaster -n &#39;[2,2]|any([2,1][]|(.==.)|debug)&#39; \r\n[&quot;DEBUG:&quot;,true]\r\ntrue\r\n\r\n```\r\n\r\nThis fix is one of the most important reasons it is such a shame that version 1.6 is still the most recent “official” version.",
                "title": "jq: how does any() real work in array context?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1679367851,
        "creation_date": 1679267900,
        "question_id": 75785532,
        "body_markdown": "jq produces unexpected results when `any()` is called in this context `any(array[]==val)` \r\n\r\nI&#39;m not sure how `jq` calculates these results:\r\n```\r\n$ jq -n &#39;[2,2] | any( [1,2][]|. == .) &#39;\r\nfalse\r\n$ jq -n &#39;[2,2] | any( [2,1][]|. == .) &#39;\r\nfalse\r\n# or\r\n$ jq -n &#39;[2,2] | any( [1,2][] == .) &#39;\r\ntrue\r\n$ jq -n &#39;[2,2] | any( [2,1][] == .) &#39;\r\nfalse\r\n```\r\nI&#39;d expect `true` in all cases?\r\n\r\nwhen using `==` in explicit expression, the results are as expected.\r\n```\r\n$ jq -n &#39;([2,2][]) == ([1,2][])&#39;\r\nfalse\r\nfalse\r\ntrue\r\ntrue\r\n$ jq -n &#39;([2,2][]) == ([2,1][])&#39;\r\ntrue\r\ntrue\r\nfalse\r\nfalse\r\n```\r\n How can it be explained?",
        "link": "https://stackoverflow.com/questions/75785532/jq-how-does-any-real-work-in-array-context",
        "title": "jq: how does any() real work in array context?"
    },
    {
        "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": 0,
                "creation_date": 1679338401,
                "post_id": 75794207,
                "comment_id": 133700764,
                "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": 1679338572,
                "post_id": 75794207,
                "comment_id": 133700804,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1679338648,
                "creation_date": 1679338648,
                "answer_id": 75794256,
                "question_id": 75794207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.clients | with_entries(.value = (.value.instances | to_entries[0].value))\r\n```\r\n\r\nWill update the `value` of the `key` with the `first` value of `instances`\r\n```\r\n{\r\n  &quot;c1&quot;: {\r\n    &quot;updated&quot;: &quot;2023-03-19T17:45:03.703984279+01:00&quot;,\r\n    &quot;chargePower&quot;: 349.9999940395355\r\n  },\r\n  &quot;c2&quot;: {\r\n    &quot;updated&quot;: &quot;2023-02-10T18:34:56.352428175+01:00&quot;,\r\n    &quot;chargePower&quot;: 0\r\n  }\r\n}\r\n\r\n```",
                "title": "Jq: how to extract from map of maps?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1679342273,
                "last_edit_date": 1679342273,
                "creation_date": 1679338663,
                "answer_id": 75794258,
                "question_id": 75794207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure if I got your question right (it is lacking the expected output), but if you are looking for an object with the instances&#39; keys as keys, then you could use [`map`](https://stedolan.github.io/jq/manual/v1.6/#map(x),map_values(x)) on the parent objects and [`add`](https://stedolan.github.io/jq/manual/v1.6/#add) on the resulting array of nested objects:\r\n\r\n```\r\n.clients | map(.instances) | add\r\n```\r\n\r\nOr a [`reduce`](https://stedolan.github.io/jq/manual/v1.6/#Reduce)-based approach:\r\n\r\n```\r\nreduce .clients[].instances as $i ({}; . + $i)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;i1&quot;: {\r\n    &quot;updated&quot;: &quot;2023-03-19T17:45:03.703984279+01:00&quot;,\r\n    &quot;chargePower&quot;: 349.9999940395355\r\n  },\r\n  &quot;i2&quot;: {\r\n    &quot;updated&quot;: &quot;2023-02-10T18:34:56.352428175+01:00&quot;,\r\n    &quot;chargePower&quot;: 0\r\n  }\r\n}\r\n```",
                "title": "Jq: how to extract from map of maps?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1679349761,
        "creation_date": 1679338336,
        "last_edit_date": 1679349761,
        "question_id": 75794207,
        "body_markdown": "I have\r\n\r\n```json\r\n{\r\n    &quot;version&quot;: 2,\r\n    &quot;clients&quot;: {\r\n        &quot;c1&quot;: {\r\n            &quot;updated&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n            &quot;instances&quot;: {\r\n                &quot;i1&quot;: {\r\n                    &quot;updated&quot;: &quot;2023-03-19T17:45:03.703984279+01:00&quot;,\r\n                    &quot;chargePower&quot;: 349.9999940395355\r\n                }\r\n            }\r\n        },\r\n        &quot;c2&quot;: {\r\n            &quot;updated&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n            &quot;instances&quot;: {\r\n                &quot;i2&quot;: {\r\n                    &quot;updated&quot;: &quot;2023-02-10T18:34:56.352428175+01:00&quot;,\r\n                    &quot;chargePower&quot;: 0\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nand would like a map of instance id (i1...) and the map it has associated like this:\r\n\r\n```json\r\n{\r\n    &quot;i1&quot;: {\r\n        &quot;updated&quot;: &quot;2023-03-19T17:45:03.703984279+01:00&quot;,\r\n        &quot;chargePower&quot;: 349.9999940395355\r\n    },\r\n    &quot;i2&quot;: {\r\n        &quot;updated&quot;: &quot;2023-02-10T18:34:56.352428175+01:00&quot;,\r\n        &quot;chargePower&quot;: 0\r\n    }\r\n}\r\n```\r\n\r\nI get as far  as\r\n\r\n    .clients | to_entries | .[].value.instances \r\n\r\nwhich gives \r\n\r\n```json\r\n{\r\n  &quot;i1&quot;: {\r\n    &quot;updated&quot;: &quot;2023-03-19T17:45:03.703984279+01:00&quot;,\r\n    &quot;chargePower&quot;: 349.9999940395355\r\n  }\r\n}\r\n{\r\n  &quot;i2&quot;: {\r\n    &quot;updated&quot;: &quot;2023-02-10T18:34:56.352428175+01:00&quot;,\r\n    &quot;chargePower&quot;: 0\r\n  }\r\n}\r\n```\r\nbut fail to convert that back to a map. Here&#39;s a jqplay: https://jqplay.org/s/FMnrrUIV27U",
        "link": "https://stackoverflow.com/questions/75794207/jq-how-to-extract-from-map-of-maps",
        "title": "Jq: how to extract from map of maps?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679412743,
                "creation_date": 1679412743,
                "answer_id": 75803253,
                "question_id": 75803143,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use:\r\n\r\n```bash\r\nAPP_ID=6e663913-0000-3456-c083e40fbc99\r\njq --arg app_id &quot;$APP_ID&quot; &#39;.[].id = $app_id&#39; oauth2-permissions.json\r\n```\r\n",
                "title": "How to replace a value in json file with a new value using a variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1679602437,
        "creation_date": 1679412219,
        "last_edit_date": 1679602437,
        "question_id": 75803143,
        "body_markdown": "I want to replace the value for `id` with a new one.\r\nI have the following json file.\r\n\r\n     [\r\n      {\r\n        &quot;adminConsentDescription&quot;: &quot;default&quot;,\r\n        &quot;adminConsentDisplayName&quot;: &quot;default&quot;,\r\n        &quot;id&quot;: &quot;5ad89ced-56a1-2222-8200-1ded5129d788&quot;,\r\n        &quot;isEnabled&quot;: true,\r\n        &quot;type&quot;: &quot;User&quot;,\r\n        &quot;userConsentDescription&quot;: null,\r\n        &quot;userConsentDisplayName&quot;: null,\r\n        &quot;value&quot;: &quot;default&quot;\r\n      }\r\n    ]\r\n\r\nAnd want to replace it with the variable app_id `app_id=6e663913-0000-3456-c083e40fbc99`\r\nand the output should be \r\n\r\n    [\r\n      {\r\n        &quot;adminConsentDescription&quot;: &quot;default&quot;,\r\n        &quot;adminConsentDisplayName&quot;: &quot;default&quot;,\r\n        &quot;id&quot;: &quot;6e663913-0000-3456-c083e40fbc99&quot;,\r\n        &quot;isEnabled&quot;: true,\r\n        &quot;type&quot;: &quot;User&quot;,\r\n        &quot;userConsentDescription&quot;: null,\r\n        &quot;userConsentDisplayName&quot;: null,\r\n        &quot;value&quot;: &quot;default&quot;\r\n      }\r\n    ]\r\n\r\nI tried and came to a point where I was able to extract the value with Jq\r\n\r\ndefined the variable first \r\n\r\nApp_id=6e663913-0000-3456-c083e40fbc99\r\n\r\n    jq --argjson id $app_id &#39;map(.&quot;id&quot; = $app_id)&#39; oauth2-permissions.json\r\n\r\nTried couple of other permutations but could not replace with a variable. Any ideas ? \r\n",
        "link": "https://stackoverflow.com/questions/75803143/how-to-replace-a-value-in-json-file-with-a-new-value-using-a-variable",
        "title": "How to replace a value in json file with a new value using a variable"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679415475,
                "last_edit_date": 1679415475,
                "creation_date": 1679414698,
                "answer_id": 75803607,
                "question_id": 75803544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.items |= (group_by(.name) | map(first | { name, version: (.version // &quot;NA&quot;) }))\r\n```\r\n\r\n1. [`group_by(.name)`][1] to group each duplicate name\r\n2. [`map()`][2] over the result\r\n    1. Take the [`first`][3] object\r\n    2. Re-create the object with a fallback for version: `(.version // &quot;NA&quot;)`\r\n```json\r\n{\r\n  &quot;foo1&quot;: &quot;bar1&quot;,\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;c1&quot;,\r\n      &quot;version&quot;: &quot;v1&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c2&quot;,\r\n      &quot;version&quot;: &quot;v2&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c3&quot;,\r\n      &quot;version&quot;: &quot;v3&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c4&quot;,\r\n      &quot;version&quot;: &quot;NA&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c5&quot;,\r\n      &quot;version&quot;: &quot;NA&quot;\r\n    }\r\n  ],\r\n  &quot;foo3&quot;: &quot;bar3&quot;,\r\n  &quot;foo4&quot;: &quot;bar4&quot;\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n#### [Updated Playground](https://www.devtoolsdaily.com/jq_playground/?#%7B%22inputText%22%3A%22%7B%5Cn%20%20%5C%22foo1%5C%22%3A%20%5C%22bar1%5C%22%2C%5Cn%20%20%5C%22foo2%5C%22%3A%20%5C%22bar2%5C%22%2C%5Cn%20%20%5C%22items%5C%22%3A%20%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c1%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v1%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c5%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c2%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v2%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c5%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c3%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v3%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c4%5C%22%5Cn%20%20%20%20%7D%5Cn%20%20%5D%2C%5Cn%20%20%5C%22foo3%5C%22%3A%20%5C%22bar3%5C%22%2C%5Cn%20%20%5C%22foo4%5C%22%3A%20%5C%22bar4%5C%22%5Cn%7D%22%2C%22filterExpr%22%3A%22.items%20%7C%3D%20(group_by(.name)%20%7C%20map(first%20%7C%20%7B%20name%2C%20version%3A%20(.version%20%2F%2F%20%5C%22NA%5C%22)%20%7D))%22%2C%22rawOutput%22%3Afalse%7D)\r\n\r\n\r\n----------\r\n\r\nBased on OP&#39;s [comment][4], you could &#39;combine&#39; the original object to keep every other value then `name` or `version` using [Addition (`+`)][5]:\r\n```\r\n.items |= (group_by(.name) | map(first | . + { name, version: (.version // &quot;NA&quot;) }))\r\n```\r\n\r\n[Playground](https://www.devtoolsdaily.com/jq_playground/?#%7B%22inputText%22%3A%22%7B%5Cn%20%20%5C%22foo1%5C%22%3A%20%5C%22bar1%5C%22%2C%5Cn%20%20%5C%22foo2%5C%22%3A%20%5C%22bar2%5C%22%2C%5Cn%20%20%5C%22items%5C%22%3A%20%5B%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c1%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v1%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c5%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c2%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v2%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22something%5C%22%3A%20%5C%22foobar%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c5%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c3%5C%22%2C%5Cn%20%20%20%20%20%20%5C%22version%5C%22%3A%20%5C%22v3%5C%22%5Cn%20%20%20%20%7D%2C%5Cn%20%20%20%20%7B%5Cn%20%20%20%20%20%20%5C%22name%5C%22%3A%20%5C%22c4%5C%22%5Cn%20%20%20%20%7D%5Cn%20%20%5D%2C%5Cn%20%20%5C%22foo3%5C%22%3A%20%5C%22bar3%5C%22%2C%5Cn%20%20%5C%22foo4%5C%22%3A%20%5C%22bar4%5C%22%5Cn%7D%22%2C%22filterExpr%22%3A%22.items%20%7C%3D%20(group_by(.name)%20%7C%20map(first%20%7C%20.%20%2B%20%7B%20name%2C%20version%3A%20(.version%20%2F%2F%20%5C%22NA%5C%22)%20%7D))%22%2C%22rawOutput%22%3Afalse%7D)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#group_by(path_expression)\r\n  [2]: https://stedolan.github.io/jq/manual/#map(x),map_values(x)\r\n  [3]: https://stedolan.github.io/jq/manual/#first,last,nth(n)\r\n  [4]: https://stackoverflow.com/questions/75803544/add-default-value-for-nested-object-and-remove-duplicates-from-nested-array-in-j/75803607?noredirect=1#comment133716430_75803607\r\n  [5]: https://stedolan.github.io/jq/manual/#Addition:+",
                "title": "Add default value for nested object and remove duplicates from nested array in JSON using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1679415666,
                "creation_date": 1679415666,
                "answer_id": 75803793,
                "question_id": 75803544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could define a default object, then add the real items to it. Existing fields will overwrite the defaults:\r\n```sh\r\njq --argjson def &#39;{&quot;version&quot;: &quot;NA&quot;}&#39; &#39;.items |= (unique_by(.name) | map($def + .))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;foo1&quot;: &quot;bar1&quot;,\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;version&quot;: &quot;v1&quot;,\r\n      &quot;name&quot;: &quot;c1&quot;,\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;v2&quot;,\r\n      &quot;name&quot;: &quot;c2&quot;,\r\n      &quot;fooArr&quot;: []\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;v3&quot;,\r\n      &quot;name&quot;: &quot;c3&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;NA&quot;,\r\n      &quot;name&quot;: &quot;c4&quot;\r\n    },\r\n    {\r\n      &quot;version&quot;: &quot;NA&quot;,\r\n      &quot;name&quot;: &quot;c5&quot;\r\n    }\r\n  ],\r\n  &quot;foo3&quot;: &quot;bar3&quot;,\r\n  &quot;foo4&quot;: &quot;bar4&quot;\r\n}\r\n```",
                "title": "Add default value for nested object and remove duplicates from nested array in JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1679415666,
        "creation_date": 1679414360,
        "last_edit_date": 1679415438,
        "question_id": 75803544,
        "body_markdown": "I have the following JSON:\r\n```json\r\n{\r\n  &quot;foo1&quot;: &quot;bar1&quot;,\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;c1&quot;,\r\n      &quot;version&quot;: &quot;v1&quot;,\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c5&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c2&quot;,\r\n      &quot;version&quot;: &quot;v2&quot;,\r\n      &quot;fooArr&quot;: []\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c5&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c3&quot;,\r\n      &quot;version&quot;: &quot;v3&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c4&quot;\r\n    }\r\n  ],\r\n  &quot;foo3&quot;: &quot;bar3&quot;,\r\n  &quot;foo4&quot;: &quot;bar4&quot;\r\n}\r\n```\r\nI&#39;m trying to convert it to below by adding default version to items and removing duplicates by name\r\n```json\r\n{\r\n  &quot;foo1&quot;: &quot;bar1&quot;,\r\n  &quot;foo2&quot;: &quot;bar2&quot;,\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;c1&quot;,\r\n      &quot;version&quot;: &quot;v1&quot;,\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c5&quot;\r\n      &quot;version&quot;: &quot;NA&quot;\r\n    {\r\n      &quot;name&quot;: &quot;c2&quot;,\r\n      &quot;version&quot;: &quot;v2&quot;\r\n      &quot;fooArr&quot;: []\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c3&quot;,\r\n      &quot;version&quot;: &quot;v3&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;c4&quot;\r\n      &quot;version&quot;: &quot;NA&quot;\r\n    }\r\n  ],\r\n  &quot;foo3&quot;: &quot;bar3&quot;,\r\n  &quot;foo4&quot;: &quot;bar4&quot;\r\n}\r\n```\r\nI&#39;m able to add default version using `.items[] | if (.version) then . else . + {&quot;version&quot;: &quot;NA&quot;} end`. But it is only returning items and removing other values.  Is this  possible using jq? [jq playground link][1]\r\n\r\n\r\n  [1]: https://www.devtoolsdaily.com/jq_playground/",
        "link": "https://stackoverflow.com/questions/75803544/add-default-value-for-nested-object-and-remove-duplicates-from-nested-array-in-j",
        "title": "Add default value for nested object and remove duplicates from nested array in JSON using jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "pretty-print"
        ],
        "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": 1679426297,
                "post_id": 75805361,
                "comment_id": 133719606,
                "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": 3,
                "creation_date": 1679428739,
                "post_id": 75805361,
                "comment_id": 133720126,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1689270,
                    "reputation": 172,
                    "user_id": 1551966,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/9a4289cad3411f1ae1ba1a430a8a7afd?s=256&d=identicon&r=PG",
                    "display_name": "Liam Caffrey",
                    "link": "https://stackoverflow.com/users/1551966/liam-caffrey"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679442547,
                "post_id": 75805361,
                "comment_id": 133722660,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679439869,
                "last_edit_date": 1679439869,
                "creation_date": 1679425735,
                "answer_id": 75805448,
                "question_id": 75805361,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `walk` through the document tree, `try` to convert `strings` using `fromjson`, and `catch` failures by falling back to the original item:\r\n```sh\r\necho … | jq &#39;walk(strings = (. as $s | try fromjson catch $s))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;my_key&quot;: &quot;my_val&quot;,\r\n  &quot;next_key&quot;: &quot;next_val&quot;,\r\n  &quot;schema&quot;: {\r\n    &quot;name&quot;: &quot;bucket_name&quot;\r\n  }\r\n}\r\n```\r\n\r\n---\r\nTo exempt from conversion certain strings that unwillingly happen to qualify as a valid JSON-encoding (like `&quot;true&quot;` or `&quot;123&quot;`), add further conditions covering a distinction. For instance, to only decode strings that represent `objects`, you could go with:\r\n```sh\r\njq &#39;walk(strings = (. as $s | try (fromjson | objects // $s) catch $s))&#39;\r\n```",
                "title": "Pretty-print nested json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1679439869,
        "creation_date": 1679425062,
        "question_id": 75805361,
        "body_markdown": "Using jq, how do I pretty-print \r\n```\r\necho &#39;{ &quot;my_key&quot;: &quot;my_val&quot;, &quot;next_key&quot;: &quot;next_val&quot;, &quot;schema&quot;: &quot;{\\n  \\&quot;name\\&quot;: \\&quot;bucket_name\\&quot;\\n}&quot; }&#39;\r\n```\r\nresulting in \r\n```\r\n{\r\n  &quot;my_key&quot;: &quot;my_val&quot;,\r\n  &quot;next_key&quot;: &quot;next_val&quot;,\r\n  &quot;schema&quot;: {\r\n    &quot;name&quot;: &quot;bucket_name&quot;\r\n  }\r\n}\r\n```\r\n\r\nI can escape the newlines and get some kind of useful output but I don&#39;t want to interfere with the source json, for example\r\n\r\n```\r\necho &#39;{ &quot;my_key&quot;: &quot;my_val&quot;, &quot;next_key&quot;: &quot;next_val&quot;, &quot;schema&quot;: &quot;{\\\\n  \\\\&quot;name\\\\&quot;: \\\\&quot;bucket_name\\\\&quot;\\\\n}&quot; }&#39; | jq &#39;(.schema | fromjson) as $s | .schema = $s&#39;\r\n```\r\n\r\nIn this example, I am also stuck with a hard-coded key `schema` key when there are other keys in my json with nested json and I don&#39;t know the names of those keys.\r\n\r\nIs there a way to do this generically for any key name that contains nested json without escaping the escapes or specifying the keys?\r\n",
        "link": "https://stackoverflow.com/questions/75805361/pretty-print-nested-json-with-jq",
        "title": "Pretty-print nested json with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679444270,
                "last_edit_date": 1679444270,
                "creation_date": 1679436222,
                "answer_id": 75806724,
                "question_id": 75806651,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Bring the assignment to top-level by enclosing traversal and filtering into parentheses, so the context stays the same on exit:\r\n```sh\r\njq &#39;(.keyPairs[] | select(.key == &quot;second&quot;).value.intValue) = &quot;0&quot;&#39; myfile.json\r\n```\r\n\r\nSaving into the same file is not supported directly, but you could either save into a temporary file and move it on success, or use tools like [sponge][1].\r\n```sh\r\njq &#39;…&#39; myfile.json &gt; tmp.json &amp;&amp; mv tmp.json myfile.json\r\n```\r\n\r\n\r\n  [1]: https://joeyh.name/code/moreutils/",
                "title": "Replace value in JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1679444270,
        "creation_date": 1679435573,
        "last_edit_date": 1679436162,
        "question_id": 75806651,
        "body_markdown": "For flexibility reasons my file is layed out as an array of keys and values with different types:\r\n```\r\n{\r\n &quot;keyPairs&quot;: [\r\n  {\r\n   &quot;key&quot;: &quot;first&quot;,\r\n   &quot;value&quot;: {\r\n    &quot;boolValue&quot;: false\r\n   }\r\n  },\r\n  {\r\n   &quot;key&quot;: &quot;second&quot;,\r\n   &quot;value&quot;: {\r\n    &quot;intValue&quot;: &quot;1&quot;\r\n   }\r\n  }\r\n}\r\n```\r\n\r\nI want to replace one of the values in the file. I&#39;ve already figured out how to read the value:\r\n\r\n    $ jq &#39;.keyPairs[] | select(.key == &quot;second&quot;) | .value.intValue&#39; myfile.json\r\n    &quot;1&quot;\r\n\r\nI can get it to change the output:\r\n\r\n    $ jq &#39;.keyPairs[] | select(.key == &quot;second&quot;) | .value.intValue = &quot;0&quot;&#39; myfile.json\r\n    {\r\n     &quot;key&quot;: &quot;second&quot;,\r\n     &quot;value&quot;: {\r\n      &quot;intValue&quot;: &quot;0&quot;\r\n     }\r\n    }\r\n\r\nBut this just changes the output. How do I get the value in the file changed?\r\n\r\nNote this is a minimal Linux distro so I only have access to limited tools.",
        "link": "https://stackoverflow.com/questions/75806651/replace-value-in-json-file-with-jq",
        "title": "Replace value in JSON file with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679465498,
                "post_id": 75808800,
                "comment_id": 133725124,
                "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": 1679469302,
                "post_id": 75808800,
                "comment_id": 133725658,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679487048,
                "creation_date": 1679487048,
                "answer_id": 75812087,
                "question_id": 75808800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Fortunately, strings can be compared lexicographically by jq which saves you from converting the strings to date objects first. You just need to make sure to actually use a string in the comparison:\r\n\r\n```\r\nselect(.updated_on &gt; &quot;2023-01-17&quot;)\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;comment_count&quot;: 0,\r\n  &quot;task_count&quot;: 0,\r\n  &quot;type&quot;: &quot;pullrequest&quot;,\r\n  &quot;id&quot;: 3,\r\n  &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n  &quot;state&quot;: &quot;MERGED&quot;,\r\n  &quot;reason&quot;: &quot;&quot;,\r\n  &quot;created_on&quot;: &quot;2023-02-08T05:17:49.292686+00:00&quot;,\r\n  &quot;updated_on&quot;: &quot;2023-02-08T08:55:02.565205+00:00&quot;\r\n}\r\n```",
                "title": "Unable to filter json output based on date field"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1679760250,
                "creation_date": 1679760250,
                "answer_id": 75842920,
                "question_id": 75808800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter date:\r\n\r\n```shell-session\r\n$ cat json_data | jq -s &#39;map(select((.updated_on &gt; &quot;2023-01-07&quot;)))&#39;\r\n\r\n[\r\n  {\r\n    &quot;comment_count&quot;: 0,\r\n    &quot;task_count&quot;: 0,\r\n    &quot;type&quot;: &quot;pullrequest&quot;,\r\n    &quot;id&quot;: 3,\r\n    &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n    &quot;state&quot;: &quot;MERGED&quot;,\r\n    &quot;reason&quot;: &quot;&quot;,\r\n    &quot;created_on&quot;: &quot;2023-02-08T05:17:49.292686+00:00&quot;,\r\n    &quot;updated_on&quot;: &quot;2023-02-08T08:55:02.565205+00:00&quot;\r\n  },\r\n  {\r\n    &quot;comment_count&quot;: 0,\r\n    &quot;task_count&quot;: 0,\r\n    &quot;type&quot;: &quot;pullrequest&quot;,\r\n    &quot;id&quot;: 2,\r\n    &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n    &quot;state&quot;: &quot;MERGED&quot;,\r\n    &quot;reason&quot;: &quot;&quot;,\r\n    &quot;created_on&quot;: &quot;2023-01-08T05:17:49.292686+00:00&quot;,\r\n    &quot;updated_on&quot;: &quot;2023-01-08T08:55:02.565205+00:00&quot;\r\n  }\r\n]\r\n```\r\n\r\nTarget date:\r\n\r\n```shell-session\r\n$ cat json_data | jq -s &#39;map(.updated_on|gsub(&quot;T.*&quot;;&quot;&quot;))&#39;\r\n\r\n[\r\n  &quot;2023-02-08&quot;,\r\n  &quot;2023-01-08&quot;,\r\n  &quot;2022-02-08&quot;\r\n]\r\n\r\n\r\n$ cat json_data | jq -s &#39;map(select((.updated_on|gsub(&quot;T.*&quot;;&quot;&quot;) ==  &quot;2023-01-08&quot;)))&#39;\r\n\r\n[\r\n  {\r\n    &quot;comment_count&quot;: 0,\r\n    &quot;task_count&quot;: 0,\r\n    &quot;type&quot;: &quot;pullrequest&quot;,\r\n    &quot;id&quot;: 2,\r\n    &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n    &quot;state&quot;: &quot;MERGED&quot;,\r\n    &quot;reason&quot;: &quot;&quot;,\r\n    &quot;created_on&quot;: &quot;2023-01-08T05:17:49.292686+00:00&quot;,\r\n    &quot;updated_on&quot;: &quot;2023-01-08T08:55:02.565205+00:00&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "Unable to filter json output based on date field"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1679760250,
        "creation_date": 1679464257,
        "question_id": 75808800,
        "body_markdown": "I have some json data, where i need to filter the output based on given date field\r\nfrom below json data i need to fetch only the block which satisfy my condition. I tried below but fetching all the fields\r\n`cat json_data | jq &quot;.&quot; | jq &#39;select(.updated_on &gt; 2023-01-17)&#39;`\r\n```\r\n{\r\n  &quot;comment_count&quot;: 0,\r\n  &quot;task_count&quot;: 0,\r\n  &quot;type&quot;: &quot;pullrequest&quot;,\r\n  &quot;id&quot;: 3,\r\n  &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n  &quot;state&quot;: &quot;MERGED&quot;,\r\n  &quot;reason&quot;: &quot;&quot;,\r\n  &quot;created_on&quot;: &quot;2023-02-08T05:17:49.292686+00:00&quot;,\r\n  &quot;updated_on&quot;: &quot;2023-02-08T08:55:02.565205+00:00&quot;\r\n}\r\n{\r\n  &quot;comment_count&quot;: 0,\r\n  &quot;task_count&quot;: 0,\r\n  &quot;type&quot;: &quot;pullrequest&quot;,\r\n  &quot;id&quot;: 2,\r\n  &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n  &quot;state&quot;: &quot;MERGED&quot;,\r\n  &quot;reason&quot;: &quot;&quot;,\r\n  &quot;created_on&quot;: &quot;2023-01-08T05:17:49.292686+00:00&quot;,\r\n  &quot;updated_on&quot;: &quot;2023-01-08T08:55:02.565205+00:00&quot;\r\n}\r\n{\r\n  &quot;comment_count&quot;: 0,\r\n  &quot;task_count&quot;: 0,\r\n  &quot;type&quot;: &quot;pullrequest&quot;,\r\n  &quot;id&quot;: 1,\r\n  &quot;title&quot;: &quot;Fix/adding jacoco&quot;,\r\n  &quot;state&quot;: &quot;MERGED&quot;,\r\n  &quot;reason&quot;: &quot;&quot;,\r\n  &quot;created_on&quot;: &quot;2022-02-08T05:17:49.292686+00:00&quot;,\r\n  &quot;updated_on&quot;: &quot;2022-02-08T08:55:02.565205+00:00&quot;\r\n}",
        "link": "https://stackoverflow.com/questions/75808800/unable-to-filter-json-output-based-on-date-field",
        "title": "Unable to filter json output based on date field"
    },
    {
        "tags": [
            "arrays",
            "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": 0,
                "creation_date": 1679494765,
                "post_id": 75813401,
                "comment_id": 133732295,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20007189,
                    "reputation": 192,
                    "user_id": 14664961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XQBCa.jpg?s=256",
                    "display_name": "Wiseface",
                    "link": "https://stackoverflow.com/users/14664961/wiseface"
                },
                "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": 1679494999,
                "post_id": 75813401,
                "comment_id": 133732369,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1679495129,
                "last_edit_date": 1679495129,
                "creation_date": 1679494706,
                "answer_id": 75813436,
                "question_id": 75813401,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nUse [`any()`][1] to check if *any* of the `demographic` match your logic:\r\n```\r\nselect(.demographic | any(.country == &quot;Spain&quot; and .rating == 7))\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;3DFD4GF&quot;,\r\n  &quot;demographic&quot;: [\r\n    {\r\n      &quot;country&quot;: &quot;Spain&quot;,\r\n      &quot;rating&quot;: 7\r\n    },\r\n    {\r\n      &quot;country&quot;: &quot;Germany&quot;,\r\n      &quot;rating&quot;: 2\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/4k86AVC4G5S)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)",
                "title": "jq select based on two conditions within one child object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679495129,
        "creation_date": 1679494537,
        "last_edit_date": 1679495127,
        "question_id": 75813401,
        "body_markdown": "I have a json file with the following format\r\n```\r\n{&quot;id&quot;: &quot;3DFD4GF&quot;, &quot;demographic&quot;: [{&quot;country&quot;: &quot;Spain&quot;, &quot;rating&quot;: 7},{&quot;country&quot;: &quot;Germany&quot;, &quot;rating&quot;: 2}]}\r\n``` \r\nI want to see each line where `country` is &quot;Canada&quot; and `rating` is 10 in the same object within the `demographic` array\r\n\r\nI tried:\r\n`jq &#39;select((.demographic[].country==&quot;Canada&quot;) and .demographic[].rating==10)&#39; json` \r\n\r\nbut this will return lines where inside the `demographic` array there can be any object containing `&quot;country&quot;: &quot;Canada&quot;` and any object where `&quot;rating&quot;: 10`\r\n\r\nHowever, my goal is to have those two key value pairs in the **same** object\r\n\r\nThe expected output is:\r\n\r\n`{&quot;id&quot;: &quot;454FGF6&quot;, &quot;demographic&quot;: [{&quot;country&quot;: &quot;Germany&quot;, &quot;rating&quot;: 4},{&quot;country&quot;: &quot;Canada&quot;, &quot;rating&quot;: 10}]}`\r\n\r\nHow can I change my query to return the desired result?",
        "link": "https://stackoverflow.com/questions/75813401/jq-select-based-on-two-conditions-within-one-child-object",
        "title": "jq select based on two conditions within one child object"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1679502272,
                "post_id": 75814612,
                "comment_id": 133734672,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1679510768,
                "last_edit_date": 1679510768,
                "creation_date": 1679501718,
                "answer_id": 75814758,
                "question_id": 75814612,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your syntax error is caused by the shell consuming the quotes. When `jq .[].&quot;My$Val&quot;` is parsed by the shell, jq only receives `.[].My` as argument.\r\nWhere did the quotes go? Your shell consumed them.\r\nWhere did `$Val` go? `$` expands a parameter/variable and since `Val` is not defined as variable in your environment, it will be replaced with the empty/null string.\r\n\r\nRead on for a solution to your actual problem, i.e. &quot;how to return &#39;true&#39; or &#39;false&#39;&quot;\r\n\r\n*****\r\n\r\nYou can use `any` to check items in a stream for a condition. If you first stream all leaf objects with `.[][][]`, then you can simply check the `Sub1` property for the expected value:\r\n\r\n```\r\njq &#39;any(.[][][]; .Sub1 == &quot;val2&quot;)&#39;\r\n```\r\n\r\n(Yes, jq is magic.)\r\n\r\n*****\r\n\r\nLonger explanation/example:\r\n\r\n`.[][][]` returns a stream of your innermost objects:\r\n\r\n```\r\n{\r\n  &quot;Sub1&quot;: &quot;val1&quot;,\r\n  &quot;pld&quot;: &quot;s&quot;\r\n}\r\n{\r\n  &quot;Sub1&quot;: &quot;val2&quot;,\r\n  &quot;pld&quot;: &quot;q&quot;\r\n}\r\n```\r\n\r\nSince your outer keys are always `My$Val`, you could use a &quot;stricter&quot; filter too to extract only `My$Val` objects: `.[][&quot;My$Val&quot;][]`\r\n\r\nComplete program with specific key:\r\n\r\n```\r\nany(.[][&quot;My$Val&quot;][]; .Sub1 == &quot;val2&quot;)\r\n```\r\n\r\n*****\r\n\r\nIt is also possible to use the SQL-like `IN` operator to check if a stream of values contains a value:\r\n\r\n```\r\nIN(.[][&quot;My$Val&quot;][].Sub1; &quot;val2&quot;)\r\n```\r\n\r\n(`IN` itself is internally implemented using `any`)",
                "title": "JQ see if a value exists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679510768,
        "creation_date": 1679500815,
        "question_id": 75814612,
        "body_markdown": "Having a JSON object like:\r\n\r\n    [{&quot;My$Val&quot;:[{&quot;Sub1&quot;:&quot;val1&quot;, &quot;pld&quot;:&quot;s&quot;}]},{&quot;My$Val&quot;:[{&quot;Sub1&quot;:&quot;val2&quot;, &quot;pld&quot;:&quot;q&quot;}]}]\r\n\r\nWhat I would like to do using jq, is see if there exists any key of Sub1, that contains the value val2.\r\n\r\nSo in the above JSON-document, the output should yield true.\r\n\r\nI&#39;ve been trying a bit but I do not have a solid grasp on jq yet. Trying to build it step by step I am getting a syntax error when I try to get the values on Sub1.\r\n\r\n     echo &#39;[{&quot;My$Val&quot;:[{&quot;Sub1&quot;:&quot;val1&quot;, &quot;pld&quot;:&quot;s&quot;}]},{&quot;My$Val&quot;:[{&quot;Sub1&quot;:&quot;val2&quot;, &quot;pld&quot;:&quot;q&quot;}]}]&#39; | jq .[].&quot;My$Val&quot;.[].&quot;Sub1&quot;\r\n\r\n Error:\r\n\r\n     jq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n            .[].My.[].Sub1    \r\n\r\n   \r\n        jq: 1 compile error",
        "link": "https://stackoverflow.com/questions/75814612/jq-see-if-a-value-exists",
        "title": "JQ see if a value exists"
    }
]