[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1683501613,
                "post_id": 76196662,
                "comment_id": 134372344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1683509798,
                "last_edit_date": 1683509798,
                "creation_date": 1683502090,
                "answer_id": 76196692,
                "question_id": 76196662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the proper tool: [`jq`](https://github.com/stedolan/jq):\r\n\r\n    jq &#39;[ .[], &quot;inputstring&quot; ]&#39; file\r\n\r\n&lt;p&gt;\r\n\r\n    [\r\n      &quot;data1&quot;,\r\n      &quot;data2&quot;,\r\n      &quot;data(n)&quot;,\r\n      &quot;inputstring&quot;\r\n    ]\r\n\r\nTo edit _in place_:\r\n\r\n    jq &#39;[ .[], &quot;inputstring&quot; ]&#39; file | sponge file",
                "title": "Append to Json files with Search and Replace using RipGrep and Sed"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1683502907,
                "creation_date": 1683502907,
                "answer_id": 76196728,
                "question_id": 76196662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `+=` to update the array. Also, use `--arg` to import a string from outside jq.\r\n```sh\r\njq --arg s &#39;inputstring&#39; &#39;. += [$s]&#39; file.json\r\n```\r\n```json\r\n[\r\n  &quot;data1&quot;,\r\n  &quot;data2&quot;,\r\n  &quot;data(n)&quot;,\r\n  &quot;inputstring&quot;\r\n]\r\n```",
                "title": "Append to Json files with Search and Replace using RipGrep and Sed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1683581174,
                "creation_date": 1683581174,
                "answer_id": 76204467,
                "question_id": 76196662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Solution to my case based on the kind answers. I couldn&#39;t use `sponge` command and was using `find` this time:\r\n````\r\nfind path/to/folder -type f -name &quot;settings.json&quot; -exec sh -c &#39;jq --argjson s &quot;[\\&quot;inputstring\\&quot;]&quot; &quot;. += \\$s&quot; &quot;{}&quot; | cat &gt; tmp &amp;&amp; mv tmp &quot;{}&quot;&#39; \\;\r\n````",
                "title": "Append to Json files with Search and Replace using RipGrep and Sed"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1683597201,
                "creation_date": 1683597201,
                "answer_id": 76205368,
                "question_id": 76196662,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Under some circumstances, it might make sense to use standard *nix tools. If that is the case, I&#39;d go for simplicity, e.g. in your case:\r\n```\r\nawk -v s=&quot;inputstring&quot; &#39;/^  *.*[^,]$/ {print $0 &quot;,&quot;; print &quot;  \\&quot;&quot; s &quot;\\&quot;&quot;; next;} {print}&#39;\r\n```",
                "title": "Append to Json files with Search and Replace using RipGrep and Sed"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": -1,
        "last_activity_date": 1683597201,
        "creation_date": 1683501508,
        "last_edit_date": 1683559128,
        "question_id": 76196662,
        "body_markdown": "It&#39;s not really append what I&#39;m looking for  but because I had future noobs in mind, I took the liberty of including it in the title.  \r\n\r\nI am looking to search for/capture a line-ending `&quot;` and a `]` in the next line (end of file) in json files (many of them). I am using multiline option in ripgrep and forwarding the list of results to be replaced with sed. Running a sole rg without -l lists my results without problems. The problem is with the sed part.  \r\n\r\n````\r\ncd path/to/folder\r\nrg -l --multiline &#39;(&quot;)(\\n\\])&#39; regex/to/path/to/folders/settings.json | xargs sed -i &#39;s/\\(&quot;\\)\\(\\n\\]\\)/\\1,\\nInputString\\n\\2/&#39; *.json\r\n````\r\n- I am searching recursively in multiple folders (the regex is correct as I used it for other replacements including git).  \r\n\r\nWhat I want is to put a comma after the comma-less line (with the captured quote at the end), put in a new line, put in a string (I&#39;ll handle the spaces and quotes myself), another new line and a `]` to close the json settings files. \r\n\r\nSample:  \r\n```\r\n[\r\n  &quot;data1&quot;,\r\n  &quot;data2&quot;,\r\n  &quot;data(n)&quot;\r\n]\r\n```\r\n\r\nDesired result:  \r\n```\r\n[\r\n  &quot;data1&quot;,\r\n  &quot;data2&quot;,\r\n  &quot;data(n)&quot;,\r\n  &quot;inputstring&quot;\r\n]\r\n```\r\n\r\nNo matter how I tried, I couldn&#39;t make it work. The `*.json` at the end is probably superfluous, just as the brackets in the rg command part. But these are not the problem. What is the problem? Am I missing a sed option/flag? Is there some character that needs to be escaped? Maybe the syntax with the groups in the replacements? \r\n",
        "link": "https://stackoverflow.com/questions/76196662/append-to-json-files-with-search-and-replace-using-ripgrep-and-sed",
        "title": "Append to Json files with Search and Replace using RipGrep and Sed"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 351433,
                    "reputation": 16555,
                    "user_id": 687901,
                    "user_type": "registered",
                    "accept_rate": 59,
                    "profile_image": "https://www.gravatar.com/avatar/514e858fbe3c3465fc1f01970317f65b?s=256&d=identicon&r=PG",
                    "display_name": "philipp",
                    "link": "https://stackoverflow.com/users/687901/philipp"
                },
                "reply_to_user": {
                    "account_id": 8497034,
                    "reputation": 1634,
                    "user_id": 6394109,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/g0WEX.png?s=256",
                    "display_name": "Ram Chander",
                    "link": "https://stackoverflow.com/users/6394109/ram-chander"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683542410,
                "post_id": 76199666,
                "comment_id": 134377488,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1683541849,
                "creation_date": 1683541849,
                "answer_id": 76199699,
                "question_id": 76199666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of using `?` or other operators, using `getpath/1` is one option, where you can just filter paths and get their value\r\n\r\n```none\r\n[ getpath(paths | select(.[-1] == &quot;file&quot; or .[-1] == &quot;dev&quot;)) ]\r\n```\r\n\r\nOr even combine with another condition to check for `source` key, if you want to be completely sure i.e. `.[-2] == &quot;source&quot;`\r\n\r\nDemo - https://jqplay.org/s/IddhVIbUenj",
                "title": "How to filter by key"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1683543461,
                "creation_date": 1683543461,
                "answer_id": 76199891,
                "question_id": 76199666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can traverse to `.file` and `.dev` at once using `.source | .file, .dev` or `.source[&quot;file&quot;, &quot;dev&quot;]`, then filter out null values using `values` (not `?`).\r\n```sh\r\nmap(.source | .file, .dev | values)\r\n# or\r\nmap(.source[&quot;file&quot;, &quot;dev&quot;] | values)\r\n```\r\n```json\r\n[\r\n  &quot;test&quot;,\r\n  &quot;foo&quot;\r\n]\r\n```",
                "title": "How to filter by key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683615709,
                "creation_date": 1683615709,
                "answer_id": 76206641,
                "question_id": 76199666,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another option using `tostream` that will essentially descend to any depth and extract the values of the `&quot;file&quot;` or `&quot;dev&quot;` key.\r\n```lang-jq\r\n[ tostream | select(.[1] and (.[0][-1] | IN(&quot;file&quot;, &quot;dev&quot;))) | .[1] ]\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/-O9PUezKfWs &quot;Click me!&quot;).",
                "title": "How to filter by key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1683615709,
        "creation_date": 1683541590,
        "last_edit_date": 1683557113,
        "question_id": 76199666,
        "body_markdown": "I have this sort of json:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;source&quot;: \r\n        {\r\n            &quot;file&quot;: &quot;test&quot;,\r\n            &quot;baz&quot;: &quot;now&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;source&quot;: {\r\n            &quot;dev&quot;: &quot;foo&quot;\r\n        }\r\n    },\r\n    \r\n    {\r\n        &quot;source&quot;: {\r\n            &quot;bar&quot;: &quot;bar&quot;\r\n        }\r\n    }\r\n]\r\n```\r\n\r\nand I would like to get a list of all values for `file` or `dev`. So the expected outcome of the above should be: `[&quot;test&quot;, &quot;foo&quot;]`\r\n\r\nI am stuck somewhere here:\r\n\r\n```\r\n.[].source | select(.file? or .dev?)\r\n```\r\n\r\nBut that yield the complete objects. How to access only the attribute values than??",
        "link": "https://stackoverflow.com/questions/76199666/how-to-filter-by-key",
        "title": "How to filter by key"
    },
    {
        "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": 1683624744,
                "post_id": 76207747,
                "comment_id": 134391500,
                "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": 1683625095,
                "post_id": 76207747,
                "comment_id": 134391567,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 284236,
                    "reputation": 2464,
                    "user_id": 582206,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9242ef14d422ef65d3a80263e5225572?s=256&d=identicon&r=PG",
                    "display_name": "LHMathies",
                    "link": "https://stackoverflow.com/users/582206/lhmathies"
                },
                "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": 1683628681,
                "post_id": 76207747,
                "comment_id": 134392450,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683629065,
                "creation_date": 1683629065,
                "answer_id": 76208480,
                "question_id": 76207747,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer is that it is indeed a [bug](https://github.com/stedolan/jq/issues/2051) (thanks @pmf), and the workaround of using `del` works just fine (as I showed in the question). (The syntax for `del` also fixes evaluation order, which I tend to get wrong in the `|=` syntax -- `|=` binds tighter than `|`, so adding a something like `| select(...)` on the RHS needs parentheses).",
                "title": "Update-assignment of `empty` only deletes first path"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1683629065,
        "creation_date": 1683624238,
        "question_id": 76207747,
        "body_markdown": "As far as I can understand from the [manual](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment%3A%7C%3D), update-assignment (`|=`) is supposed to assign the RHS to every path on the LHS, and if the RHS is `empty` it should delete the path. But as seen below, it only deletes the first path, while `del` and update-assignment of a plain value do update all the paths.\r\n\r\n    $ jq --version\r\n    jq-1.6\r\n    $ echo &#39;[1, 2]&#39; | jq -c &#39;del(.[])&#39;\r\n    []\r\n    $ echo &#39;[1, 2]&#39; | jq -c &#39;.[] |= 0&#39;\r\n    [0,0]\r\n    $ echo &#39;[1, 2]&#39; | jq -c &#39;.[] |= empty&#39;\r\n    [2]\r\n\r\nWhat did I miss, or is it a bug I should report? (I did check related issues here as well as jq&#39;s bugtracker, but only found issues relating to `try`/`catch`).",
        "link": "https://stackoverflow.com/questions/76207747/update-assignment-of-empty-only-deletes-first-path",
        "title": "Update-assignment of `empty` only deletes first path"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "data-conversion",
            "gsutil"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683640230,
                "last_edit_date": 1683640230,
                "creation_date": 1683639046,
                "answer_id": 76209913,
                "question_id": 76209557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;ve no idea how you&#39;d use `jq` to parse regular text to turn it into JSON or if that&#39;s even something `jq` is designed to do but here&#39;s a **start** using `awk` to just handle the input/output you show:\r\n\r\n    $ cat tst.awk\r\n    /^[^[:space:]]/ { if (NR&gt;1) prtRec() }\r\n    { rec = rec $0 RS }\r\n    END { prtRec(); print &quot;&quot; }\r\n    \r\n    function prtRec(        lines,numLines,lineNr,line,tag,val,depth) {\r\n        printf &quot;%s&quot;, recSep\r\n        recSep = &quot;,&quot; ORS\r\n    \r\n        print &quot;{&quot;\r\n    \r\n        numLines = split(rec,lines,RS) - 1\r\n        for ( lineNr=1; lineNr&lt;=numLines; lineNr++ ) {\r\n            line = lines[lineNr]\r\n            gsub(/^[[:space:]]+|[[:space:]]+$/,&quot;&quot;,line)\r\n            tag = val = line\r\n            if ( lineNr == 1 ) {\r\n                tag = &quot;Key&quot;\r\n                sub(/:$/,&quot;&quot;,val)\r\n            }\r\n            else {\r\n                sub(/[[:space:]]*:.*/,&quot;&quot;,tag)\r\n                sub(/[^:]+:[[:space:]]*/,&quot;&quot;,val)\r\n            }\r\n            printf &quot;  \\&quot;%s\\&quot;: \\&quot;%s\\&quot;%s\\n&quot;, tag, val, (lineNr&lt;numLines ? &quot;,&quot; : &quot;&quot;)\r\n        }\r\n    \r\n        printf &quot;}&quot;\r\n    \r\n        rec = &quot;&quot;\r\n    }\r\n\r\n&lt;p&gt;\r\n\r\n    $ awk -f tst.awk file\r\n    {\r\n      &quot;Key&quot;: &quot;gs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip&quot;,\r\n      &quot;Creation time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n      &quot;Update time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n      &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n      &quot;Content-Length&quot;: &quot;0&quot;,\r\n      &quot;Content-Type&quot;: &quot;application/zip&quot;,\r\n      &quot;Hash (crc32c)&quot;: &quot;AAAAAA==&quot;,\r\n      &quot;Hash (md5)&quot;: &quot;1B2M2Y8AsgTpgAmY7PhCfg==&quot;,\r\n      &quot;ETag&quot;: &quot;CM30q9XCivwCEAE=&quot;,\r\n      &quot;Generation&quot;: &quot;1671619167320653&quot;,\r\n      &quot;Metageneration&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;gs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L&quot;,\r\n      &quot;Creation time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n      &quot;Update time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n      &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n      &quot;Content-Disposition&quot;: &quot;inline; filename=James_INGREDIENTS_A3.pdf&quot;,\r\n      &quot;Content-Length&quot;: &quot;4381797&quot;,\r\n      &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n      &quot;Hash (crc32c)&quot;: &quot;GOzitA==&quot;,\r\n      &quot;Hash (md5)&quot;: &quot;eUSLC/z70gjDB2WQKIPOuQ==&quot;,\r\n      &quot;ETag&quot;: &quot;CLGPvu+BoP4CEAE=&quot;,\r\n      &quot;Generation&quot;: &quot;1681153781106609&quot;,\r\n      &quot;Metageneration&quot;: &quot;1&quot;\r\n    },\r\n    {\r\n      &quot;Key&quot;: &quot;gs://bucket-test/prova.pdf&quot;,\r\n      &quot;Creation time&quot;: &quot;Mon, 08 May 2023 15:37:26 GMT&quot;,\r\n      &quot;Update time&quot;: &quot;Mon, 08 May 2023 15:40:12 GMT&quot;,\r\n      &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n      &quot;Content-Disposition&quot;: &quot;inline; filename=James_KEY_VISUAL_A3.pdf&quot;,\r\n      &quot;Content-Language&quot;: &quot;ace&quot;,\r\n      &quot;Content-Length&quot;: &quot;15407&quot;,\r\n      &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n      &quot;Metadata&quot;: &quot;&quot;,\r\n      &quot;meta-1&quot;: &quot;prova 1&quot;,\r\n      &quot;meta-2&quot;: &quot;prova 2&quot;,\r\n      &quot;Hash (crc32c)&quot;: &quot;ZIrHPA==&quot;,\r\n      &quot;Hash (md5)&quot;: &quot;oZbD+S8y35spkNozW3hUDA==&quot;,\r\n      &quot;ETag&quot;: &quot;CNDj09OG5v4CEAM=&quot;,\r\n      &quot;Generation&quot;: &quot;1683560246604240&quot;,\r\n      &quot;Metageneration&quot;: &quot;3&quot;\r\n    }\r\n\r\nYou&#39;d just have to modify it to spot the missing `val` on the `Metadata` line and use the increase/decrease of the indent on the subsequent lines to add the necessary additional `{` and `}`.",
                "title": "Convert text from txt file into json using jq tool"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1683654157,
                "last_edit_date": 1683654157,
                "creation_date": 1683640556,
                "answer_id": 76210120,
                "question_id": 76209557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq, you can read in raw text using the `-R` flag, and iterate through the lines using `reduce`. Start out with an empty array `[]`, then, based on the indentation, add a new item, append to the `last` one, or append to `last` one&#39;s `.Metadata` field. Checking the indentation and parsing the line&#39;s content is done using regular expressions with `match` and `capture`, respectively:\r\n```sh\r\njq -Rn &#39;\r\n  reduce (inputs | {\r\n    ind: match(&quot;^\\\\s*&quot;).length,\r\n    cap: capture(&quot;\\\\s*(?&lt;key&gt;.*):(\\\\s+(?&lt;value&gt;.*))?$&quot;)\r\n  }) as {$ind, $cap} ([];\r\n    if $ind == 0 then . + [$cap | {key}]\r\n    elif $ind == 4 then last += ([$cap | select(.key == &quot;Metadata&quot;).value = {}] | from_entries)\r\n    elif $ind == 8 then last.Metadata += ([$cap] | from_entries)\r\n    else . end\r\n  )\r\n&#39;\r\n```\r\nThis creates a valid JSON array (because without the brackets but with commas in between the items, it wouldn&#39;t be valid JSON):\r\n```json\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;gs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip&quot;,\r\n    &quot;Creation time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n    &quot;Update time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n    &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n    &quot;Content-Length&quot;: &quot;0&quot;,\r\n    &quot;Content-Type&quot;: &quot;application/zip&quot;,\r\n    &quot;Hash (crc32c)&quot;: &quot;AAAAAA==&quot;,\r\n    &quot;Hash (md5)&quot;: &quot;1B2M2Y8AsgTpgAmY7PhCfg==&quot;,\r\n    &quot;ETag&quot;: &quot;CM30q9XCivwCEAE=&quot;,\r\n    &quot;Generation&quot;: &quot;1671619167320653&quot;,\r\n    &quot;Metageneration&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;gs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L&quot;,\r\n    &quot;Creation time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n    &quot;Update time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n    &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n    &quot;Content-Disposition&quot;: &quot;inline; filename=James_INGREDIENTS_A3.pdf&quot;,\r\n    &quot;Content-Length&quot;: &quot;4381797&quot;,\r\n    &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n    &quot;Hash (crc32c)&quot;: &quot;GOzitA==&quot;,\r\n    &quot;Hash (md5)&quot;: &quot;eUSLC/z70gjDB2WQKIPOuQ==&quot;,\r\n    &quot;ETag&quot;: &quot;CLGPvu+BoP4CEAE=&quot;,\r\n    &quot;Generation&quot;: &quot;1681153781106609&quot;,\r\n    &quot;Metageneration&quot;: &quot;1&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;gs://bucket-test/prova.pdf&quot;,\r\n    &quot;Creation time&quot;: &quot;Mon, 08 May 2023 15:37:26 GMT&quot;,\r\n    &quot;Update time&quot;: &quot;Mon, 08 May 2023 15:40:12 GMT&quot;,\r\n    &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n    &quot;Content-Disposition&quot;: &quot;inline; filename=James_KEY_VISUAL_A3.pdf&quot;,\r\n    &quot;Content-Language&quot;: &quot;ace&quot;,\r\n    &quot;Content-Length&quot;: &quot;15407&quot;,\r\n    &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n    &quot;Metadata&quot;: {\r\n      &quot;meta-1&quot;: &quot;prova 1&quot;,\r\n      &quot;meta-2&quot;: &quot;prova 2&quot;\r\n    },\r\n    &quot;Hash (crc32c)&quot;: &quot;ZIrHPA==&quot;,\r\n    &quot;Hash (md5)&quot;: &quot;oZbD+S8y35spkNozW3hUDA==&quot;,\r\n    &quot;ETag&quot;: &quot;CNDj09OG5v4CEAM=&quot;,\r\n    &quot;Generation&quot;: &quot;1683560246604240&quot;,\r\n    &quot;Metageneration&quot;: &quot;3&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/drb3Z7WE08a)",
                "title": "Convert text from txt file into json using jq tool"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1683654157,
        "creation_date": 1683636718,
        "question_id": 76209557,
        "body_markdown": "I have a txt file with values obtained by calling the following command recursively: `gsutil ls -r gs://bucket-test/** | while IFS= read -r key; do gsutil stat $key; done`, it looks like this:\r\n```\r\ngs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip:\r\n    Creation time:          Wed, 21 Dec 2022 10:39:27 GMT\r\n    Update time:            Wed, 21 Dec 2022 10:39:27 GMT\r\n    Storage class:          STANDARD\r\n    Content-Length:         0\r\n    Content-Type:           application/zip\r\n    Hash (crc32c):          AAAAAA==\r\n    Hash (md5):             1B2M2Y8AsgTpgAmY7PhCfg==\r\n    ETag:                   CM30q9XCivwCEAE=\r\n    Generation:             1671619167320653\r\n    Metageneration:         1\r\ngs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L:\r\n    Creation time:          Mon, 10 Apr 2023 19:09:41 GMT\r\n    Update time:            Mon, 10 Apr 2023 19:09:41 GMT\r\n    Storage class:          STANDARD\r\n    Content-Disposition:    inline; filename=James_INGREDIENTS_A3.pdf\r\n    Content-Length:         4381797\r\n    Content-Type:           application/pdf\r\n    Hash (crc32c):          GOzitA==\r\n    Hash (md5):             eUSLC/z70gjDB2WQKIPOuQ==\r\n    ETag:                   CLGPvu+BoP4CEAE=\r\n    Generation:             1681153781106609\r\n    Metageneration:         1\r\ngs://bucket-test/prova.pdf:\r\n    Creation time:          Mon, 08 May 2023 15:37:26 GMT\r\n    Update time:            Mon, 08 May 2023 15:40:12 GMT\r\n    Storage class:          STANDARD\r\n    Content-Disposition:    inline; filename=James_KEY_VISUAL_A3.pdf\r\n    Content-Language:       ace\r\n    Content-Length:         15407\r\n    Content-Type:           application/pdf\r\n    Metadata:               \r\n        meta-1:             prova 1\r\n        meta-2:             prova 2\r\n    Hash (crc32c):          ZIrHPA==\r\n    Hash (md5):             oZbD+S8y35spkNozW3hUDA==\r\n    ETag:                   CNDj09OG5v4CEAM=\r\n    Generation:             1683560246604240\r\n    Metageneration:         3\r\n```\r\n\r\nI need to convert the output to json format, splitting by leading spaces and assigning the value present on the first row of each group to the &quot;Key&quot; field, then there may be subfields for example under the &quot;Metadata&quot; value:\r\n```\r\n{\r\n  &quot;Key&quot;: &quot;gs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip&quot;,\r\n  &quot;Creation time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n  &quot;Update time&quot;: &quot;Wed, 21 Dec 2022 10:39:27 GMT&quot;,\r\n  &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n  &quot;Content-Length&quot;: &quot;0&quot;,\r\n  &quot;Content-Type&quot;: &quot;application/zip&quot;,\r\n  &quot;Hash (crc32c)&quot;: &quot;AAAAAA==&quot;,\r\n  &quot;Hash (md5)&quot;: &quot;1B2M2Y8AsgTpgAmY7PhCfg==&quot;,\r\n  &quot;ETag&quot;: &quot;CM30q9XCivwCEAE=&quot;,\r\n  &quot;Generation&quot;: &quot;1671619167320653&quot;,\r\n  &quot;Metageneration&quot;: &quot;1&quot;\r\n},\r\n{\r\n  &quot;Key&quot;: &quot;gs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L&quot;,\r\n  &quot;Creation time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n  &quot;Update time&quot;: &quot;Mon, 10 Apr 2023 19:09:41 GMT&quot;,\r\n  &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n  &quot;Content-Disposition&quot;: &quot;inline; filename=James_INGREDIENTS_A3.pdf&quot;,\r\n  &quot;Content-Length&quot;: &quot;4381797&quot;,\r\n  &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n  &quot;Hash (crc32c)&quot;: &quot;GOzitA==&quot;,\r\n  &quot;Hash (md5)&quot;: &quot;eUSLC/z70gjDB2WQKIPOuQ==&quot;,\r\n  &quot;ETag&quot;: &quot;CLGPvu+BoP4CEAE=&quot;,\r\n  &quot;Generation&quot;: &quot;1681153781106609&quot;,\r\n  &quot;Metageneration&quot;: &quot;1&quot;\r\n},\r\n{\r\n  &quot;Key&quot;: &quot;gs://bucket-test/prova.pdf&quot;,\r\n  &quot;Creation time&quot;: &quot;Mon, 08 May 2023 15:37:26 GMT&quot;,\r\n  &quot;Update time&quot;: &quot;Mon, 08 May 2023 15:40:12 GMT&quot;,\r\n  &quot;Storage class&quot;: &quot;STANDARD&quot;,\r\n  &quot;Content-Disposition&quot;: &quot;inline; filename=James_KEY_VISUAL_A3.pdf&quot;,\r\n  &quot;Content-Language&quot;: &quot;ace&quot;,\r\n  &quot;Content-Length&quot;: &quot;15407&quot;,\r\n  &quot;Content-Type&quot;: &quot;application/pdf&quot;,\r\n  &quot;Metadata&quot;: {\r\n    &quot;meta-1&quot;: &quot;prova 1&quot;,\r\n    &quot;meta-2&quot;: &quot;prova 2&quot;\r\n  },\r\n  &quot;Hash (crc32c)&quot;: &quot;ZIrHPA==&quot;,\r\n  &quot;Hash (md5)&quot;: &quot;oZbD+S8y35spkNozW3hUDA==&quot;,\r\n  &quot;ETag&quot;: &quot;CNDj09OG5v4CEAM=&quot;,\r\n  &quot;Generation&quot;: &quot;1683560246604240&quot;,\r\n  &quot;Metageneration&quot;: &quot;3&quot;\r\n}\r\n```\r\n\r\nI tried with this command for an only group but without success:\r\n`gsutil stat gs://bucket-test/prova.pdf | printf %s &quot;$(cat)&quot; | jq -R -s &#39;split(&quot;\\n&quot;) | map({key: split(&quot;: &quot;)[0], value: split(&quot;: &quot;)[1]})&#39;`\r\n\r\nThe json is converted into an array:\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;gs://spin8-test/prova.pdf:&quot;,\r\n    &quot;value&quot;: null\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Creation time&quot;,\r\n    &quot;value&quot;: &quot;         Mon, 08 May 2023 15:37:26 GMT&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Update time&quot;,\r\n    &quot;value&quot;: &quot;           Mon, 08 May 2023 15:40:12 GMT&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Storage class&quot;,\r\n    &quot;value&quot;: &quot;         STANDARD&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Content-Disposition&quot;,\r\n    &quot;value&quot;: &quot;   inline; filename=James_KEY_VISUAL_A3.pdf&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Content-Language&quot;,\r\n    &quot;value&quot;: &quot;      ace&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Content-Length&quot;,\r\n    &quot;value&quot;: &quot;        15407&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Content-Type&quot;,\r\n    &quot;value&quot;: &quot;          application/pdf&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Metadata&quot;,\r\n    &quot;value&quot;: &quot;              &quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;        meta-1&quot;,\r\n    &quot;value&quot;: &quot;            prova 1&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;        meta-2&quot;,\r\n    &quot;value&quot;: &quot;            prova 2&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Hash (crc32c)&quot;,\r\n    &quot;value&quot;: &quot;         ZIrHPA==&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Hash (md5)&quot;,\r\n    &quot;value&quot;: &quot;            oZbD+S8y35spkNozW3hUDA==&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    ETag&quot;,\r\n    &quot;value&quot;: &quot;                  CNDj09OG5v4CEAM=&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Generation&quot;,\r\n    &quot;value&quot;: &quot;            1683560246604240&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;    Metageneration&quot;,\r\n    &quot;value&quot;: &quot;        3&quot;\r\n  }\r\n]\r\n```\r\n\r\nAny suggestions? Thanks",
        "link": "https://stackoverflow.com/questions/76209557/convert-text-from-txt-file-into-json-using-jq-tool",
        "title": "Convert text from txt file into json using jq tool"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683722680,
                "post_id": 76218573,
                "comment_id": 134409955,
                "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": 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": 1683723158,
                "post_id": 76218573,
                "comment_id": 134410078,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683724075,
                "post_id": 76218573,
                "comment_id": 134410335,
                "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683724712,
                "post_id": 76218573,
                "comment_id": 134410503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683725247,
                "last_edit_date": 1683725247,
                "creation_date": 1683723414,
                "answer_id": 76218698,
                "question_id": 76218573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add `\\(.groups[].name)` in the string literal\r\n\r\nSyntax example with reduced field to keep it simple\r\n```\r\n.objects[] | &quot;\\(.name),\\(.uid),\\(.groups[].name)&quot; \r\n```\r\n\r\n```\r\n&quot;BL_2.2.2.2,network11111&quot;\r\n&quot;BL_2.2.2.2,workrrorxzdg&quot;\r\n```\r\n\r\n\r\n----------\r\n\r\nWith all fields (from OP):\r\n```\r\n.objects[] | &quot;\\(.name),\\(.uid),\\(.type),\\(.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv6-address&quot;),\\(.&quot;nat-settings&quot;.&quot;install-on&quot;),\\(.&quot;nat-settings&quot;.method),\\(.groups[].name)&quot; \r\n```\r\n```\r\n&quot;BL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111&quot;\r\n&quot;BL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,workrrorxzdg&quot;\r\n```\r\n\r\n----------\r\n\r\nOP&#39;s comment, output as a single line:\r\nUse `join()` in the string literal:\r\n```\r\n.objects[] | &quot;\\(.name),\\(.uid),\\(.type),\\(.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv6-address&quot;),\\(.&quot;nat-settings&quot;.&quot;install-on&quot;),\\(.&quot;nat-settings&quot;.method),\\([ .groups[].name ] | join(&quot;,&quot;))&quot; \r\n```\r\n\r\nBut removing the string literal and using `join()` or `@csv` on an array holding your field makes this a lot easier:\r\n```\r\n.objects[] | [ .name, .uid, .type, .groups[].name ] | join(&quot;,&quot;)\r\n```",
                "title": "extract specific values from json data by combining 2 jq command"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1683724369,
                "last_edit_date": 1683724369,
                "creation_date": 1683724178,
                "answer_id": 76218833,
                "question_id": 76218573,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also store it in a variable:\r\n```sh\r\n.objects[] | .groups[].name as $groupsname | [ .name, .uid, .type,\r\n  .&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv6-address&quot;,\r\n  .&quot;nat-settings&quot;.&quot;install-on&quot;, .&quot;nat-settings&quot;.method, $groupsname\r\n] | join(&quot;,&quot;)  # or @csv\r\n```\r\n```csv\r\nBL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111\r\nBL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,workrrorxzdg\r\n```\r\n[Demo](https://jqplay.org/s/Ng87Fe1MZqz)\r\n\r\n----\r\nThe edited output is even simpler: Just iterate over the array:\r\n```sh\r\n.objects[] | [ .name, .uid, .type,\r\n  .&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv4-address&quot;, .&quot;nat-settings&quot;.&quot;ipv6-address&quot;,\r\n  .&quot;nat-settings&quot;.&quot;install-on&quot;, .&quot;nat-settings&quot;.method, .groups[].name\r\n] | join(&quot;,&quot;)  # or @csv\r\n```\r\n```csv\r\nBL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111,workrrorxzdg\r\n```\r\n[Demo](https://jqplay.org/s/mtrloNm1pZT)",
                "title": "extract specific values from json data by combining 2 jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1683725247,
        "creation_date": 1683722553,
        "last_edit_date": 1683724270,
        "question_id": 76218573,
        "body_markdown": "I want to combine below mentioned 2 jq commands to work together in a single jq command.\r\n\r\n**Command 1:**\r\n```\r\njq -r &#39;.objects[] | &quot;\\(.name),\\(.uid),\\(.type),\\(.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv4-address&quot;),\\(.&quot;nat-settings&quot;.&quot;ipv6-address&quot;),\\(.&quot;nat-settings&quot;.&quot;install-on&quot;),\\(.&quot;nat-settings&quot;.method)&quot;&#39;\r\n```\r\n**Command 2:**\r\n```\r\njq -r &#39;.objects[].groups[].name&#39;\r\n```\r\n\r\nI&#39;m able to get output of commands when executed separately but I&#39;m not getting any output after combining both.\r\n\r\n**Combined command that I used:**\r\n\r\n```\r\njq -r &#39;.objects[] | &quot;\\(.name),\\(.uid),\\(.type),\\(.[&quot;ipv4-address&quot;]),\\(.[&quot;nat-settings&quot;][&quot;ipv4-address&quot;]),\\(.[&quot;nat-settings&quot;][&quot;ipv6-address&quot;]),\\(.[&quot;nat-settings&quot;][&quot;install-on&quot;]),\\(.[&quot;nat-settings&quot;][&quot;method&quot;]),\\(.groups[]?.name)&quot;&#39;\r\n```\r\nPlease help me correct this command.\r\n\r\n**Input JSON Code:**\r\n\r\n```\r\n{\r\n  &quot;from&quot; : 1,\r\n  &quot;to&quot; : 1,\r\n  &quot;total&quot; : 1,\r\n  &quot;objects&quot; : [ {\r\n    &quot;uid&quot; : &quot;11c758bf-15d7-47ba-af1a-200ffa171587&quot;,\r\n    &quot;name&quot; : &quot;BL_2.2.2.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;2.2.2.2&quot;,\r\n    &quot;interfaces&quot; : [ ],\r\n    &quot;nat-settings&quot; : {\r\n      &quot;auto-rule&quot; : true,\r\n      &quot;ipv4-address&quot; : &quot;66.66.66.66&quot;,\r\n      &quot;ipv6-address&quot; : &quot;&quot;,\r\n      &quot;hide-behind&quot; : &quot;ip-address&quot;,\r\n      &quot;install-on&quot; : &quot;All&quot;,\r\n      &quot;method&quot; : &quot;hide&quot;\r\n    },\r\n    &quot;groups&quot; : [ {\r\n      &quot;uid&quot; : &quot;eebedbc9-ef19-4c68-91d2-cd6ea3fec11d&quot;,\r\n      &quot;name&quot; : &quot;network11111&quot;,\r\n      &quot;type&quot; : &quot;group&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;members&quot; : [ &quot;11c758bf-15d7-47ba-af1a-200ffa171587&quot; ],\r\n      &quot;groups&quot; : [ ],\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;General/group&quot;,\r\n      &quot;tags&quot; : [ ],\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; : 1683719146105,\r\n          &quot;iso-8601&quot; : &quot;2023-05-10T17:15+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1683719146105,\r\n          &quot;iso-8601&quot; : &quot;2023-05-10T17:15+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;read-only&quot; : false,\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;true&quot;\r\n      }\r\n    }, {\r\n      &quot;uid&quot; : &quot;f04b042d-0a37-4a10-b470-08ca0e18a129&quot;,\r\n      &quot;name&quot; : &quot;workrrorxzdg&quot;,\r\n      &quot;type&quot; : &quot;group&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;members&quot; : [ &quot;11c758bf-15d7-47ba-af1a-200ffa171587&quot; ],\r\n      &quot;groups&quot; : [ ],\r\n      &quot;comments&quot; : &quot;&quot;,\r\n      &quot;color&quot; : &quot;black&quot;,\r\n      &quot;icon&quot; : &quot;General/group&quot;,\r\n      &quot;tags&quot; : [ ],\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; : 1683719351164,\r\n          &quot;iso-8601&quot; : &quot;2023-05-10T17:19+0530&quot;\r\n        },\r\n        &quot;last-modifier&quot; : &quot;admin&quot;,\r\n        &quot;creation-time&quot; : {\r\n          &quot;posix&quot; : 1683719351164,\r\n          &quot;iso-8601&quot; : &quot;2023-05-10T17:19+0530&quot;\r\n        },\r\n        &quot;creator&quot; : &quot;admin&quot;\r\n      },\r\n      &quot;read-only&quot; : false,\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;true&quot;\r\n      }\r\n    } ],\r\n    &quot;comments&quot; : &quot;&quot;,\r\n    &quot;color&quot; : &quot;black&quot;,\r\n    &quot;icon&quot; : &quot;Objects/host&quot;,\r\n    &quot;tags&quot; : [ ],\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; : 1683514434876,\r\n        &quot;iso-8601&quot; : &quot;2023-05-08T08:23+0530&quot;\r\n      },\r\n      &quot;last-modifier&quot; : &quot;admin&quot;,\r\n      &quot;creation-time&quot; : {\r\n        &quot;posix&quot; : 1683514434876,\r\n        &quot;iso-8601&quot; : &quot;2023-05-08T08:23+0530&quot;\r\n      },\r\n      &quot;creator&quot; : &quot;admin&quot;\r\n    },\r\n    &quot;read-only&quot; : false,\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;true&quot;\r\n    }\r\n  } ]\r\n}\r\n```\r\n\r\n**Expected Output:**\r\n\r\n```\r\nBL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111,workrrorxzdg\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76218573/extract-specific-values-from-json-data-by-combining-2-jq-command",
        "title": "extract specific values from json data by combining 2 jq command"
    },
    {
        "tags": [
            "json",
            "pivot-table",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1683773547,
                "creation_date": 1683773547,
                "answer_id": 76223844,
                "question_id": 76223335,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following invocation produces TSV output, as shown:\r\n```\r\njq -r &#39;\r\n  .RECORDS \r\n  | (map(.STAT) | unique) as $statuses\r\n  | reduce .[] as $x (null; .[$x.EXEC_HOST][$x.STAT] += 1)\r\n  | [null, $statuses[]],\r\n     (to_entries[] | [.key, .value[$statuses[]]])\r\n  | @tsv\r\n```\r\n```\r\n\tDONE\tEXIT\tRUN\r\ncompute-node-1\t1\t1\t1\r\ncompute-node-2\t\t\t2\r\n```\r\n\r\nYou can easily tweak the above, e.g. if you want more control over the ordering of the columns.  Also, you might want to use `@csv` instead of `@tsv`, etc....\r\n",
                "title": "Translate non-uniqified json output into a summary table using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1683781035,
        "creation_date": 1683763994,
        "last_edit_date": 1683781035,
        "question_id": 76223335,
        "body_markdown": "I am trying to transform job data from the `LSF` job scheduler into a summary table of hosts and statuses. For example this might be some sample data:\r\n\r\n```\r\n$ bjobs -q normal -a -uall -o &#39;exec_host stat&#39; -json\r\n{\r\n  &quot;COMMAND&quot;:&quot;bjobs&quot;,\r\n  &quot;JOBS&quot;:5,\r\n  &quot;RECORDS&quot;:[\r\n    {\r\n      &quot;EXEC_HOST&quot;:&quot;compute-node-1&quot;,\r\n      &quot;STAT&quot;:&quot;RUN&quot;\r\n    },\r\n    {\r\n      &quot;EXEC_HOST&quot;:&quot;compute-node-1&quot;,\r\n      &quot;STAT&quot;:&quot;DONE&quot;\r\n    },\r\n    {\r\n      &quot;EXEC_HOST&quot;:&quot;compute-node-2&quot;,\r\n      &quot;STAT&quot;:&quot;RUN&quot;\r\n    },\r\n    {\r\n      &quot;EXEC_HOST&quot;:&quot;compute-node-1&quot;,\r\n      &quot;STAT&quot;:&quot;EXIT&quot;\r\n    },\r\n    {\r\n      &quot;EXEC_HOST&quot;:&quot;compute-node-2&quot;,\r\n      &quot;STAT&quot;:&quot;RUN&quot;\r\n    },\r\n```\r\n\r\nAnd I want output that looks like:\r\n\r\n```\r\n                 RUN   DONE   EXIT\r\ncompute-node-1   1     1      1\r\ncompute-node-2   2\r\n\r\n```\r\n\r\nI can accomplish this through some really awkward contortions using `datamash`, but minimizing the workflow to `bjobs` and `jq` would significantly improve maintainability. I&#39;m struggling to come up with the recipe to summarize the unique `EXEC_HOST`/`STAT` values.\r\n\r\nIs there a way within `jq` to summarize this data as above?",
        "link": "https://stackoverflow.com/questions/76223335/translate-non-uniqified-json-output-into-a-summary-table-using-jq",
        "title": "Translate non-uniqified json output into a summary table using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1683830102,
                "creation_date": 1683830102,
                "answer_id": 76230691,
                "question_id": 76230610,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Add each item of the `.users` array to the single `{group}` item. Do it for all items in the `.accounts` array using `map`, and do it in place using an update-assignment `|=`:\r\n```sh\r\njq &#39;.accounts |= map({group} + .users[])&#39; file.json\r\n```\r\n```json\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;group&quot;: 1,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;id&quot;: 1\r\n    },\r\n    {\r\n      &quot;group&quot;: 1,\r\n      &quot;name&quot;: &quot;Jane&quot;,\r\n      &quot;id&quot;: 2\r\n    },\r\n    {\r\n      &quot;group&quot;: 2,\r\n      &quot;name&quot;: &quot;Bob&quot;,\r\n      &quot;id&quot;: 3\r\n    },\r\n    {\r\n      &quot;group&quot;: 2,\r\n      &quot;name&quot;: &quot;Mary&quot;,\r\n      &quot;id&quot;: 3\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/Qm_FVWQ9z6r)",
                "title": "How to flatten a multi-dimension array in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1683830102,
        "creation_date": 1683829376,
        "question_id": 76230610,
        "body_markdown": "I have the following JSON:\r\n```\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;group&quot;: 1,\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;John&quot;,\r\n          &quot;id&quot;: 1\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Jane&quot;,\r\n          &quot;id&quot;: 2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;group&quot;: 2,\r\n      &quot;users&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Bob&quot;,\r\n          &quot;id&quot;: 3\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Mary&quot;,\r\n          &quot;id&quot;: 3\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like the output to look like this:\r\n```\r\n{\r\n  &quot;accounts&quot;: [\r\n    {\r\n      &quot;group&quot;: 1,\r\n      &quot;name&quot;: &quot;John&quot;,\r\n      &quot;id&quot;: 1\r\n    },\r\n    {\r\n      &quot;group&quot;: 1,\r\n      &quot;name&quot;: &quot;Jane&quot;,\r\n      &quot;id&quot;: 2\r\n    },\r\n    {\r\n      &quot;group&quot;: 2,\r\n      &quot;name&quot;: &quot;Bob&quot;,\r\n      &quot;id&quot;: 3\r\n    },\r\n    {\r\n      &quot;group&quot;: 2,\r\n      &quot;name&quot;: &quot;Mary&quot;,\r\n      &quot;id&quot;: 3\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow do I use `jq` to accomplish this?\r\n\r\nI would like an object:\r\n\r\n 1. with the key &quot;accounts&quot;\r\n 2. elements with &quot;group&quot;, &quot;name&quot;, &quot;id&quot;\r\n\r\nSo far I have tried `jq --raw-output &#39;.accounts[].group, .accounts[].users[].name, .accounts[].users[].id&#39;`, but it gives me the following:\r\n```\r\n1\r\n2\r\nJohn\r\nJane\r\nBob\r\nMary\r\n1\r\n2\r\n3\r\n3\r\n```",
        "link": "https://stackoverflow.com/questions/76230610/how-to-flatten-a-multi-dimension-array-in-jq",
        "title": "How to flatten a multi-dimension array in JQ"
    },
    {
        "tags": [
            "json",
            "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": 1683830579,
                "post_id": 76230620,
                "comment_id": 134430588,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8067809,
                    "reputation": 43,
                    "user_id": 6081417,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ea39f989e4fe22433657e25052385adc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cppdev",
                    "link": "https://stackoverflow.com/users/6081417/cppdev"
                },
                "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": 1683834801,
                "post_id": 76230620,
                "comment_id": 134431471,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683835260,
                "last_edit_date": 1683835260,
                "creation_date": 1683831501,
                "answer_id": 76230848,
                "question_id": 76230620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the key names are known, you could pre-define their order in a variable as an array, then use that for the header as well as the columns in each row. `@tsv` will turn arrays into tab-separated text, so make sure to use `jq -r` or `jq --raw-output`.\r\n```sh\r\n[&quot;c&quot;,&quot;d&quot;,&quot;a&quot;,&quot;b&quot;,&quot;e&quot;] as $keys\r\n| $keys, (.data[] | [.[$keys[]]])\r\n| @tsv\r\n```\r\n```\r\nc\td\ta\tb\te\r\n3\t2\t1\t4\t\r\n7\t6\t5\t8\t9\r\n```\r\n[Demo](https://jqplay.org/s/XR1jiQ3ymth)\r\n\r\n---\r\nIf the `&lt;absent&gt;` string was intended to be inserted literally, use `//` to provide an alternative content:\r\n```sh\r\n[&quot;c&quot;,&quot;d&quot;,&quot;a&quot;,&quot;b&quot;,&quot;e&quot;] as $keys\r\n| $keys, (.data[] | [.[$keys[]] | . // &quot;&lt;absent&gt;&quot;])\r\n| @tsv\r\n```\r\n```\r\nc\td\ta\tb\te\r\n3\t2\t1\t4\t&lt;absent&gt;\r\n7\t6\t5\t8\t9\r\n```\r\n[Demo](https://jqplay.org/s/UYBBiAEfAD_3)\r\n\r\n---\r\n&gt; I know column names but there are a lot of columns (about 30) and I don&#39;t want to list all of them in the filters.\r\n\r\nThen scan the keys first, make a `unique` list, drop `c` and `d`, and prepend them. This is your dynamic `$keys` variable.\r\n```sh\r\n.data\r\n| (map(to_entries[].key | select(IN(&quot;c&quot;, &quot;d&quot;) | not)) | [&quot;c&quot;,&quot;d&quot;] + unique) as $keys\r\n| $keys, (.[] | [.[$keys[]] | . // &quot;&lt;absent&gt;&quot;])\r\n| @tsv\r\n```\r\n```\r\nc\td\ta\tb\te\r\n3\t2\t1\t4\t&lt;absent&gt;\r\n7\t6\t5\t8\t9\r\n```\r\n[Demo](https://jqplay.org/s/jsJATziEMhC)\r\n",
                "title": "Transform JSON into a table and arrange columns in a special manner using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1683908165,
                "last_edit_date": 1683908165,
                "creation_date": 1683907847,
                "answer_id": 76238171,
                "question_id": 76230620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n.data\r\n| [&quot;c&quot;,&quot;d&quot;] as $cd\r\n| ($cd + (add|keys - $cd)) as $keys\r\n| $keys, [.[][$keys[]] // &quot;&lt;absent&gt;&quot;]\r\n| @tsv\r\n```",
                "title": "Transform JSON into a table and arrange columns in a special manner using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1683908165,
        "creation_date": 1683829449,
        "last_edit_date": 1683860148,
        "question_id": 76230620,
        "body_markdown": "There is JSON like below:\r\n\r\n```\r\n{\r\n    &quot;data&quot;: [\r\n        {\r\n            &quot;a&quot;: 1,\r\n            &quot;d&quot;: 2,\r\n            &quot;c&quot;: 3,\r\n            &quot;b&quot;: 4\r\n        },\r\n        {\r\n            &quot;a&quot;: 5,\r\n            &quot;d&quot;: 6,\r\n            &quot;c&quot;: 7,\r\n            &quot;b&quot;: 8,\r\n            &quot;e&quot;: 9\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI want to transform it to the table like this:\r\n```\r\nc\td\ta\tb\te\r\n3\t2\t1\t4\t&lt;absent&gt;\r\n7\t6\t5\t8\t9\r\n```\r\n\r\nSo:\r\n- Columns `c` and `d` are moved to the beginning of the table;\r\n- All other columns are sorted alphabetically.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76230620/transform-json-into-a-table-and-arrange-columns-in-a-special-manner-using-jq",
        "title": "Transform JSON into a table and arrange columns in a special manner using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1683889084,
                "post_id": 76235231,
                "comment_id": 134439124,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19642851,
                    "reputation": 174,
                    "user_id": 14378530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/83cb86cebbb24605caaefb544ce07705?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Burps",
                    "link": "https://stackoverflow.com/users/14378530/burps"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684138947,
                "post_id": 76235231,
                "comment_id": 134467410,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683886685,
                "creation_date": 1683886685,
                "answer_id": 76235305,
                "question_id": 76235231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First iterare over the array, then select by criteria:\r\n```sh\r\njq -r &#39;.data.system[] | select(.login == &quot;vault keystore password&quot;).password&#39;\r\n\r\n# or by importing a string from outside dynamically\r\n\r\njq -r --arg login &quot;vault keystore password&quot; &#39;\r\n  .data.system[] | select(.login == $login).password\r\n&#39;\r\n```\r\n```\r\n123456\r\n```",
                "title": "Select with a string containing spaces using map_values not working as expected"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1683892849,
                "last_edit_date": 1683892849,
                "creation_date": 1683886968,
                "answer_id": 76235343,
                "question_id": 76235231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using just `map(select(..))` will solve your problem.\r\n\r\n```none\r\n.data.system | map(select(.login == &quot;vault keystore password&quot;))[].password\r\n```\r\n\r\nBy the official docs, using `map_values()` should also work. For some reason `jq` (jq-1.6) is misbehaving (possibly a bug) while using for this filter. The same filter works well with [gojq][1]. \r\n\r\nPer [builtin.jq][2], `map_values(..)` is just \r\n\r\n```none\r\ndef map_values(f): .[] |= f;\r\n```\r\n\r\nso essentially, your filter comes down to \r\n\r\n```\r\n.data.system[] |= select(.login == &quot;vault keystore password&quot;)\r\n```\r\n\r\nwhich is producing 3 objects inside the list `system`, which is incorrect. On the other hand `gojq` handles it correctly. I would argue the whole issue is around the update assignment operator of `jq` (i.e. `|=`), which is known to have caused issues in the past. See https://github.com/stedolan/jq/issues/2051\r\n\r\n`jq` has been stuck in a release limbo for a while now (https://github.com/stedolan/jq/issues/2305). So until the time a new release &gt; 1.6 comes along, `gojq` would be an ideal replacement with much of the known issues fixed (those of jq).\r\n\r\n---\r\nOn `gojq` version 0.12.12\r\n\r\n```bash\r\necho &#39;{&quot;data&quot;:{&quot;system&quot;:[{&quot;login&quot;:&quot;vault keystore password&quot;,&quot;password&quot;:&quot;123456&quot;},{&quot;login&quot;:&quot;vault keystore masked&quot;,&quot;password&quot;:&quot;MASK-789101112&quot;},{&quot;login&quot;:&quot;vault salt&quot;,&quot;password&quot;:&quot;toto&quot;},{&quot;login&quot;:&quot;vault iteration&quot;,&quot;password&quot;:&quot;10&quot;},{&quot;login&quot;:&quot;keystore Alias&quot;,&quot;password&quot;:&quot;vault&quot;}]}}&#39; |\r\n  gojq &#39;.data.system | map_values(select(.login == &quot;vault keystore password&quot;))[].password&#39; \r\n```\r\nproduces\r\n\r\n```\r\n&quot;123456&quot;\r\n```\r\n\r\n\r\n  [1]: https://github.com/itchyny/gojq\r\n  [2]: https://github.com/stedolan/jq/blob/master/src/builtin.jq#L33",
                "title": "Select with a string containing spaces using map_values not working as expected"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1683888411,
                "last_edit_date": 1683888411,
                "creation_date": 1683887700,
                "answer_id": 76235435,
                "question_id": 76235231,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do:\r\n\r\n    .data.system | .[] |select(.login==&quot;vault keystore password&quot;).password\r\n\r\n[Demo][1]\r\n\r\nOr as a jq command line:\r\n\r\n    jq -r &#39;.data.system | .[] |select(.login==&quot;vault keystore password&quot;).password&#39; \r\n\r\nOr you can use ruby:\r\n\r\n    ruby -r json -e &#39;JSON.parse($&lt;.read)[&quot;data&quot;][&quot;system&quot;].\r\n        select{|h| h[&quot;login&quot;]==&quot;vault keystore password&quot;}.\r\n        each{|h| puts h[&quot;password&quot;]}&#39; \r\n\r\nEither of those, given JSON on STDIN or as a file prints `123456` on STDOUT.\r\n\r\n\r\n  [1]: https://jqplay.org/s/NPtsX6_gJ7P",
                "title": "Select with a string containing spaces using map_values not working as expected"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1684139219,
        "creation_date": 1683886072,
        "last_edit_date": 1684139219,
        "question_id": 76235231,
        "body_markdown": "I have the following dataset :\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;system&quot;: [\r\n      {\r\n        &quot;login&quot;: &quot;vault keystore password&quot;,\r\n        &quot;password&quot;: &quot;123456&quot;\r\n      },\r\n      {\r\n        &quot;login&quot;: &quot;vault keystore masked&quot;,\r\n        &quot;password&quot;: &quot;MASK-789101112&quot;\r\n      },\r\n      {\r\n        &quot;login&quot;: &quot;vault salt&quot;,\r\n        &quot;password&quot;: &quot;toto&quot;\r\n      },\r\n      {\r\n        &quot;login&quot;: &quot;vault iteration&quot;,\r\n        &quot;password&quot;: &quot;10&quot;\r\n      },\r\n      {\r\n        &quot;login&quot;: &quot;keystore Alias&quot;,\r\n        &quot;password&quot;: &quot;vault&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI want to retrieve in my shell the password when login is &quot;vault keystore password&quot;.\r\n\r\n\r\n\r\nThe closest that I have found is :\r\n`.data.system |map_values(select(.login == &quot;vault keystore password&quot;))[].password`\r\nbut it returns me not the expected output (I wanted `123456`):\r\n```\r\n&quot;123456&quot;\r\n&quot;toto&quot;\r\n&quot;vault&quot;\r\n```\r\n\r\nCould you please explain me the correct syntax ?",
        "link": "https://stackoverflow.com/questions/76235231/select-with-a-string-containing-spaces-using-map-values-not-working-as-expected",
        "title": "Select with a string containing spaces using map_values not working as expected"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1683899471,
                "creation_date": 1683899471,
                "answer_id": 76236998,
                "question_id": 76236956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do it in two stages. Use a variable placeholder for the state name and use it again while matching the array of entries inside `xls`\r\n\r\n```none\r\n.form.state as $c | .xls[] | select(.state == $c).city\r\n```\r\n\r\nYour attempt doesn&#39;t work, because once you descend into the `xls` leaf path, there is no way to get the value of `.form.state`, unless you store it in a variable.\r\n\r\nhttps://jqplay.org/s/SSkOvKywcUa",
                "title": "JQ Expression to filter inside array with field outside the array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1683899471,
        "creation_date": 1683899229,
        "question_id": 76236956,
        "body_markdown": "My JSON is like so:\r\n\r\n```\r\n{\r\n    &quot;form&quot; : {\r\n        &quot;state&quot; : &quot;MH&quot;\r\n    },\r\n    &quot;xls&quot;:[\r\n        {\r\n            &quot;state&quot;: &quot;MH&quot;,\r\n            &quot;channel&quot; : 1,\r\n            &quot;city&quot;: &quot;Pune&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;MH&quot;,\r\n            &quot;channel&quot; : 1,\r\n            &quot;city&quot;: &quot;Nashik&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;MH&quot;,\r\n            &quot;channel&quot; : 2,\r\n            &quot;city&quot;: &quot;Solapur&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;MH&quot;,\r\n            &quot;channel&quot; : 2,\r\n            &quot;city&quot;: &quot;Nagpur&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;KAR&quot;,\r\n            &quot;channel&quot; : 1,\r\n            &quot;city&quot;: &quot;Mysore&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;KAR&quot;,\r\n            &quot;channel&quot; : 1,\r\n            &quot;city&quot;: &quot;Bijapur&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;KAR&quot;,\r\n            &quot;channel&quot; : 2,\r\n            &quot;city&quot;: &quot;Bellary&quot;\r\n        },{\r\n            &quot;state&quot;: &quot;KAR&quot;,\r\n            &quot;channel&quot; : 2,\r\n            &quot;city&quot;: &quot;Mangalore&quot;\r\n        }\r\n    \r\n    ]\r\n    \r\n    \r\n}\r\n```\r\n\r\nNow, I want to find all the cities inside the xls array where the value is equal to form.state. I want to create a jq expression which can do this.\r\n\r\nI tried :\r\n\r\n```\r\n    .xls[] | select(.state == .form.state) | .city\r\n\r\n```\r\n\r\nBut this wont work since .form.state is outside. \r\n\r\nI don&#39;t really want to pass arguments to my JQ expression. Is there any neat way to do this?",
        "link": "https://stackoverflow.com/questions/76236956/jq-expression-to-filter-inside-array-with-field-outside-the-array",
        "title": "JQ Expression to filter inside array with field outside the array"
    },
    {
        "tags": [
            "json",
            "csv",
            "gitlab",
            "jq"
        ],
        "comments": [
            {
                "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": 1683947201,
                "post_id": 76240669,
                "comment_id": 134448718,
                "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": 1683958752,
                "post_id": 76240669,
                "comment_id": 134449439,
                "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": 1683958943,
                "post_id": 76240669,
                "comment_id": 134449459,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1683968722,
                "last_edit_date": 1683968722,
                "creation_date": 1683959327,
                "answer_id": 76241387,
                "question_id": 76240669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You seem to be confused about the usage of [`.` (object identifier-index)](https://stedolan.github.io/jq/manual/v1.6/#ObjectIdentifier-Index:.foo,.foo.bar), [`,` (comma)](https://stedolan.github.io/jq/manual/v1.6/#Comma:,), and [`|` (pipe)](https://stedolan.github.io/jq/manual/v1.6/#Pipe:|).\r\n\r\nIf you want to access the `package` of the following JSON object:\r\n\r\n```json\r\n{\r\n  &quot;location&quot;: {\r\n    &quot;dependency&quot;: {\r\n      &quot;package&quot;: {\r\n        &quot;name&quot;: &quot;audit-libs&quot;\r\n      },\r\n      &quot;version&quot;: &quot;2.8.5-4.el7&quot;\r\n    },\r\n    &quot;operating_system&quot;: &quot;Unknown&quot;,\r\n    &quot;image&quot;: &quot;image.tar&quot;\r\n  }\r\n}\r\n```\r\n\r\nthe syntax is `.location | .dependency | .package` or `.location.dependency.package` (but not `.location, .dependency, .package`; the latter is a stream of 3 properties all from the same level in your JSON).\r\n\r\nElements of an array are accessed with `[0]` and not with `.0` (`.0` is the decimal number `0.0`).\r\n\r\n*****\r\n\r\nNow, if you want CSV, it is easier to use the builtin `@csv` filter. You don&#39;t need that `echo` for the headers either, `jq` can add the headers just fine:\r\n\r\n```\r\n[&quot;id&quot;, &quot;message&quot;, &quot;description&quot;, &quot;severity&quot;, &quot;name&quot;, &quot;version&quot;, &quot;identifiers&quot;],\r\n(\r\n    .vulnerabilities[]\r\n    | [\r\n      .id,\r\n      .message,\r\n      .description,\r\n      .severity,\r\n      (.location.dependency | .package.name, .version),\r\n      (.identifiers[0] | .type, .name, .value, .url)\r\n    ]\r\n) | @csv\r\n```\r\n\r\n(Raw) output:\r\n\r\n```csv\r\n&quot;id&quot;,&quot;message&quot;,&quot;description&quot;,&quot;severity&quot;,&quot;name&quot;,&quot;version&quot;,&quot;identifiers&quot;\r\n&quot;CVE-2015-5186&quot;,&quot;Audit: log terminal emulator escape sequences handling&quot;,&quot;Audit before 2.4.4 in Linux does not sanitize escape characters in filenames.&quot;,&quot;Medium&quot;,&quot;audit-libs&quot;,&quot;2.8.5-4.el7&quot;,&quot;cve&quot;,&quot;CVE-2015-5186&quot;,&quot;CVE-2015-5186&quot;,&quot;example.com&quot;\r\n```\r\n\r\nFurther reading: https://stackoverflow.com/questions/32960857/how-to-convert-arbitrary-simple-json-to-csv-using-jq",
                "title": "Convert JSON from Gitlab to CSV with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1683968722,
        "creation_date": 1683939915,
        "question_id": 76240669,
        "body_markdown": "I am currently trying to create a json convert job in gitlab and I am running into issues with jq.\r\n\r\nThe following is the output from gitlab after doing container scanning and I am trying to convert it to a csv by using jq to get the information I want.\r\n\r\nThis is so I can include a readable csv as a build artifact.\r\n\r\n\r\n```json\r\n&quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;CVE-2015-5186&quot;,\r\n      &quot;category&quot;: &quot;container_scanning&quot;,\r\n      &quot;message&quot;: &quot;Audit: log terminal emulator escape sequences handling&quot;,\r\n      &quot;description&quot;: &quot;Audit before 2.4.4 in Linux does not sanitize escape characters in filenames.&quot;,\r\n      &quot;cve&quot;: &quot;CVE-2015-5186&quot;,\r\n      &quot;severity&quot;: &quot;Medium&quot;,\r\n      &quot;solution&quot;: &quot;No solution provided&quot;,\r\n      &quot;scanner&quot;: {\r\n        &quot;id&quot;: &quot;trivy&quot;,\r\n        &quot;name&quot;: &quot;trivy&quot;\r\n      },\r\n      &quot;location&quot;: {\r\n        &quot;dependency&quot;: {\r\n          &quot;package&quot;: {\r\n            &quot;name&quot;: &quot;audit-libs&quot;\r\n          },\r\n          &quot;version&quot;: &quot;2.8.5-4.el7&quot;\r\n        },\r\n        &quot;operating_system&quot;: &quot;Unknown&quot;,\r\n        &quot;image&quot;: &quot;image.tar&quot;\r\n      },\r\n      &quot;identifiers&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;cve&quot;,\r\n          &quot;name&quot;: &quot;CVE-2015-5186&quot;,\r\n          &quot;value&quot;: &quot;CVE-2015-5186&quot;,\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        }\r\n      ],\r\n      &quot;links&quot;: [{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        },{\r\n          &quot;url&quot;: &quot;example.com&quot;\r\n        }\r\n      ]\r\n    }\r\n```\r\n\r\nThe following is my current jq statement and I am not sure what I am missing to make this work. \r\n\r\n```yml\r\n- echo &quot;id, message, description, severity, name, version, identifiers&quot; &gt; $CI_PROJECT_DIR/reports/${IMAGENAME}-trivy.csv\r\n\r\n- jq -r &#39;.vulnerabilities | map([.id, .message, .description, .severity, (.location | .dependency, .package, .name), (.location | .dependency, .version), (.identifiers | .0, .type), (.identifiers | .0, .name), (.identifiers | .0, .value), (.identifiers | .0, .url)] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; $CI_PROJECT_DIR/reports/gl-container-scanning-report.json &gt;&gt; $CI_PROJECT_DIR/reports/${IMAGENAME}-trivy.csv  \r\n\r\n```\r\n\r\nwhich results in\r\n\r\n\r\n```yml\r\n$ jq -r &#39;.vulnerabilities | map([.id, .message, .description, .severity, (.location | .dependency, .package, .name), (.location | .dependency, .version), (.identifiers | .0, .type), (.identifiers | .0, .name), (.identifiers | .0, .value), (.identifiers | .0, .url)] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; $CI_PROJECT_DIR/reports/gl-container-scanning-report.json &gt;&gt; $CI_PROJECT_DIR/reports/${IMAGENAME}-trivy.csv\r\njq: error (at /builds/group/subgroup/project/reports/gl-container-scanning-report.json:34424): Cannot index array with string &quot;type&quot;\r\n```\r\n\r\nI have also tried slightly modifying to remove the identifiers which resulted in this.\r\n\r\n```yml\r\n$ echo &quot;id, message, description, severity, name, version&quot; &gt; $CI_PROJECT_DIR/reports/${IMAGENAME}-trivy.csv\r\n$ jq -r &#39;.vulnerabilities | map([.id, .message, .description, .severity, (.location | .dependency, .package, .name), (.location | .dependency, .version)] | join(&quot;, &quot;)) | join(&quot;\\n&quot;)&#39; $CI_PROJECT_DIR/reports/gl-container-scanning-report.json &gt;&gt; $CI_PROJECT_DIR/reports/${IMAGENAME}-trivy.csv\r\njq: error (at /builds/jdiss/fdtm/galelisten/reports/gl-container-scanning-report.json:34424): string (&quot;CVE-2015-5...) and object ({&quot;package&quot;:...) cannot be added\r\n```\r\n\r\nI am trying to figure out the location stuff so I can get the package name and its version.\r\n\r\nI am also trying to get the identifiers information. \r\n\r\nAny idea what I might be missing?",
        "link": "https://stackoverflow.com/questions/76240669/convert-json-from-gitlab-to-csv-with-jq",
        "title": "Convert JSON from Gitlab to CSV with JQ"
    },
    {
        "tags": [
            "json",
            "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": 1684077273,
                "post_id": 76248117,
                "comment_id": 134460667,
                "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": 1684077629,
                "post_id": 76248117,
                "comment_id": 134460698,
                "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": 1684088731,
                "post_id": 76248117,
                "comment_id": 134462106,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684077357,
                "last_edit_date": 1684077357,
                "creation_date": 1684076985,
                "answer_id": 76248198,
                "question_id": 76248117,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Quotes around both the version string and the whole expression:\r\n\r\n```sh\r\njq -r &#39;.attributes.DeployVersion.default=&quot;0.0.2&quot;&#39;\r\n```\r\n\r\nOr escape the quotes around the version string:\r\n\r\n```sh\r\njq -r .attributes.deployVersion.default=\\&quot;0.0.2\\&quot;\r\n```\r\n\r\nYou could also use `tostring` in a pipe, but it would be unnecessary.",
                "title": "jq Invalid numeric literal at EOF updating json value to 0.0.x"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1684077357,
        "creation_date": 1684076151,
        "question_id": 76248117,
        "body_markdown": "i am trying to update my json file as following\r\n\r\n    jq  .attributes.DeployVersion.default=0.0.1 block.json &gt; t.tmp &amp;&amp; mv t.tmp block.json\r\n\r\nwhich throws an error \r\n\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 5 (while parsing &#39;0.0.0&#39;) at &lt;top-level&gt;, line 1:\r\n    .attributes.DeployVersion.default=0.0.1\r\n\r\nwhile this:\r\n\r\n    jq  .attributes.DeployVersion.default=0.1  block.json &gt; t.tmp &amp;&amp; mv t.tmp block.json\r\n works perfectly (the only difference is instead of 0.0.1 I use 0.1)\r\n\r\ntried quotes, didnt work. \r\n",
        "link": "https://stackoverflow.com/questions/76248117/jq-invalid-numeric-literal-at-eof-updating-json-value-to-0-0-x",
        "title": "jq Invalid numeric literal at EOF updating json value to 0.0.x"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1684154729,
                "last_edit_date": 1684154729,
                "creation_date": 1684154423,
                "answer_id": 76254173,
                "question_id": 76254127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can filter for objects using `select(type == &quot;object&quot;)`, or use its shortcut equivalent `objects`:\r\n```sh\r\n.[] | select(type == &quot;object&quot; and has(&quot;auditScore&quot;))\r\n# or\r\n.[] | objects | select(has(&quot;auditScore&quot;))\r\n```\r\nThis will return a stream of objects having a field named `auditScore`\r\n```json\r\n{\r\n  &quot;auditScore&quot;: 1,\r\n  &quot;suspensionScore&quot;: 1,\r\n  &quot;password&quot;: &quot;value1&quot;,\r\n  &quot;onlineScore&quot;: 0.99743587,\r\n  &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n}\r\n{\r\n  &quot;auditScore&quot;: 1,\r\n  &quot;suspensionScore&quot;: 1,\r\n  &quot;password&quot;: &quot;valueX&quot;,\r\n  &quot;onlineScore&quot;: 0.9992917,\r\n  &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n}\r\n{\r\n  &quot;auditScore&quot;: 1,\r\n  &quot;suspensionScore&quot;: 1,\r\n  &quot;password&quot;: &quot;value72&quot;,\r\n  &quot;onlineScore&quot;: 0.99930555,\r\n  &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n}\r\n```\r\n---\r\nTo set a(nother) field based on that stream, wrap the LHS into parens to keep the context:\r\n```sh\r\n(.[] | select(type == &quot;object&quot; and has(&quot;auditScore&quot;))).password = &quot;X&quot;\r\n# or\r\n(.[] | objects | select(has(&quot;auditScore&quot;))).password = &quot;X&quot;\r\n```",
                "title": "Loop through JSON and retrieve sets when key exists"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684166209,
                "creation_date": 1684166209,
                "answer_id": 76255894,
                "question_id": 76254127,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With Ruby:\r\n\r\n    ruby -r json -e &#39;\r\n    JSON.parse($&lt;.read).select{|k,v| v.is_a?(Hash) &amp;&amp; v.has_key?(&quot;auditScore&quot;)}.\r\n        each{|k,v| puts &quot;Key: #{k} \\nValue: #{v}\\n&quot; }\r\n    &#39; file \r\n\r\nPrints:\r\n\r\n    Key: audit1 \r\n    Value: {&quot;auditScore&quot;=&gt;1, &quot;suspensionScore&quot;=&gt;1, &quot;password&quot;=&gt;&quot;value1&quot;, &quot;onlineScore&quot;=&gt;0.99743587, &quot;satelliteName&quot;=&gt;&quot;us2.storj.io:7777&quot;}\r\n    Key: audit2 \r\n    Value: {&quot;auditScore&quot;=&gt;1, &quot;suspensionScore&quot;=&gt;1, &quot;password&quot;=&gt;&quot;valueX&quot;, &quot;onlineScore&quot;=&gt;0.9992917, &quot;satelliteName&quot;=&gt;&quot;saltlake.tardigrade.io:7777&quot;}\r\n    Key: audit3 \r\n    Value: {&quot;auditScore&quot;=&gt;1, &quot;suspensionScore&quot;=&gt;1, &quot;password&quot;=&gt;&quot;value72&quot;, &quot;onlineScore&quot;=&gt;0.99930555, &quot;satelliteName&quot;=&gt;&quot;ap1.storj.io:7777&quot;}\r\n\r\n\r\n\r\nIf you want to change the password of each:\r\n\r\n    ruby -r json -e &#39;\r\n    puts JSON.pretty_generate(JSON.parse($&lt;.read).\r\n        each{|k,v| if v.is_a?(Hash) &amp;&amp; v.has_key?(&quot;auditScore&quot;) \r\n        then\r\n            v[&quot;password&quot;]=&quot;XXX&quot;\r\n        end\r\n    })\r\n    &#39; file \r\n\r\nPrints:\r\n\r\n    {\r\n      &quot;storageSummary&quot;: &quot;testvalue&quot;,\r\n      &quot;audit1&quot;: {\r\n        &quot;auditScore&quot;: 1,\r\n        &quot;suspensionScore&quot;: 1,\r\n        &quot;password&quot;: &quot;XXX&quot;,\r\n        &quot;onlineScore&quot;: 0.99743587,\r\n        &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n      },\r\n      &quot;audit2&quot;: {\r\n        &quot;auditScore&quot;: 1,\r\n        &quot;suspensionScore&quot;: 1,\r\n        &quot;password&quot;: &quot;XXX&quot;,\r\n        &quot;onlineScore&quot;: 0.9992917,\r\n        &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n      },\r\n      &quot;audit3&quot;: {\r\n        &quot;auditScore&quot;: 1,\r\n        &quot;suspensionScore&quot;: 1,\r\n        &quot;password&quot;: &quot;XXX&quot;,\r\n        &quot;onlineScore&quot;: 0.99930555,\r\n        &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n      }\r\n    }",
                "title": "Loop through JSON and retrieve sets when key exists"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1684229630,
        "creation_date": 1684154124,
        "last_edit_date": 1684229630,
        "question_id": 76254127,
        "body_markdown": "I have the following data: \r\n```\r\n{\r\n   &quot;storageSummary&quot;: &quot;testvalue&quot;,\r\n   &quot;audit1&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;password&quot; : &quot;value1&quot;,\r\n         &quot;onlineScore&quot;: 0.99743587,\r\n         &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n      },\r\n   &quot;audit2&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;password&quot; : &quot;valueX&quot;,\r\n         &quot;onlineScore&quot;: 0.9992917,\r\n         &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n      },\r\n   &quot;audit3&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;password&quot; : &quot;value72&quot;,\r\n         &quot;onlineScore&quot;: 0.99930555,\r\n         &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n      }\r\n}\r\n```\r\n\r\nIn bash, I need to go through this data, to update the `password` for all `auditX` objects. I&#39;ve tried the following: \r\n```\r\njq &#39; .[] |select(has(&quot;auditScore&quot;)) &#39;\r\n```\r\nBut I get an error on the first item: \r\n```\r\njq: error (at &lt;stdin&gt;:23): Cannot check whether string has a string key\r\nexit status 5\r\n```\r\n\r\nWhen I remove the first item `&quot;storageSummary&quot;: &quot;testvalue&quot;`in my data, I can loop through my objects (but my data has some items without `auditscore` keys).\r\n\r\nThe final goal is to run this result in a bash `for` loop to update the password (and do more specific task).\r\n\r\nCould you please point me in the right direction?\r\n",
        "link": "https://stackoverflow.com/questions/76254127/loop-through-json-and-retrieve-sets-when-key-exists",
        "title": "Loop through JSON and retrieve sets when key exists"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684164358,
                "post_id": 76255433,
                "comment_id": 134473345,
                "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": 1684170674,
                "post_id": 76255433,
                "comment_id": 134474901,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1684164430,
                "creation_date": 1684164430,
                "answer_id": 76255631,
                "question_id": 76255433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use:\r\n\r\n```bash\r\n$ jq -r &#39;.change_tasks[] | select(.short_description == &quot;01. Project validation&quot;).description | gsub(&quot;,\\\\s+&quot;;&quot;,&quot;) | split(&quot;,&quot;) | @sh &#39; test.json\r\n&#39;value-01&#39; &#39;value-02&#39;\r\n```\r\n\r\nif you want to read this into two variables:\r\n\r\n```bash\r\nfunction get_values {\r\n    jq -r &#39;.change_tasks[] | select(.short_description == &quot;01. Project validation&quot;).description | gsub(&quot;,\\\\s+&quot;;&quot;,&quot;) | split(&quot;,&quot;) | @sh &#39; test.json\r\n}\r\n\r\nread value1 value2&lt;&lt;&lt;$(get_values)\r\n```",
                "title": "Find objects based on value of a key in object using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684164731,
                "creation_date": 1684164731,
                "answer_id": 76255681,
                "question_id": 76255433,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ended up sorting it myself like this in the end\r\n\r\n```\r\n#!/bin/sh\r\n\r\nvariable=$(jq -r &#39;.change_tasks[] | select(.short_description==&quot;01. Project validation&quot;).description&#39; test.json)\r\n\r\nfor i in ${variable//,/ }\r\ndo\r\n    # call your procedure/other scripts here below\r\n    echo &quot;$i&quot;\r\ndone\r\n````",
                "title": "Find objects based on value of a key in object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1684164731,
        "creation_date": 1684163191,
        "question_id": 76255433,
        "body_markdown": "From the json change_tasks array below I would like to extract only the values of the key &quot;description&quot; when the key:value is an exact match of &quot;short_description&quot;: &quot;01. Project validation&quot;. \r\n\r\n\r\n```\r\n{\r\n\t&quot;change_tasks&quot;: [{\r\n\t\t&quot;active&quot;: &quot;true&quot;,\r\n\t\t&quot;approval&quot;: &quot;Not Yet Requested&quot;, \r\n\t\t&quot;description&quot;: &quot;testing&quot;,\r\n\t\t&quot;short_description&quot;: &quot;Test description&quot;,\r\n\t\t&quot;state&quot;: &quot;-5&quot;,\r\n\t\t&quot;state_description&quot;: &quot;Pending&quot;,\r\n\t\t&quot;sys_class_name&quot;: &quot;Change Task&quot;,\r\n\t\t&quot;sys_created_on&quot;: &quot;2023-05-10 15:23:50&quot;,\r\n\t\t&quot;sys_updated_on&quot;: &quot;2023-05-10 15:25:58&quot;,\r\n\t\t&quot;time_worked&quot;: &quot;&quot;,\r\n\t\t&quot;u_actions_taken_to_prevent_recurrence&quot;: &quot;&quot;,\r\n\t\t&quot;u_createdby_businessappid&quot;: &quot;&quot;\r\n\t}, \r\n\t{\r\n\t\t&quot;active&quot;: &quot;true&quot;,\r\n\t\t&quot;approval&quot;: &quot;Not Yet Requested&quot;,\r\n\t\t&quot;description&quot;: &quot;value-01, value-02&quot;,\r\n\t\t&quot;short_description&quot;: &quot;01. Project validation&quot;,\r\n\t\t&quot;state&quot;: &quot;-5&quot;,\r\n\t\t&quot;state_description&quot;: &quot;Pending&quot;,\r\n\t\t&quot;sys_class_name&quot;: &quot;Change Task&quot;,\r\n\t\t&quot;sys_created_on&quot;: &quot;2023-05-10 15:21:01&quot;,\r\n\t\t&quot;sys_updated_on&quot;: &quot;2023-05-10 15:25:58&quot;,\r\n\t\t&quot;time_worked&quot;: &quot;&quot;,\r\n\t\t&quot;u_actions_taken_to_prevent_recurrence&quot;: &quot;&quot;,\r\n\t\t&quot;u_createdby_businessappid&quot;: &quot;&quot;\r\n\t}],\r\n\t&quot;responseSummary&quot;: {\r\n\t\t&quot;message&quot;: &quot;Search successfully executed&quot;,\r\n\t\t&quot;code&quot;: &quot;200&quot;,\r\n\t\t&quot;businessUnit&quot;: &quot;unit1&quot;,\r\n\t\t&quot;businessAppId&quot;: &quot;123456&quot;,\r\n\t\t&quot;numRecordsReturned&quot;: &quot;2&quot;,\r\n\t\t&quot;totalRecords&quot;: &quot;2&quot;,\r\n\t\t&quot;hasMore&quot;: &quot;false&quot;\r\n\t}\r\n}\r\n```\r\n\r\nThis query gives me the output of the correct change task but I only require the values of &quot;description&quot; when &quot;short_description&quot; is &quot;01. Project validation&quot;. Also  the change tasks value I want will not always be [1] it could be any in the list of objects. \r\n```\r\n$ jq -r .change_tasks[1].short_description test.json\r\n01. Project validation\r\n```\r\n\r\nI will then need to turn the comma separated values of &quot;description&quot; into variables so they can be checked against another list of values in bash.",
        "link": "https://stackoverflow.com/questions/76255433/find-objects-based-on-value-of-a-key-in-object-using-jq",
        "title": "Find objects based on value of a key in object using jq"
    },
    {
        "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": 0,
                "creation_date": 1684229880,
                "post_id": 76261455,
                "comment_id": 134483738,
                "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": 1684233576,
                "post_id": 76261455,
                "comment_id": 134484574,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1684234056,
                "creation_date": 1684234056,
                "answer_id": 76262148,
                "question_id": 76261455,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`to_entries`]() to convert your object to a list of key-value pairs. This list can be filtered and transformed easily.\r\n\r\n```\r\nto_entries[]\r\n| select(.value.auditScore == 1)?\r\n| [.value.onlineScore, .key]\r\n| join(&quot; &quot;)\r\n```\r\n\r\nI also suggest not starting 1 new `jq` process per loop iteration, but generate the proper output and parse it:\r\n\r\n```\r\njq -r &#39;to_entries[]\r\n| select(.value.auditScore == 1)?\r\n| [.value.onlineScore, .key]\r\n| join(&quot; &quot;)&#39; | while read onlineScore name; do\r\n    echo -e &quot;Processing $name...&quot;\r\n    echo -e &quot;onlineScore is $onlineScore&quot;\r\ndone\r\n```\r\n\r\nOr just do everything in jq directly:\r\n\r\n```\r\njq -r &#39;to_entries[]\r\n| select(.value.auditScore == 1)?\r\n| &quot;Processing \\(.key)...\\nonlineScore is \\(.value.onlineScore)&quot;&#39;\r\n```",
                "title": "Loop through JSON, retrieve parent value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1684234056,
        "creation_date": 1684229462,
        "last_edit_date": 1684229589,
        "question_id": 76261455,
        "body_markdown": "This is a follow up to https://stackoverflow.com/questions/76254127/jq-loop-through-json-and-retrieve-sets-when-key-exists. Here is the dataset: \r\n```\r\n{\r\n   &quot;storageSummary&quot;: 6.8624392E13,\r\n   &quot;audit1&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.99743587,\r\n         &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n      },\r\n   &quot;audit2&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.9992917,\r\n         &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n      },\r\n   &quot;audit3&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.99930555,\r\n         &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n      }\r\n}\r\n```\r\n\r\nI want to go through it: when the `auditScore` is 1, I need to store the parent object name (like `audit1`), and the `onlineScore`.\r\n\r\nFor now, I have something like:\r\n```\r\nDS_OBJECT=$(jq -c &#39; .[]|select(type == &quot;object&quot; and has(&quot;auditScore&quot;))&#39; ${DS_SRC_FILE})\r\n\r\nfor row in ${DS_OBJECT}; do\r\n    _jq() {\r\n     echo &quot;${row}&quot; | jq -r &quot;${1}&quot;\r\n    }\r\n    echo -e &quot;Processing $(_jq &#39;.satelliteName&#39;)...&quot;\r\n    echo -e &quot;onlineScore is $(_jq &#39;.onlineScore&#39;)\r\ndone\r\n```\r\nSo, I need to extract the `parent object name` instead of the `satelliteName` in this code.\r\nHow can I do that, with bash and jq (I&#39;d prefer to avoid adding Ruby or any other language, as advised in the former topic)?",
        "link": "https://stackoverflow.com/questions/76261455/loop-through-json-retrieve-parent-value",
        "title": "Loop through JSON, retrieve parent value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684265759,
                "creation_date": 1684265759,
                "answer_id": 76266513,
                "question_id": 76266479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You first have to `select` the objects you want, then feed the selected result into a new filter which extracts the display name:\r\n\r\n```\r\n.entities[]\r\n| select(.properties.kubernetesLabels.some_condition==null)\r\n| .displayName\r\n```",
                "title": "jq - print value only where key value pair exists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1684265759,
        "creation_date": 1684265383,
        "question_id": 76266479,
        "body_markdown": "I have json file like below. I want to print only the value of displayName when &#39;&quot;some_condition&quot;&#39; doesnt exists or value is null. I cant seem to figure this out. \r\n\r\n\r\n    {\r\n     &quot;entities&quot;: [\r\n        {\r\n          &quot;displayName&quot;: &quot;host123.bcbsfl.com&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;kubernetesLabels&quot;: {\r\n              &quot;kubernetes.io/hostname&quot;: &quot;host123.bcbsfl.com&quot;,\r\n              &quot;some_condition&quot;: &quot;true&quot;,\r\n              &quot;kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n              &quot;kubernetes.io/os&quot;: &quot;linux&quot;,\r\n              &quot;beta.kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n              &quot;node.openshift.io/os_id&quot;: &quot;rhcos&quot;,\r\n              &quot;beta.kubernetes.io/os&quot;: &quot;linux&quot;,\r\n              &quot;node-role.kubernetes.io/worker&quot;: &quot;&quot;\r\n            }\r\n          }\r\n        },\r\n        {\r\n          &quot;displayName&quot;: &quot;host567.abc.com&quot;,\r\n          &quot;properties&quot;: {\r\n            &quot;kubernetesLabels&quot;: {\r\n              &quot;kubernetes.io/hostname&quot;: &quot;host567.abc.com&quot;,\r\n              &quot;kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n              &quot;kubernetes.io/os&quot;: &quot;linux&quot;,\r\n              &quot;beta.kubernetes.io/arch&quot;: &quot;amd64&quot;,\r\n              &quot;node.openshift.io/os_id&quot;: &quot;rhcos&quot;,\r\n              &quot;beta.kubernetes.io/os&quot;: &quot;linux&quot;,\r\n              &quot;node-role.kubernetes.io/worker&quot;: &quot;&quot;\r\n            }\r\n          }\r\n        },\r\n    \t]\r\n    }\r\n\r\nI have tried stuff like this but its not the output I&#39;m looking for since it prints the whole object (sorry if terminology is off a bit. Im still trying to learn this).\r\n\r\njq -r &#39;.entities[] |.displayName, select(.properties.kubernetesLabels.some_condition==null) &#39; file.json",
        "link": "https://stackoverflow.com/questions/76266479/jq-print-value-only-where-key-value-pair-exists",
        "title": "jq - print value only where key value pair exists"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1684267340,
                "post_id": 76266656,
                "comment_id": 134492793,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684267801,
                "post_id": 76266656,
                "comment_id": 134492850,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684307171,
                "post_id": 76266656,
                "comment_id": 134497284,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1684267235,
        "creation_date": 1684267192,
        "last_edit_date": 1684267235,
        "question_id": 76266656,
        "body_markdown": "How to write loop to iterate the below command for 10 times for variable i. \r\n\r\n    _RESULT=$(curl -sgG &quot;${CURL_OPTS[@]}&quot; --data-urlencode &quot;query=${PROMETHEUS_QUERY}&quot; &quot;${PROMETHEUS_SERVER}/api/v1/query&quot; | jq -r &#39;.data.result[**i**]&#39;)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76266656/how-to-write-loop-on-shell-script",
        "title": "How to write loop on shell script"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684267579,
                "post_id": 76266678,
                "comment_id": 134492821,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684267620,
                "post_id": 76266678,
                "comment_id": 134492828,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684267665,
                "post_id": 76266678,
                "comment_id": 134492834,
                "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": 1684267789,
                "post_id": 76266678,
                "comment_id": 134492847,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1684267731,
        "creation_date": 1684267387,
        "question_id": 76266678,
        "body_markdown": "I have a JSON array output from an API, which I am interpreting with the `jq` package. I want to see if a target value exists in this array. I am quite new to shell scripting and am using one of the simpler approaches described in [this post][1]. It works when I type the target value in manually, but not when I set it as a variable. \r\n\r\n\r\n```\r\nin_stock=$(jq -n --argjson v &#39;[&quot;orange&quot;,&quot;apple&quot;,&quot;pickle&quot;]&#39; &#39;$v&#39;)\r\necho $in_stock | jq &#39;contains([&quot;pickle&quot;])&#39;\r\n&gt;&gt;&gt; true\r\necho $in_stock | jq &#39;contains([&quot;spinach&quot;])&#39;\r\n&gt;&gt;&gt; false\r\nfavorite_food=&quot;pickle&quot;\r\necho $in_stock | jq &#39;contains([&quot;$favorite_food&quot;])&#39;\r\n&gt;&gt;&gt; false\r\n```\r\nI assume this is a basic syntax issue on my part. I&#39;ve tried a number of variations and it outputs `false`. What am I doing wrong?\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/43259563/how-to-check-if-element-exists-in-array-with-jq",
        "link": "https://stackoverflow.com/questions/76266678/how-to-fix-shell-jq-syntax-to-determine-if-json-array-contains-a-variable-stored",
        "title": "How to fix shell jq syntax to determine if JSON array contains a variable stored in a string?"
    },
    {
        "tags": [
            "format",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684337586,
                "creation_date": 1684337586,
                "answer_id": 76273799,
                "question_id": 76273350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "According to the [docs](https://stedolan.github.io/jq/manual/), the format for `strftime` is:\r\n\r\n&gt; The format strings for strptime and strftime are described in typical C library documentation. The format string for ISO 8601 datetime is &quot;%Y-%m-%dT%H:%M:%SZ&quot;.\r\n\r\nwhich is why your expression errors, since the input does not match the required format.\r\n\r\nIn this case, you should simply slice the string:\r\n\r\n```bash\r\necho &#39;{&quot;date&quot;:&quot;20200101&quot;}{&quot;date&quot;:&quot;20210101&quot;}&#39; | jq -r &#39;&quot;The bus will be here on \\( .date | .[0:4] + &quot;-&quot; + .[4:6] + &quot;-&quot; + .[6:8] ), at ten o clock&quot;&#39;\r\n```",
                "title": "Insert dash into the output of jq at specific positions"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1684342304,
                "creation_date": 1684342304,
                "answer_id": 76274455,
                "question_id": 76273350,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use `strptime` to first parse the `%Y%m%d`-formatted date, then re-format it with `strftime` to, for example, `%F`:\r\n```sh\r\n… | jq -r &#39;&quot;The bus will be here on \\(.date | strptime(&quot;%Y%m%d&quot;) | strftime(&quot;%F&quot;)), at ten o clock&quot;&#39;\r\n```\r\n```\r\nThe bus will be here on 2020-01-01, at ten o clock\r\nThe bus will be here on 2021-01-01, at ten o clock\r\n```\r\n[Demo](https://jqplay.org/s/WiPUEOJLMKl)",
                "title": "Insert dash into the output of jq at specific positions"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1684342304,
        "creation_date": 1684334605,
        "last_edit_date": 1684336146,
        "question_id": 76273350,
        "body_markdown": "How do I modify the jq code in: \r\n\r\n    echo &#39;{&quot;date&quot;:&quot;20200101&quot;}{&quot;date&quot;:&quot;20210101&quot;}&#39; | jq -r &#39;&quot;The bus will be here on \\( .date ), at ten o clock&quot;&#39;\r\n\r\nto change the format of the date from eg `20200101` into `2020-01-01`?\r\n\r\nI get the output:\r\n\r\n    The bus will be here on 20200101, at ten o clock\r\n    The bus will be here on 20210101, at ten o clock\r\n\r\nI want the output:\r\n\r\n    The bus will be here on 2020-01-01, at ten o clock\r\n    The bus will be here on 2021-01-01, at ten o clock\r\n\r\nI tried:\r\n\r\n    echo &#39;{&quot;date&quot;:&quot;20200101&quot;}{&quot;date&quot;:&quot;20210101&quot;}&#39; | jq -r &#39;&quot;The bus will be here on \\( .date | strftime(&quot;%Y-%m-%d&quot;) ), at ten o clock&quot;&#39;\r\n\r\nbut that tells me:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): strftime/1 requires parsed datetime inputs\r\n\r\n`strftime` apparently needs the input date to be in another format.\r\n",
        "link": "https://stackoverflow.com/questions/76273350/insert-dash-into-the-output-of-jq-at-specific-positions",
        "title": "Insert dash into the output of jq at specific positions"
    },
    {
        "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": 1684336519,
                "post_id": 76273403,
                "comment_id": 134504195,
                "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": 1684336879,
                "post_id": 76273403,
                "comment_id": 134504288,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684336620,
                "last_edit_date": 1684336620,
                "creation_date": 1684335789,
                "answer_id": 76273524,
                "question_id": 76273403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JSON doesn&#39;t use single quotes. Use double quotes instead, or leave the number unquoted.\r\n\r\nThe command will still fail: starting with `.[]` will throw away the keys of the object and return the values, so you don&#39;t have access to the &quot;audit1&quot; anymore.\r\n\r\nAlso, to change the value, you can use the plain `=` (and without `select`) as the right hand side is not sensitive to context:\r\n\r\n    jq --arg ds &quot;$ds&quot; --arg name &quot;$new_name&quot; &#39;.[$ds][&quot;satelliteName&quot;] = $name&#39; &lt;&lt;&lt; &quot;$DS_OBJECT&quot;\r\n\r\nAlso note that I double quoted the shell variables which should make the command work even if they contained whitespace.",
                "title": "jq : update json content when path is variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1684336901,
        "creation_date": 1684334944,
        "last_edit_date": 1684336901,
        "question_id": 76273403,
        "body_markdown": "I have the following dataset in a file : \r\n```\r\n{\r\n   &quot;storageSummary&quot;: 6.8624392E13,\r\n   &quot;audit1&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.99743587,\r\n         &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n      },\r\n   &quot;audit2&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.9992917,\r\n         &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n      },\r\n   &quot;audit3&quot;: {\r\n         &quot;auditScore&quot;: 1,\r\n         &quot;suspensionScore&quot;: 1,\r\n         &quot;onlineScore&quot;: 0.99930555,\r\n         &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n      }\r\n}\r\n```\r\n\r\nI want to update the content (I&#39;m storing the json into a variable, since I make several updates, then I&#39;ll create a new file), but the path of the data to update is variable : \r\n\r\nFor example, I have : \r\n```\r\nDS_SRC_FILE=&quot;test.json&quot;\r\n\r\nDS_OBJECT=$(jq -c &#39;&#39; ${DS_SRC_FILE})\r\n\r\nds=&quot;audit1&quot;\r\nnew_name=&quot;toto&quot;\r\n\r\njq --arg ds ${ds} --arg name ${new_name} &#39;.[]|select(.value==$ds)|=(.satellitename = $name)&#39; &lt;&lt;&lt; ${DS_OBJECT}\r\n```\r\nSo, of course, this is failing with `parse error: Invalid numeric literal at line 2, column 36`\r\n\r\nWhat&#39;s the right way to do that please ?",
        "link": "https://stackoverflow.com/questions/76273403/jq-update-json-content-when-path-is-variable",
        "title": "jq : update json content when path is variable"
    },
    {
        "tags": [
            "json",
            "python-3.x",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684430583,
                "post_id": 76283081,
                "comment_id": 134519957,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1684434210,
                "creation_date": 1684434210,
                "answer_id": 76283505,
                "question_id": 76283081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -Rs &#39;                        # 1. -Rs = read the input into a single string\r\n    split(&quot;\\n{2,}&quot;; &quot;&quot;)         # 2. split on sequences of blank lines\r\n    | map(                      # 3. transform each paragraph into an object\r\n        split(&quot;\\n&quot;) \r\n        | map(scan(&quot;^([^:]+)(: (.*))?&quot;) | {key: first, value: last}) \r\n        | from_entries\r\n    )\r\n&#39; data.file\r\n```\r\n\r\noutputs\r\n```json\r\n[\r\n  {\r\n    &quot;Cus Id&quot;: &quot;1234&quot;,\r\n    &quot;Cus Name&quot;: &quot;10:/John Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: &quot;tesla;toyota&quot;,\r\n    &quot;Dept Id&quot;: &quot;111&quot;\r\n  },\r\n  {\r\n    &quot;Cus Id&quot;: &quot;1235&quot;,\r\n    &quot;Cus Name&quot;: &quot;10:/William Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: null,\r\n    &quot;Dept Id&quot;: &quot;222&quot;\r\n  }\r\n]\r\n```",
                "title": "Convert repeated key value pairs text file to JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684436127,
                "creation_date": 1684436127,
                "answer_id": 76283699,
                "question_id": 76283081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A Python solution:\r\n\r\n```py\r\nimport json\r\n\r\ndef try_to_convert_to_int(val):\r\n    try:\r\n        val = int(val)\r\n    except:\r\n        pass\r\n    return val\r\n\r\ndata, group = [], {}\r\nwith open(&#39;your_file.txt&#39;, &#39;r&#39;) as f_in:\r\n    for line in map(str.strip, f_in):\r\n        if line == &quot;&quot;:\r\n            if group:\r\n                data.append(group)\r\n            group = {}\r\n        else:\r\n            k, v = map(str.strip, line.split(&#39;:&#39;, maxsplit=1))\r\n            group[k] = try_to_convert_to_int(v) if v else None\r\n\r\nif group:\r\n    data.append(group)\r\n\r\nprint(json.dumps(data, indent=4))\r\n```\r\n\r\nPrints:\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;Cus Id&quot;: 1234,\r\n        &quot;Cus Name&quot;: &quot;10:/John Parks&quot;,\r\n        &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n        &quot;Cus client&quot;: &quot;tesla;toyota&quot;,\r\n        &quot;Dept Id&quot;: 111\r\n    },\r\n    {\r\n        &quot;Cus Id&quot;: 1235,\r\n        &quot;Cus Name&quot;: &quot;10:/William Parks&quot;,\r\n        &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n        &quot;Cus client&quot;: null,\r\n        &quot;Dept Id&quot;: 222\r\n    }\r\n]\r\n```\r\n",
                "title": "Convert repeated key value pairs text file to JSON"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1684442203,
                "creation_date": 1684442203,
                "answer_id": 76284310,
                "question_id": 76283081,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `reduce` the stream of raw-text (flag `-R`) `inputs` (flag `-n`) by iteratively building up the output array. Start with an array containing one empty object (`[{}]`), then `capture` each line&#39;s contents using regular expressions, and populate the currently last array item with it. If capturing fails structurally (testing the presence of a key), add another empty object.\r\n\r\n```sh\r\njq -Rn &#39;reduce (inputs | capture(&quot;(?&lt;k&gt;[^:]+):\\\\s*(?&lt;v&gt;.*)|&quot;)) as $in (\r\n  [{}]; if $in.k then last[$in.k] = $in.v else . + [{}] end\r\n)&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;Cus Id&quot;: &quot;1234&quot;,\r\n    &quot;Cus Name&quot;: &quot;10:/John Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: &quot;tesla;toyota&quot;,\r\n    &quot;Dept Id&quot;: &quot;111&quot;\r\n  },\r\n  {\r\n    &quot;Cus Id&quot;: &quot;1235&quot;,\r\n    &quot;Cus Name&quot;: &quot;10:/William Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: &quot;&quot;,\r\n    &quot;Dept Id&quot;: &quot;222&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/AVM3l9IC4cA)\r\n\r\nGoing further:\r\n- If you want to treat special values differently, adapt `$in.v` accordingly before the assignment. For example, to first test if values look like numbers and turn them into one, then test for empty strings and replace them with a special one (`&quot;null&quot;`), or else use the given string, you could go with something like `($in.v | tonumber? // (select(. == &quot;&quot;) | &quot;null&quot;) // .)`.\r\n- If you want to treat special blocks differently, process the output after the reduction. For example, to prevent the generation of empty objects that occur if input blocks are separated by more then one empty line, you could go with something like `map(select(. != {}))`.",
                "title": "Convert repeated key value pairs text file to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1684442203,
        "creation_date": 1684430288,
        "last_edit_date": 1684430377,
        "question_id": 76283081,
        "body_markdown": "I have a file that contains this format:\r\n\r\n```\r\nCus Id: 1234\r\nCus Name: 10:/John Parks\r\nCus Type: temporary\r\nCus client: tesla;toyota\r\nDept Id: 111\r\n\r\nCus Id: 1235\r\nCus Name: 10:/William Parks\r\nCus Type: temporary\r\nCus client:\r\nDept Id: 222\r\n```\r\nHow can I convert this to JSON format? Any methods bash, jq, or python is fine.\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Cus Id&quot;: 1234,\r\n    &quot;Cus Name&quot;: &quot;10:/John Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: &quot;tesla;toyota&quot;,\r\n    &quot;Dept Id&quot;: 111\r\n  },\r\n  { \r\n    &quot;Cus Id&quot;: 1235,\r\n    &quot;Cus Name&quot;: &quot;10:/William Parks&quot;,\r\n    &quot;Cus Type&quot;: &quot;temporary&quot;,\r\n    &quot;Cus client&quot;: &quot;null&quot;,\r\n    &quot;Dept Id&quot;: 222\r\n  }\r\n] \r\n```",
        "link": "https://stackoverflow.com/questions/76283081/convert-repeated-key-value-pairs-text-file-to-json",
        "title": "Convert repeated key value pairs text file to JSON"
    },
    {
        "tags": [
            "jquery",
            "bash",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684500292,
                "post_id": 76289104,
                "comment_id": 134530255,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1684500048,
                "creation_date": 1684500048,
                "answer_id": 76289173,
                "question_id": 76289104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can have jq output `true` or `false`, thus set the variable directly. Within jq, you can use `any` to find &quot;at least one item&quot; that matches your criteria.\r\n```sh\r\nhasJerry=&quot;$(jq &#39;any(.user.login == &quot;JERRY&quot; and .state == &quot;APPROVED&quot;)&#39; input.json)&quot;\r\n```\r\n[Demo](https://jqplay.org/s/TghJUmO6f7O)\r\n\r\nNote that your Bash script has errors (e.g. whitespace around `=` with the variable assignment), as does your (sample) JSON input (e.g. commas after the last field in an object). Please correct them first.",
                "title": "jq command to check if a json array response has particular user name and state as approved using shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1684504596,
                "creation_date": 1684504596,
                "answer_id": 76289786,
                "question_id": 76289104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of returning the raw True or False strings, you could test the return status:\r\n\r\n```sh\r\n#!/usr/bin/env sh\r\n\r\nuser=$1\r\n\r\nwhile [ -z &quot;$user&quot; ]; do\r\n  printf &#39;Enter user: &#39; \r\n  read -r user\r\n  printf \\\\n\r\ndone\r\n\r\nif jq -e --arg user &quot;$user&quot; \\\r\n  &#39;\r\n.users | \r\nany(\r\n  .user.login == ($user | ascii_upcase) and\r\n  .state == &quot;APPROVED&quot;\r\n)\r\n&#39; input.json &gt; /dev/null\r\nthen\r\n  printf &#39;%s is approved!\\n&#39; &quot;$user&quot;\r\nelse\r\n  printf &#39;Non-aproved user %s!\\n&#39; &quot;$user&quot;\r\nfi\r\n```",
                "title": "jq command to check if a json array response has particular user name and state as approved using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1684504596,
        "creation_date": 1684499578,
        "question_id": 76289104,
        "body_markdown": "I have a json array response below,\r\n\r\n```\r\n[\r\n    {\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;TOM&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n    },\r\n\t{\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;JERRY&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n    },\r\n\t{\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;ANDY&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;REJECTED&quot;,\r\n    }\r\n]\r\n```\r\n\r\nI am working on code to check if only when user **Jerry** exists and has state **APPROVED** I should set a variable value as true else it should be false.\r\n\r\nIn above case I should get true and in either of the below cases it should be false\r\n\r\n```\r\n[\r\n    {\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;TOM&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n    },\r\n\t{\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;JERRY&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;REJECTED&quot;,\r\n    },\r\n\t{\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;ANDY&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;REJECTED&quot;,\r\n    }\r\n]\r\n```\r\n\r\nor \r\n\r\n```\r\n[\r\n    {\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;TOM&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;APPROVED&quot;,\r\n    },\r\n\t{\r\n        &quot;user&quot;: {\r\n            &quot;login&quot;: &quot;ANDY&quot;,\r\n        },\r\n        &quot;body&quot;: &quot;&quot;,\r\n        &quot;state&quot;: &quot;REJECTED&quot;,\r\n    }\r\n]\r\n```\r\n\r\nI tried below code but I am not able to address both the condition \r\n\r\n```\r\nhasJerry = false\r\nif [ (jq -r &#39;.[].user.login | index(&quot;JTHOM949&quot;)&#39;) &amp;&amp; (jq -r &#39;.[].state&#39; == &quot;APPROVED&quot;) ]; then\r\n\r\n    hasJerry = true\r\n\r\nfi\r\n```\r\n\r\ncan someone help me to fix this script.",
        "link": "https://stackoverflow.com/questions/76289104/jq-command-to-check-if-a-json-array-response-has-particular-user-name-and-state",
        "title": "jq command to check if a json array response has particular user name and state as approved using shell script"
    },
    {
        "tags": [
            "bash",
            "shell",
            "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": 3,
                "creation_date": 1684526747,
                "post_id": 76292146,
                "comment_id": 134535482,
                "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": 1684526794,
                "post_id": 76292146,
                "comment_id": 134535491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24157239,
                    "reputation": 23,
                    "user_id": 18121317,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Ghx-KfGIgmIIrufdZ9BNA08ThshEXae3-0C8OWTng=k-s256",
                    "display_name": "ramesh k",
                    "link": "https://stackoverflow.com/users/18121317/ramesh-k"
                },
                "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": 1684526986,
                "post_id": 76292146,
                "comment_id": 134535529,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1684527357,
                "creation_date": 1684527357,
                "answer_id": 76292195,
                "question_id": 76292146,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Neither the input nor the desired output is valid JSON. Thus, treating input and output as raw text (using jq with flags `-Rr`, although at this point you could use any JSON-unrelated text-processing tool), you could simply scan by regular expressions, for instance from `{` to `}`:\r\n```sh\r\njq -Rr &#39;scan(&quot;({[^}]*})&quot;)[]&#39;\r\n```\r\n```\r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }\r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }\r\n```\r\n[Demo](https://jqplay.org/s/jD4pBjSIbBZ)",
                "title": "How to split the query response of 2 metric in to two"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1684564984,
        "creation_date": 1684526661,
        "last_edit_date": 1684564984,
        "question_id": 76292146,
        "body_markdown": "PROMETHEUS_METRIC: { __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }\r\n\r\nIts json format. How to split the above response into 2 as below in shell script. I have variable PROMETHEUS_METRIC have the above json. \r\n\r\n    { __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }\r\n   \r\n    { __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76292146/how-to-split-the-query-response-of-2-metric-in-to-two",
        "title": "How to split the query response of 2 metric in to two"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684586128,
                "post_id": 76295204,
                "comment_id": 134540463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 24174158,
                    "reputation": 9,
                    "user_id": 18135805,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14Gg4oNgFF4h-2dzT_abUjkKeFIPKdbXRFyuiADjMYA=k-s256",
                    "display_name": "Павел Зоранович Керкезов",
                    "link": "https://stackoverflow.com/users/18135805/%d0%9f%d0%b0%d0%b2%d0%b5%d0%bb-%d0%97%d0%be%d1%80%d0%b0%d0%bd%d0%be%d0%b2%d0%b8%d1%87-%d0%9a%d0%b5%d1%80%d0%ba%d0%b5%d0%b7%d0%be%d0%b2"
                },
                "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": 1684587079,
                "post_id": 76295204,
                "comment_id": 134540590,
                "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": 1684588483,
                "post_id": 76295204,
                "comment_id": 134540771,
                "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": 1685000925,
                "post_id": 76295204,
                "comment_id": 134600454,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1684585845,
                "creation_date": 1684585845,
                "answer_id": 76295247,
                "question_id": 76295204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter `[select(.data.slot == &quot;6436990&quot;)]` will create an array `[…]` for each input item. As you are filtering out (most of) the input items using `select(…)`, you get a stream of (mostly) empty arrays.\r\n\r\nDrop the array brackets (just use `select(…)`) and there will be no output for input items not matching.",
                "title": "jq returns an array of empty values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684595456,
        "creation_date": 1684585239,
        "last_edit_date": 1684595456,
        "question_id": 76295204,
        "body_markdown": "I have an huge json file (around 7GB) with multiple elements, let&#39;s call it `data.json`. Each element looks like this:\r\n\r\n```lang-json\r\n{\r\n  &quot;aggregation_bits&quot;: &quot;0xf7fffffffffffdfffffffffffffdfffffffffffffffffffffff7fffffffffffffff7ff&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;slot&quot;: &quot;6436981&quot;,\r\n    &quot;index&quot;: &quot;8&quot;,\r\n    &quot;beacon_block_root&quot;: &quot;0xf8afce2fc26df10061d641633a7256cf47ffa8793771ae83e190e72bf2c5886e&quot;,\r\n    &quot;source&quot;: {\r\n      &quot;epoch&quot;: &quot;201154&quot;,\r\n      &quot;root&quot;: &quot;0x694231a8135b3f546a6fe483ba6b467c686592f6d627aaf06b56ffbd78d75f63&quot;\r\n    },\r\n    &quot;target&quot;: {\r\n      &quot;epoch&quot;: &quot;201155&quot;,\r\n      &quot;root&quot;: &quot;0x2fc0d9f58cda026678d98f010fec13d202eec4ec9ae4dbd57878413a75fe22d7&quot;\r\n    }\r\n  },\r\n  &quot;signature&quot;: &quot;0xadb0d576ee418e37017f423e77622ce85bdb741d0e984e78df3a250c172fc67c6c7ec94e4802d6323aee8f62b7df218300f42010fe673ed85f4e06d1361336474ecfb4db39aa2bc31b31bf6fbe52c7bff769f024faa5ba3554d5ea02fe9663c3&quot;,\r\n  &quot;arrival&quot;: 1684067808365\r\n}\r\n```\r\n\r\nWhat I want to do is use `jq` scripting to select all elements that contain slot with a certain value and save them in a separate json file, let&#39;s call it `data_for_slot.json`\r\n\r\n\r\n\r\n\r\n\r\n\r\nLet&#39;s assume I want all elements where `slot = 6436990`. For this purpose, I used:\r\n\r\n\r\n```\r\njq -c &#39;[select(.data.slot == &quot;6436990&quot;)]&#39; data.json &gt; data_for_slot.json\r\n```\r\n\r\nAfter running for some time, it returned `data_for_slot.json`, but when I opened it to inspect, what I got was:\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...\r\n```\r\n\r\nI know for a fact that `slot = 6436990` exists in some of the elements, so I was expecting an array of such elements, but got this instead. I don&#39;t understand why is it returning results like this, while not throwing any error. \r\n\r\nI am very new to `jq` scripting, and I would appreciate if anyone could tell me what am I doing wrong and what is the correct way of doing this.",
        "link": "https://stackoverflow.com/questions/76295204/jq-returns-an-array-of-empty-values",
        "title": "jq returns an array of empty values"
    },
    {
        "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": 1684599141,
                "post_id": 76296125,
                "comment_id": 134542051,
                "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": 2,
                "creation_date": 1684599238,
                "post_id": 76296125,
                "comment_id": 134542066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684604747,
                "post_id": 76296125,
                "comment_id": 134542693,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1684608894,
                "post_id": 76296125,
                "comment_id": 134543261,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4175409,
                    "reputation": 84960,
                    "user_id": 3422102,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/Tg0Gt.png?s=256",
                    "display_name": "David C. Rankin",
                    "link": "https://stackoverflow.com/users/3422102/david-c-rankin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684646885,
                "post_id": 76296125,
                "comment_id": 134545861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28643025,
                    "reputation": 21,
                    "user_id": 21931731,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8c35736a0ddef07f45568f7bcab70607?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sree",
                    "link": "https://stackoverflow.com/users/21931731/sree"
                },
                "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": 1684673477,
                "post_id": 76296125,
                "comment_id": 134548260,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28643025,
                    "reputation": 21,
                    "user_id": 21931731,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8c35736a0ddef07f45568f7bcab70607?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sree",
                    "link": "https://stackoverflow.com/users/21931731/sree"
                },
                "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": 1684675731,
                "post_id": 76296125,
                "comment_id": 134548519,
                "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": 1684693193,
                "post_id": 76296125,
                "comment_id": 134550649,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684693003,
                "last_edit_date": 1684693003,
                "creation_date": 1684624914,
                "answer_id": 76297705,
                "question_id": 76296125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The quasi-JSON to JSON step could be accomplished as follows:\r\n```\r\njq -R &#39;\r\n  def rtrim: sub(&quot; +$&quot;;&quot;&quot;);\r\n  def kvs:\r\n     capture( &quot;[, ]*(?&lt;key&gt;[^:]+) *: *(?&lt;value&gt;[^,]*)(?&lt;etc&gt;.*)&quot; )\r\n     | {key,value}, (.etc | kvs) ;\r\n\r\n  scan( &quot; *[{] *([^}]+)[}]&quot; ) | first | rtrim | [kvs] | from_entries\r\n&#39;\r\n```\r\n\r\nWith your sample input, this produces:\r\n```\r\n{\r\n  &quot;__name__&quot;: &quot;sc_pcd_g2version&quot;,\r\n  &quot;container&quot;: &quot;mgmtbroker&quot;,\r\n  &quot;endpoint&quot;: &quot;vxexporter&quot;,\r\n  &quot;instance&quot;: &quot;10.42.24.132:9116&quot;,\r\n  &quot;job&quot;: &quot;prometheus&quot;,\r\n  &quot;namespace&quot;: &quot;delivery&quot;,\r\n  &quot;pod&quot;: &quot;chn1-d1-ac-0&quot;,\r\n  &quot;service&quot;: &quot;prometheus&quot;\r\n}\r\n{\r\n  &quot;__name__&quot;: &quot;sc_pcd_g2version&quot;,\r\n  &quot;container&quot;: &quot;mgmtbroker&quot;,\r\n  &quot;endpoint&quot;: &quot;vxexporter&quot;,\r\n  &quot;instance&quot;: &quot;10.42.3.110:9116&quot;,\r\n  &quot;job&quot;: &quot;prometheus&quot;,\r\n  &quot;namespace&quot;: &quot;delivery&quot;,\r\n  &quot;pod&quot;: &quot;chn1-d1-ia-0&quot;,\r\n  &quot;service&quot;: &quot;prometheus&quot;\r\n}\r\n```\r\n\r\nSome tweaking might be in order to handle various edge cases.\r\n\r\nIf the extraction step cannot be done in jq itself, then consider\r\nusing jq&#39;s -c command-line option in conjunction with a bash `while` loop, along the lines of:\r\n\r\n    while read -r object ; do\r\n       echo &quot;$object&quot;\r\n    done &lt;  &lt;( jq -Rc .... )\r\n",
                "title": "How to iterate and pick the each element in {} blocks"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1742385858,
        "creation_date": 1684598596,
        "last_edit_date": 1742385858,
        "question_id": 76296125,
        "body_markdown": "```\r\n\r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }\r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }\r\n\r\n```\r\nThere are two block below how to iterate the below data block using jq filter which should pick on first iteration\r\n``` \r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }\r\n```\r\nOn second iteration, it should pick the second one\r\n``` \r\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }\r\n```\r\nThe response of the above which needs to be later selected each `{}` block \r\n\r\n\r\nThe required output filtered and captured below. Now i am looking to select the first element  {} block and then next iteration must select the next one.  \r\n\r\n\r\n    function get_prometheus_vector_value {\r\n      local _RESULT\r\n      for i in 0 1\r\n      do\r\n        # return the value of the first element of the vector\r\n        _RESULT=$(echo $1 | jq -r &#39;.[&#39;$i&#39;].value?&#39;)\r\n        printf &#39;%s&#39; &quot;${_RESULT}&quot;\r\n      done\r\n    }\r\n    \r\n    function get_prometheus_vector_metric {\r\n    \r\n      local _RESULT\r\n      for i in 0 1\r\n      do\r\n        # return the metric information of the first element of the vector\r\n        _RESULT=$(echo $1 | jq -r &#39;.[&#39;$i&#39;].metric?&#39; | xargs)\r\n        printf &#39;%s&#39; &quot;${_RESULT}&quot;\r\n      done\r\n    }\r\n    \r\n    # set up exit function\r\n    trap on_exit EXIT TERM\r\n    \r\n    # process the cli options\r\n    process_command_line &quot;$@&quot;\r\n    \r\n    # get the raw query from prometheus\r\n    PROMETHEUS_RAW_RESULT=&quot;$( get_prometheus_raw_result )&quot;\r\n    \r\n    \r\n      # extract the metric value from the raw prometheus result\r\n      if [[ &quot;${PROMETHEUS_QUERY_TYPE}&quot; = &quot;scalar&quot; ]]\r\n      then\r\n          PROMETHEUS_RESULT=$( get_prometheus_scalar_result &quot;$PROMETHEUS_RAW_RESULT&quot; )\r\n          PROMETHEUS_METRIC=UNKNOWN\r\n      else\r\n          PROMETHEUS_VALUE=$( get_prometheus_vector_value &quot;$PROMETHEUS_RAW_RESULT&quot; )\r\n          PROMETHEUS_RESULT=$( get_prometheus_scalar_result &quot;$PROMETHEUS_VALUE&quot; )\r\n          printf &#39;PROMETHEUS_RESULT: %s\\n&#39; &quot;${PROMETHEUS_RESULT}&quot;\r\n    \r\n          PROMETHEUS_METRIC=$( get_prometheus_vector_metric &quot;$PROMETHEUS_RAW_RESULT&quot; )\r\n    \r\n          PROMETHEUS_METRIC=$(echo $PROMETHEUS_METRIC | jq -Rr &#39;scan(&quot;({[^}]*})&quot;)&#39;)\r\n          printf &#39;PROMETHEUS_METRIC after scan: %s\\n&#39; &quot;${PROMETHEUS_METRIC}&quot;\r\n    \r\n      fi\r\n    for i in &quot;$PROMETHEUS_METRIC&quot;\r\n    do\r\n      # check the value\r\n      **PROMETHEUS_METRIC=$(echo $PROMETHEUS_METRIC) |jq .[1]**\r\n      if [[ ${PROMETHEUS_RESULT} =~ ^-?[0-9]+$ ]]\r\n      then\r\n        if eval [[ ${PROMETHEUS_RESULT} -${COMPARISON_METHOD} ${CRITICAL_LEVEL} ]]\r\n        then\r\n          NAGIOS_STATUS=CRITICAL\r\n          NAGIOS_SHORT_TEXT=&quot;${METRIC_NAME} is ${PROMETHEUS_RESULT}&quot;\r\n        elif eval [[ ${PROMETHEUS_RESULT} -${COMPARISON_METHOD} $WARNING_LEVEL ]]\r\n        then\r\n          NAGIOS_STATUS=WARNING\r\n          NAGIOS_SHORT_TEXT=&quot;${METRIC_NAME} is ${PROMETHEUS_RESULT}&quot;\r\n        else\r\n          NAGIOS_STATUS=OK\r\n          NAGIOS_SHORT_TEXT=&quot;${METRIC_NAME} is ${PROMETHEUS_RESULT}&quot;\r\n        fi\r\n      else\r\n        if [[ &quot;${NAN_OK}&quot; = &quot;true&quot; &amp;&amp; &quot;${PROMETHEUS_RESULT}&quot; = &quot;NaN&quot; ]]\r\n        then\r\n          NAGIOS_STATUS=OK\r\n          NAGIOS_SHORT_TEXT=&quot;${METRIC_NAME} is ${PROMETHEUS_RESULT}&quot;\r\n        else\r\n          NAGIOS_SHORT_TEXT=&quot;unable to parse prometheus response&quot;\r\n          NAGIOS_LONG_TEXT=&quot;${METRIC_NAME} is ${PROMETHEUS_RESULT}&quot;\r\n        fi\r\n      fi\r\n      if [[ &quot;${NAGIOS_INFO}&quot; = &quot;true&quot; ]]\r\n      then\r\n          NAGIOS_SHORT_TEXT=&quot;${NAGIOS_SHORT_TEXT}: ${PROMETHEUS_METRIC}&quot;\r\n      fi\r\n      if [[ &quot;${PERFDATA}&quot; = &quot;true&quot; ]]\r\n      then\r\n          NAGIOS_SHORT_TEXT=&quot;${NAGIOS_SHORT_TEXT} | query_result=${PROMETHEUS_RESULT}&quot;\r\n      fi\r\n    exit\r\n",
        "link": "https://stackoverflow.com/questions/76296125/how-to-iterate-and-pick-the-each-element-in-blocks",
        "title": "How to iterate and pick the each element in {} blocks"
    },
    {
        "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": 1684640150,
                "post_id": 76298165,
                "comment_id": 134545548,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8878585,
                    "reputation": 396,
                    "user_id": 6629722,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://lh4.googleusercontent.com/-aAiSphNyWzw/AAAAAAAAAAI/AAAAAAAAACc/mbFNUmwue_8/s256-rj/photo.jpg",
                    "display_name": "Mangesh Tak",
                    "link": "https://stackoverflow.com/users/6629722/mangesh-tak"
                },
                "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": 1684640184,
                "post_id": 76298165,
                "comment_id": 134545549,
                "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": 1684640310,
                "post_id": 76298165,
                "comment_id": 134545557,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8878585,
                    "reputation": 396,
                    "user_id": 6629722,
                    "user_type": "registered",
                    "accept_rate": 40,
                    "profile_image": "https://lh4.googleusercontent.com/-aAiSphNyWzw/AAAAAAAAAAI/AAAAAAAAACc/mbFNUmwue_8/s256-rj/photo.jpg",
                    "display_name": "Mangesh Tak",
                    "link": "https://stackoverflow.com/users/6629722/mangesh-tak"
                },
                "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": 1684640470,
                "post_id": 76298165,
                "comment_id": 134545569,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1684641169,
                "last_edit_date": 1684641169,
                "creation_date": 1684640583,
                "answer_id": 76298201,
                "question_id": 76298165,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` to generate an array of indices and values. Use the indices to index into the other key, stored in a variable for reference:\r\n```sh\r\njq &#39;. as {$key2} | .key1 |= [to_entries[] | .value + &quot;-&quot; + $key2[.key]]&#39; data.json\r\n```\r\n[Demo](https://jqplay.org/s/a4acVQHYZKJ)\r\n\r\nIf the arrays aren&#39;t big, you could also use the less efficient `transpose` filter to zip them:\r\n```sh\r\njq &#39;.key1 = [map(.) | transpose[] | join(&quot;-&quot;)]&#39; data.json\r\n```\r\n[Demo](https://jqplay.org/s/VXq_Brl0bRd)\r\n\r\nOutput of both:\r\n```json\r\n{\r\n  &quot;key1&quot;: [\r\n    &quot;val1-v1&quot;,\r\n    &quot;val2-v2&quot;\r\n  ],\r\n  &quot;key2&quot;: [\r\n    &quot;v1&quot;,\r\n    &quot;v2&quot;\r\n  ]\r\n}\r\n```",
                "title": "JQ transform JSON doc"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684641169,
        "creation_date": 1684639299,
        "last_edit_date": 1684640413,
        "question_id": 76298165,
        "body_markdown": "I have JSON file with below format\r\n\r\n    {\r\n        &quot;key1&quot;: [&quot;val1&quot;, &quot;val2&quot;],\r\n        &quot;key2&quot;: [&quot;v1&quot;, &quot;v2&quot;]\r\n    }\r\n\r\nI want to transform it into\r\n \r\n\r\n    {\r\n        &quot;key1&quot;: [&quot;val1-v1&quot;, &quot;val2-v2&quot;],\r\n        &quot;key2&quot;: [&quot;v1&quot;, &quot;v2&quot;]\r\n    }\r\n\r\nHow can I acheive this using jq in linux environment?",
        "link": "https://stackoverflow.com/questions/76298165/jq-transform-json-doc",
        "title": "JQ transform JSON doc"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684671503,
                "last_edit_date": 1684671503,
                "creation_date": 1684671008,
                "answer_id": 76299844,
                "question_id": 76299813,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n```sh\r\njq -s &#39;add | group_by(.lang) | map(add)&#39; file1.json file2.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/CucpzOi9KhC)&lt;/sup&gt;\r\n\r\nand another:\r\n``` sh\r\njq -n &#39;reduce inputs[] as $obj ({};\r\n  .[$obj.lang] += $obj\r\n) | map(.)&#39; file1.json file2.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/K3cnGCTVbgl)&lt;/sup&gt;\r\n",
                "title": "How to join objects within array of json files by matching key:value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684672787,
        "creation_date": 1684670554,
        "question_id": 76299813,
        "body_markdown": "Given file1.json and file2.json with objects sharing a common &quot;lang&quot; properties with identical values :\r\n \r\n```js\r\n[\r\n  { &quot;lang&quot;: &quot;Inari Sami&quot;, &quot;audios&quot;: 78 },\r\n  { &quot;lang&quot;: &quot;Tofalar&quot;, &quot;audios&quot;: 42 },\r\n  { &quot;lang&quot;: &quot;Kumyk&quot;, &quot;audios&quot;: 305 }\r\n]\r\n```\r\n\r\n```js\r\n[\r\n    { &quot;lang&quot;: &quot;Inari Sami&quot;, &quot;isoCode&quot;: &quot;smn&quot;, &quot;genderFemales&quot;: 1, &quot;genderMales&quot;: 5, &quot;genderOthers&quot;: 3 },\r\n    { &quot;lang&quot;: &quot;Tofalar&quot;,  &quot;genderFemales&quot;: 2, &quot;genderMales&quot;: 3, &quot;genderOthers&quot;: 1 },\r\n    { &quot;lang&quot;: &quot;Kumyk&quot;, &quot;isoCode&quot;: &quot;kum&quot;, &quot;genderFemales&quot;: 5, &quot;genderMales&quot;: 4, &quot;genderOthers&quot;: 2 },\r\n    { &quot;lang&quot;: &quot;French&quot;}\r\n]\r\n```\r\n\r\nHow can I get a consolidation (fusion) of those such as : \r\n\r\n```js\r\n[\r\n{ &quot;lang&quot;: &quot;Inari Sami&quot;, &quot;audios&quot;: 78, &quot;isoCode&quot;: &quot;smn&quot;, &quot;genderFemales&quot;: 1, &quot;genderMales&quot;: 7, &quot;genderOthers&quot;: 1 },\r\n  { &quot;lang&quot;: &quot;Tofalar&quot;, &quot;audios&quot;: 42, &quot;isoCode&quot;: &quot;xal&quot;, &quot;genderFemales&quot;: 2, &quot;genderMales&quot;: 6, &quot;genderOthers&quot;: 0 },\r\n  { &quot;lang&quot;: &quot;Kumyk&quot;, &quot;audios&quot;: 305, &quot;isoCode&quot;: &quot;kum&quot;, &quot;genderFemales&quot;: 5, &quot;genderMales&quot;: 7, &quot;genderOthers&quot;: 1 },\r\n  { &quot;lang&quot;: &quot;French&quot;}\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76299813/how-to-join-objects-within-array-of-json-files-by-matching-keyvalue",
        "title": "How to join objects within array of json files by matching key:value?"
    },
    {
        "tags": [
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 6,
                "creation_date": 1684768463,
                "post_id": 76307599,
                "comment_id": 134561373,
                "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": 1684768522,
                "post_id": 76307599,
                "comment_id": 134561387,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1684769053,
                "post_id": 76307599,
                "comment_id": 134561503,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1684769248,
                "creation_date": 1684769248,
                "answer_id": 76307742,
                "question_id": 76307599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In problems like this it is important to determine where the error is coming from. Your pipeline is doing two different things: Using `curl` to fetch the data, and then `jq` to parse it. Your first goal is to find out whether it is `curl` or `jq` that is giving you the error.\r\n\r\nSo, save the results of `curl` to a file:\r\n\r\n    curl -c - &quot;https://sample.com&quot; \\\r\n        -H &#39;User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/110.0&#39; \\\r\n        -H &#39;Accept: application/json, text/plain, */*&#39; \\\r\n        -s &gt; data.txt\r\n\r\nand then if that doesn&#39;t give you an error, then you can:\r\n\r\n    jq .data.name.status data.txt\r\n\r\nThis lets you focus on where the problem is.",
                "title": "&quot;parse error&quot; when I curl to fetch some data and parse it with jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1684769286,
        "creation_date": 1684768379,
        "last_edit_date": 1684769286,
        "question_id": 76307599,
        "body_markdown": "```\r\ncurl -c - &quot;https://sample.com&quot; -H &#39;User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/110.0&#39; -H &#39;Accept: application/json, text/plain, */*&#39; -s | jq .data.name.status\r\n```\r\n\r\nhow can i fix parse error: Invalid numeric literal at line 37, column 3 ?",
        "link": "https://stackoverflow.com/questions/76307599/parse-error-when-i-curl-to-fetch-some-data-and-parse-it-with-jq",
        "title": "&quot;parse error&quot; when I curl to fetch some data and parse it with jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1684774878,
                "creation_date": 1684774878,
                "answer_id": 76308446,
                "question_id": 76308296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; which would have as key the first two words\r\n\r\nYou can `def`ine a function that splits at the second slash, then usi it to `group_by` the input array, creating an array of arrays, then use `INDEX` to turn it into an object, using the same function on the `first` item.\r\n```sh\r\ndef f: .[:indices(&quot;/&quot;)[1]];\r\ngroup_by(f) | INDEX(first | f)\r\n```\r\n```json\r\n{\r\n  &quot;nonprod/global&quot;: [\r\n    &quot;nonprod/global/app/sit01&quot;,\r\n    &quot;nonprod/global/app/dev02&quot;,\r\n    &quot;nonprod/global/app/dev03&quot;\r\n  ],\r\n  &quot;prod/na&quot;: [\r\n    &quot;prod/na/app/prod01&quot;\r\n  ],\r\n  &quot;test/eu&quot;: [\r\n    &quot;test/eu/app/cust01&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/nhDPe1J691H)",
                "title": "Create object starting from a list of string with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684776053,
                "creation_date": 1684776053,
                "answer_id": 76308576,
                "question_id": 76308296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `+=` to add to an array. If the key doesn&#39;t exist, jq will create it on the fly (`null + []` evaluates to `[]`):\r\n```sh\r\nreduce (.[] | capture(&quot;^(?&lt;env&gt;(?&lt;type&gt;[^/]*/[^/]*).*)$&quot;)) as {$env, $type} \r\n({}; .[$type] += [$env])\r\n```\r\n```json\r\n{\r\n  &quot;nonprod/global&quot;: [\r\n    &quot;nonprod/global/app/sit01&quot;,\r\n    &quot;nonprod/global/app/dev02&quot;,\r\n    &quot;nonprod/global/app/dev03&quot;\r\n  ],\r\n  &quot;prod/na&quot;: [\r\n    &quot;prod/na/app/prod01&quot;\r\n  ],\r\n  &quot;test/eu&quot;: [\r\n    &quot;test/eu/app/cust01&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/72TIrzt9VIC)",
                "title": "Create object starting from a list of string with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1684779072,
        "creation_date": 1684773612,
        "last_edit_date": 1684779072,
        "question_id": 76308296,
        "body_markdown": "I would like to create a json object starting with a list of string in json format as the following\r\n\r\n```json\r\n[\r\n  &quot;nonprod/global/app/sit01&quot;,\r\n  &quot;nonprod/global/app/dev02&quot;,\r\n  &quot;prod/na/app/prod01&quot;,\r\n  &quot;test/eu/app/cust01&quot;,\r\n  &quot;nonprod/global/app/dev03&quot;\r\n]\r\n```\r\n\r\nWhat I would like to obtain is a map of lists of strings which would have as key the first two words of the string from the list and as value the strings that starts with that specific key.\r\n\r\nI&#39;ve tried the following:\r\n\r\n```\r\njq &#39;reduce (.[] | capture(&quot;(?&lt;env_type&gt;([^/]*/[^/]*))&quot;).env_type as $key | {($key) : [.]}) as $item ({}; . *= $item)&#39;\r\n```\r\n\r\nAnd obtained:\r\n\r\n```json\r\n{\r\n  &quot;nonprod/global&quot;: [\r\n    &quot;nonprod/global/app/dev03&quot;\r\n  ],\r\n  &quot;prod/na&quot;: [\r\n    &quot;prod/na/app/prod01&quot;\r\n  ],\r\n  &quot;test/eu&quot;: [\r\n    &quot;test/eu/app/cust01&quot;\r\n  ],\r\n  &quot;prod/eu&quot;: [\r\n    &quot;prod/eu/app/prod01&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;m expecting:\r\n\r\n```json\r\n{\r\n  &quot;nonprod/global&quot;:[\r\n    &quot;nonprod/global/app/sit01&quot;,\r\n    &quot;nonprod/global/app/dev02&quot;,\r\n    &quot;nonprod/global/app/dev03&quot;\r\n  ],\r\n  &quot;prod/eu&quot;:[\r\n    &quot;prod/eu/app/prod01&quot;\r\n  ],\r\n  \r\n  &quot;prod/na&quot;:[\r\n    &quot;prod/na/app/prod01&quot;\r\n  ],\r\n  &quot;test/eu&quot;:[\r\n    &quot;test/eu/app/cust01&quot;\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76308296/create-object-starting-from-a-list-of-string-with-jq",
        "title": "Create object starting from a list of string with jq"
    },
    {
        "tags": [
            "json",
            "jq",
            "winmerge"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684828179,
                "post_id": 76312374,
                "comment_id": 134570012,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19973458,
                    "reputation": 11,
                    "user_id": 14638379,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/4Xmqd.png?s=256",
                    "display_name": "Oshida_BCF",
                    "link": "https://stackoverflow.com/users/14638379/oshida-bcf"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684832028,
                "post_id": 76312374,
                "comment_id": 134570886,
                "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": 1684866961,
                "post_id": 76312374,
                "comment_id": 134579214,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1684873781,
                "creation_date": 1684873781,
                "answer_id": 76318447,
                "question_id": 76312374,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming we have only to deal with top-level keys, the following approach would suffice.\r\n\r\n\r\ninput.json:\r\n```\r\n{&quot;b&quot;:1, &quot;a&quot;:2, &quot;x&quot;: 3}\r\n```\r\n\r\nreference.json\r\n```\r\n{&quot;a&quot;:10, &quot;b&quot;:20, &quot;y&quot;: 30}\r\n```\r\n\r\n```\r\n&lt; input.json | jq --argfile reference reference.json &#39;\r\n  . as $in\r\n  | ($reference|keys_unsorted) as $refkeys\r\n  | (keys_unsorted - $refkeys) as $remainder\r\n  | reduce ($refkeys[], $remainder[]) as $k ({};\r\n      if $in|has($k) then .[$k] = $in[$k] else . end)\r\n&#39;\r\n```\r\n\r\nThere are of course many ways to provide the two JSON files.",
                "title": "JQ : Sort a JSON file using another JSON as &quot;order&quot; model"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684873781,
        "creation_date": 1684827972,
        "last_edit_date": 1684832013,
        "question_id": 76312374,
        "body_markdown": "JQ : Sort a JSON file using another JSON as &quot;order&quot; model\r\n\r\nI&#39;m trying to compare two JSON file, but because a lot of &quot;reordering&quot; happened, i wish to &quot;sort&quot; the second file using the first one as a &quot;model&quot;, basically moving all the fields to match the position in the first one.\r\n\r\n\r\nI&#39;m using winmerge which use a plugin that&#39;s actually just JQ, so i can&#39;t pass only one file and i need to pass the two together\r\n\r\nis there an argument for this \r\nI know there is &quot;-S&quot; but that sort both files\r\n\r\nHere are two of the files i&#39;m using, there are a lil big also don&#39;t worry about it&#39;s content\r\n\r\nhttps://pastebin.com/Z8p1nVDs `Left side`\r\n\r\nhttps://pastebin.com/X3Jq42S0 `Right side`\r\n",
        "link": "https://stackoverflow.com/questions/76312374/jq-sort-a-json-file-using-another-json-as-order-model",
        "title": "JQ : Sort a JSON file using another JSON as &quot;order&quot; model"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1684853345,
                "post_id": 76315906,
                "comment_id": 134576182,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19642851,
                    "reputation": 174,
                    "user_id": 14378530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/83cb86cebbb24605caaefb544ce07705?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Burps",
                    "link": "https://stackoverflow.com/users/14378530/burps"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684854297,
                "post_id": 76315906,
                "comment_id": 134576463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684854509,
                "post_id": 76315906,
                "comment_id": 134576521,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1684854318,
                "creation_date": 1684854318,
                "answer_id": 76316191,
                "question_id": 76315906,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`with_entries`][1] to be able to [`select()`][2] the object where your condition match. \r\n\r\nThen update the `.value.autitScore` to something new:\r\n\r\n```\r\nwith_entries(select(.value?.satelliteName? == &quot;us2.storj.io:7777&quot;).value.auditScore = 999)\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n##### [JqPlay Demo](https://jqplay.org/s/byObRV5WfMl)\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries\r\n  [2]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "jq : update sub-value 1 when sub-value 2 matches a value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684854560,
        "creation_date": 1684852391,
        "last_edit_date": 1684854560,
        "question_id": 76315906,
        "body_markdown": "I have the following dataset : \r\n```json\r\n{\r\n  &quot;storageSummary&quot;: 68624392000000,\r\n  &quot;audit1&quot;: {\r\n    &quot;auditScore&quot;: 1,\r\n    &quot;suspensionScore&quot;: 1,\r\n    &quot;onlineScore&quot;: 0.99743587,\r\n    &quot;satelliteName&quot;: &quot;us2.storj.io:7777&quot;\r\n  },\r\n  &quot;audit2&quot;: {\r\n    &quot;auditScore&quot;: 1,\r\n    &quot;suspensionScore&quot;: 1,\r\n    &quot;onlineScore&quot;: 0.9992917,\r\n    &quot;satelliteName&quot;: &quot;saltlake.tardigrade.io:7777&quot;\r\n  },\r\n  &quot;audit3&quot;: {\r\n    &quot;auditScore&quot;: 1,\r\n    &quot;suspensionScore&quot;: 1,\r\n    &quot;onlineScore&quot;: 0.99930555,\r\n    &quot;satelliteName&quot;: &quot;ap1.storj.io:7777&quot;\r\n  }\r\n}\r\n```\r\n\r\nI need (that should be quite simple though...) to update the `auditScore` when `satelliteName` is `us2.storj.io:7777`\r\n\r\nEDIT : \r\nI tried the following : \r\n`.[]|select(.satelliteName==&quot;us2.storj.io:7777&quot;)` : it only works if I remove the 1st entry in my dataset : `&quot;storageSummary&quot;: 68624392000000,`, otherwise, I get `jq: error (at &lt;stdin&gt;:20): Cannot index number with string &quot;satelliteName&quot;`\r\n\r\n\r\nI tried with map/select/to_entries (I must admit that jq is a bit of wizard to me...), but could not succeed yet. And apparently, I&#39;m not good to define clearly my request to google...\r\n\r\nThanks for your help.",
        "link": "https://stackoverflow.com/questions/76315906/jq-update-sub-value-1-when-sub-value-2-matches-a-value",
        "title": "jq : update sub-value 1 when sub-value 2 matches a value"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1684860365,
                "post_id": 76316881,
                "comment_id": 134577962,
                "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": 1684861113,
                "post_id": 76316881,
                "comment_id": 134578126,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1684866729,
                "creation_date": 1684866729,
                "answer_id": 76317711,
                "question_id": 76316881,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "     jq &#39;.Obj | map(select(.field2 == true))&#39; &lt;&lt;&lt; &quot;$obj&quot;\r\n\r\nYou can then tack on a call to `length`, or perhaps you would consider something like:\r\n\r\n    .Obj | map(select(.field2 == true)) | ., length\r\n\r\n",
                "title": "select and convert to comma separated array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1684866729,
        "creation_date": 1684859276,
        "last_edit_date": 1684861651,
        "question_id": 76316881,
        "body_markdown": "I have a json object in a bash script that looks like\r\n\r\n    obj={ &quot;Obj&quot;: [ {&quot;field1&quot;: a, &quot;field2&quot;: true}, \r\n     {&quot;field1&quot;: b, &quot;field2&quot;: true},\r\n     {&quot;field1&quot;: c, &quot;field2&quot;: false},\r\n     {&quot;field1&quot;: d, &quot;field2&quot;: true}]}\r\n\r\nI would like to filter it so that I get an array with items that have `field2` set to `true`\r\nand then get its length (so in the example it would return 3 of the 4 items)\r\n\r\nI tried\r\n\r\n    r=`echo $obj | jq &#39;.Obj | select(.field2 == true)&#39;`\r\n    r=&quot;[$r]&quot;\r\n    echo $r\r\n\r\n but this gives the elements without commas between them \r\n\r\n    [ {&quot;field1&quot;: a, &quot;field2&quot;: true} {&quot;field1&quot;: b, &quot;field2&quot;: true} {&quot;field1&quot;: d, &quot;field2&quot;: true}]\r\n\r\nand I cant then use `jq length`\r\n\r\nHow do I get\r\n \r\n\r\n     [ {&quot;field1&quot;: a, &quot;field2&quot;: true}, {&quot;field1&quot;: b, &quot;field2&quot;: true},{&quot;field1&quot;: d, &quot;field2&quot;: true}]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76316881/select-and-convert-to-comma-separated-array-with-jq",
        "title": "select and convert to comma separated array with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1684888887,
                "last_edit_date": 1684888887,
                "creation_date": 1684886145,
                "answer_id": 76319296,
                "question_id": 76319135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do it is create a range of all the indexes of the arrays and build a new object by combining the corresponding elements:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nnewValArr=&#39;\r\n[{ &quot;firstValue&quot;: &quot;foo&quot;, &quot;secondValue&quot;: &quot;bar&quot;},\r\n { &quot;firstValue&quot;: &quot;baz&quot;, &quot;secondValue&quot;: &quot;qux&quot;}\r\n]\r\n&#39;\r\n\r\njq -n --argjson newval &quot;$newValArr&quot; --argfile master masterfile.json &#39;\r\n   { value: [ range($master.value | length)\r\n              | . as $n\r\n              | $master.value[$n] * { properties: { newObject: $newval[$n] } }\r\n            ]\r\n   }&#39;\r\n```\r\n\r\noutputs\r\n\r\n```none\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;abc&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;stuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;foo&quot;,\r\n          &quot;secondValue&quot;: &quot;bar&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;def&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;morestuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;baz&quot;,\r\n          &quot;secondValue&quot;: &quot;qux&quot;\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nOr another approach that uses `transpose` to [zip the two arrays][1] together and then merges them:\r\n\r\n```sh\r\njq --argjson newval &quot;$newValArr&quot; &#39;\r\n   .value |= [ [ ., $newval ] | transpose[] | .[0] * { properties: { newObject: .[1] }} ]\r\n&#39; masterfile.json\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/70831992/parse-json-with-jq-and-zip-two-arrays",
                "title": "JQ: Adding a single JSON object to another JSON object in order of index/corresponding order"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1684900932,
                "creation_date": 1684900932,
                "answer_id": 76320017,
                "question_id": 76319135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` which, when applied to an array, generates indices in the `.key` field, which then can be used to index into the imported variable. Then, just `map` over the result array to construct your final objects.\r\n```sh\r\njq --argjson vals &quot;$newValArr&quot; &#39;.value |= (to_entries | map(\r\n  $vals[.key] as $newObject | .value | .properties += {$newObject}\r\n))&#39; masterfile.json\r\n```\r\n```json\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;abc&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;stuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;foo&quot;,\r\n          &quot;secondValue&quot;: &quot;bar&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;def&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;morestuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;baz&quot;,\r\n          &quot;secondValue&quot;: &quot;qux&quot;\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "JQ: Adding a single JSON object to another JSON object in order of index/corresponding order"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1684900932,
        "creation_date": 1684883047,
        "last_edit_date": 1684883175,
        "question_id": 76319135,
        "body_markdown": "I have two simple JSON objects, I&#39;m trying to add a single object from a Bash variable `newValArr` in order of the corresponding objects to the `masterfile.json`. They appear as following:  \r\n  \r\n`newValArr`  \r\n```\r\n[{ &quot;firstValue&quot;: &quot;foo&quot;, &quot;secondValue&quot;: &quot;bar&quot;},\r\n { &quot;firstValue&quot;: &quot;baz&quot;, &quot;secondValue&quot;: &quot;qux&quot;},\r\n ...\r\n]\r\n```\r\n  \r\n`masterfile.json`  \r\n```\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;abc&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;stuff&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;def&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;morestuff&quot;\r\n      }\r\n    },\r\n...\r\n  ]\r\n}\r\n\r\n```  \r\n  \r\nI&#39;ve created the following in Bash that adds the `firstValue` and `secondValue` object in the intended spot in the `value` array of objects, here is the script:  \r\n\r\n```\r\njq --argjson newvalues &quot;${newValArr}&quot; &#39;.value[].properties.newObject += $newvalues[0]&#39; masterfile.json &gt; newoutput.json\r\n```  \r\n  \r\nAnd here is the current JSON output:  \r\n\r\n`newoutput.json`\r\n```\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;abc&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;stuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;foo&quot;, \r\n          &quot;secondValue&quot;: &quot;bar&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;def&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;otherstuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;foo&quot;, \r\n          &quot;secondValue&quot;: &quot;bar&quot;\r\n        }\r\n      }\r\n    },\r\n...\r\n  ]\r\n}\r\n\r\n```  \r\n  \r\nWith the desired output being:  \r\n  \r\n```\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;abc&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;stuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;foo&quot;, \r\n          &quot;secondValue&quot;: &quot;bar&quot;\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;def&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;blah&quot;: &quot;otherstuff&quot;,\r\n        &quot;newObject&quot;: {\r\n          &quot;firstValue&quot;: &quot;baz&quot;, \r\n          &quot;secondValue&quot;: &quot;qux&quot;\r\n        }\r\n      }\r\n    },\r\n...\r\n  ]\r\n}\r\n\r\n```  \r\n  \r\nThe problem obviously is that the same `newValArr` object is being placed into every single `newObject` as we&#39;re continually referencing the same index. If we don&#39;t specify the index, then all the `newValArr` objects will be placed into each `newObject`, and I&#39;m not quite sure if it&#39;s even possible to iterate through the indexes in JQ like we would in Bash using `newValArr[@]` for example so that each index could be assigned in order. Is this possible in JQ? Or must an entirely different method be used?  \r\nThe two JSON&#39;s will always have the same number of objects, in the same order, no need to worry about that.\r\n  \r\nI&#39;ve looked into implementing this using to_entires, however it doesn&#39;t seem compatible with what I&#39;m trying to accomplish.",
        "link": "https://stackoverflow.com/questions/76319135/jq-adding-a-single-json-object-to-another-json-object-in-order-of-index-corresp",
        "title": "JQ: Adding a single JSON object to another JSON object in order of index/corresponding order"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685013277,
                "post_id": 76331173,
                "comment_id": 134602980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12878361,
                    "reputation": 11,
                    "user_id": 10423176,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-WJQekI4fn6U/AAAAAAAAAAI/AAAAAAAAABU/Qsfny4u6vMg/s256-rj/photo.jpg",
                    "display_name": "El Amo",
                    "link": "https://stackoverflow.com/users/10423176/el-amo"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685049670,
                "post_id": 76331173,
                "comment_id": 134611082,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1685010165,
                "creation_date": 1685010165,
                "answer_id": 76331256,
                "question_id": 76331173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n```sh\r\njq &#39;map(&quot;\\(.name): \\(.status)&quot;)&#39;\r\n```",
                "title": "What&#39;s the easiest way to map JSON array values to a dictionary using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685057704,
                "creation_date": 1685057704,
                "answer_id": 76336814,
                "question_id": 76331173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Working through the requirements in your comment. Given:\r\n```sh\r\n$ cat api_fm.json\r\n[\r\n  {&quot;name&quot;:&quot;plugin&quot;, &quot;status&quot;:&quot;Started&quot;},\r\n  {&quot;name&quot;:&quot;c_docker_2&quot;, &quot;status&quot;:&quot;Started&quot;},\r\n  {&quot;name&quot;:&quot;c_docker_5&quot;, &quot;status&quot;:&quot;Started&quot;},\r\n  {&quot;name&quot;:&quot;c_docker_4&quot;, &quot;status&quot;:&quot;Started&quot;},\r\n  {&quot;name&quot;:&quot;c_docker_3&quot;, &quot;status&quot;:&quot;Started&quot;},\r\n  {&quot;name&quot;:&quot;c_docker_1&quot;, &quot;status&quot;:&quot;Started&quot;}\r\n]\r\n```\r\nWe can produce tab-separated name-status pairs like\r\n```sh\r\n$ jq -r &#39;.[] | [.name, .status] | @tsv&#39; api_fm.json\r\nplugin\tStarted\r\nc_docker_2\tStarted\r\nc_docker_5\tStarted\r\nc_docker_4\tStarted\r\nc_docker_3\tStarted\r\nc_docker_1\tStarted\r\n```\r\n\r\nThen, to create the bash associative array\r\n```bash\r\ndeclare -A prod\r\n\r\nwhile IFS=$&#39;\\t&#39; read -r name status; do\r\n    prod[&quot;$name&quot;]=$status\r\ndone &lt; &lt;(\r\n    jq -r &#39;.[] | [.name, .status] | @tsv&#39; api_fm.json\r\n)\r\n\r\ndeclare -p prod\r\n```\r\n```bash\r\ndeclare -A prod=([c_docker_2]=&quot;Started&quot; [c_docker_3]=&quot;Started&quot; [c_docker_1]=&quot;Started&quot; [c_docker_4]=&quot;Started&quot; [c_docker_5]=&quot;Started&quot; [plugin]=&quot;Started&quot; )\r\n```",
                "title": "What&#39;s the easiest way to map JSON array values to a dictionary using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1719233259,
                "last_edit_date": 1719233259,
                "creation_date": 1719124255,
                "answer_id": 78657929,
                "question_id": 76331173,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The OP mentioned in the title of his post and in a comment that the output shall be a dictionary (and not an array of strings). I.e. a list of **key value pairs**\r\n\r\n    [\r\n      {&quot;name&quot;: &quot;plugin&quot;,     &quot;status&quot;: &quot;Started&quot;},\r\n      {&quot;name&quot;: &quot;c_docker_2&quot;, &quot;status&quot;: &quot;Started&quot;},\r\n      ...\r\n    ]\r\n\r\nshall be converted  to a **dictionary**\r\n\r\n    {\r\n       &quot;plugin&quot;:     &quot;Started&quot;,\r\n       &quot;c_docker_2&quot;: &quot;Started&quot;,\r\n       ...\r\n    }\r\n\r\nThis is achieved via\r\n\r\n    jq &quot;map({(.name): .status}) | add&quot;\r\n\r\nThe first expression `map({(.name): .status})` converts the array elements - e.g  `{&quot;name&quot;: &quot;plugin&quot;, &quot;status&quot;: &quot;Started&quot;}` to  `{&quot;plugin&quot;: &quot;Started&quot;}`.The &quot;add&quot; converts the array of records to a dictionary.\r\n   ",
                "title": "What&#39;s the easiest way to map JSON array values to a dictionary using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1719233259,
        "creation_date": 1685009655,
        "last_edit_date": 1685014259,
        "question_id": 76331173,
        "body_markdown": "How can I make a key value dictionary using jq?\r\n\r\nIf I do: `cat api_fm.json | jq -r &quot;[ .[].name, .[].status ]&quot;`\r\nI receive:\r\n```\r\n[\r\n  &quot;plugin&quot;,\r\n  &quot;c_docker_2&quot;,\r\n  &quot;c_docker_5&quot;,\r\n  &quot;c_docker_4&quot;,\r\n  &quot;c_docker_3&quot;,\r\n  &quot;c_docker_1&quot;,\r\n  &quot;Started&quot;,\r\n  &quot;Started&quot;,\r\n  &quot;Started&quot;,\r\n  &quot;Started&quot;,\r\n  &quot;Started&quot;,\r\n  &quot;Started&quot;\r\n]\r\n```\r\nSo, I would like to map the name with the status like this:\r\n```\r\n[\r\n   &quot;plugin: started&quot;\r\n...\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76331173/whats-the-easiest-way-to-map-json-array-values-to-a-dictionary-using-jq",
        "title": "What&#39;s the easiest way to map JSON array values to a dictionary using jq?"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1685019053,
                "creation_date": 1685019053,
                "answer_id": 76332461,
                "question_id": 76332247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[] |= …` (or `map_values(…)`) lets you manipulate the contents of objects without losing the outer structure. Nest it twice to go two levels deep. `select(.cycle != null)` is your main filter, but I&#39;ve also added `select(. != {})` on the intermediate level as your desired output didn&#39;t include `&quot;foo&quot;: {}`.\r\n```sh\r\njq &#39;.[] |= (.[] |= select(.cycle != null) | select(. != {}))&#39;\r\n```\r\n```json\r\n{\r\n  &quot;bar&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;simple&quot;\r\n    }\r\n  },\r\n  &quot;qux&quot;: {\r\n    &quot;d&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;,\r\n        &quot;z&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;complex&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/FIqf5nhArdo)",
                "title": "Filtering out sections in nested object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1685023785,
        "creation_date": 1685017464,
        "last_edit_date": 1685023785,
        "question_id": 76332247,
        "body_markdown": "Given the following json:\r\n```json\r\n{\r\n  &quot;foo&quot;: {},\r\n  &quot;bar&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;simple&quot;\r\n    },\r\n    &quot;b&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;\r\n      ],\r\n      &quot;cycle&quot;: null\r\n    }\r\n  },\r\n  &quot;baz&quot;: {\r\n    &quot;c&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;y&quot;\r\n      ],\r\n      &quot;cycle&quot;: null\r\n    }\r\n  },\r\n  &quot;qux&quot;: {\r\n    &quot;d&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;,\r\n        &quot;z&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;complex&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI&#39;d like to drop all objects in the top-level object which have `&quot;cycle == null&quot;`. When filtering for `&quot;cycle&quot;`, I don&#39;t know how to access fields from earlier filters:\r\n```shell\r\n$ jq &#39;.[] | .[] | select(.cycle != null)&#39; data.json\r\n{\r\n  &quot;tags&quot;: [\r\n    &quot;x&quot;,\r\n    &quot;y&quot;\r\n  ],\r\n  &quot;cycle&quot;: &quot;simple&quot;\r\n}\r\n{\r\n  &quot;tags&quot;: [\r\n    &quot;x&quot;,\r\n    &quot;y&quot;,\r\n    &quot;z&quot;\r\n  ],\r\n  &quot;cycle&quot;: &quot;complex&quot;\r\n}\r\n```\r\n\r\nI&#39;d like to keep the structure of the matching entries, something like this:\r\n```json\r\n{\r\n  &quot;bar&quot;: {\r\n    &quot;a&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;simple&quot;\r\n    }\r\n  },\r\n  &quot;qux&quot;: {\r\n    &quot;d&quot;: {\r\n      &quot;tags&quot;: [\r\n        &quot;x&quot;,\r\n        &quot;y&quot;,\r\n        &quot;z&quot;\r\n      ],\r\n      &quot;cycle&quot;: &quot;complex&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nI was hoping to write something like this `jq &#39;.*.*. | select(.cycle != null)&#39;` so that I wouldn&#39;t need to manually re-assemble the original structure, but didn&#39;t understand wildcards.\r\n",
        "link": "https://stackoverflow.com/questions/76332247/filtering-out-sections-in-nested-object",
        "title": "Filtering out sections in nested object"
    },
    {
        "tags": [
            "git",
            "pip",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10847936,
                    "reputation": 96652,
                    "user_id": 7976758,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/512cfbaf98d63ca4acd57b2df792aec6?s=256&d=identicon&r=PG",
                    "display_name": "phd",
                    "link": "https://stackoverflow.com/users/7976758/phd"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1685026405,
                "post_id": 76333390,
                "comment_id": 134606484,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13482976,
                    "reputation": 41,
                    "user_id": 9727676,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pJ17x.jpg?s=256",
                    "display_name": "Sai Teja Makani",
                    "link": "https://stackoverflow.com/users/9727676/sai-teja-makani"
                },
                "reply_to_user": {
                    "account_id": 10847936,
                    "reputation": 96652,
                    "user_id": 7976758,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/512cfbaf98d63ca4acd57b2df792aec6?s=256&d=identicon&r=PG",
                    "display_name": "phd",
                    "link": "https://stackoverflow.com/users/7976758/phd"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685453686,
                "post_id": 76333390,
                "comment_id": 134659759,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1685045476,
        "creation_date": 1685024815,
        "last_edit_date": 1685045476,
        "question_id": 76333390,
        "body_markdown": "$pip install jq\r\nCollecting jq\r\n  Using cached jq-1.4.1.tar.gz (2.7 MB)\r\n  Installing build dependencies ... done\r\n  Getting requirements to build wheel ... done\r\n  Preparing metadata (pyproject.toml) ... done\r\nBuilding wheels for collected packages: jq\r\n  Building wheel for jq (pyproject.toml) ... error\r\n  error: subprocess-exited-with-error\r\n  \r\n  &#215; Building wheel for jq (pyproject.toml) did not run successfully.\r\n  │ exit code: 1\r\n  ╰─&gt; [5 lines of output]\r\n      running bdist_wheel\r\n      running build\r\n      running build_ext\r\n      Executing: ./configure CFLAGS=-fPIC --prefix=C:\\Users\\SaiTejaMakani\\AppData\\Local\\Temp\\pip-install-_7jksk26\\jq_bc859a8c4bf54fa0a70720ec3ecd5114\\_deps\\build\\onig-install-6.9.4\r\n      error: [WinError 2] The system cannot find the file specified\r\n      [end of output]\r\n\r\n  note: This error originates from a subprocess, and is likely not a problem with pip.\r\n  ERROR: Failed building wheel for jq\r\nFailed to build jq\r\nERROR: Could not build wheels for jq, which is required to install pyproject.toml-based projects\r\n\r\n[notice] A new release of pip available: 22.2.2 -&gt; 23.1.2\r\n[notice] To update, run: python.exe -m pip install --upgrade pip\r\n\r\nI have created anempty setup.py in my project to tryitbut no luck. Havent found any solution so far.",
        "link": "https://stackoverflow.com/questions/76333390/unable-to-install-jq-in-my-local-windows-11-machine-building-wheel-for-jq-pypr",
        "title": "unable to install jq in my local windows 11 machine. Building wheel for jq (pyproject.toml) ... error"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq",
            "ipv4"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1685130795,
                "creation_date": 1685130795,
                "answer_id": 76343875,
                "question_id": 76343829,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply split the ip and convert it to an array of numbers:\r\n\r\n```\r\nsort_by(.ip | split(&quot;.&quot;)[] | tonumber)\r\n```\r\n\r\nFull command (note that the reassigning (`.|=`) at the beginning is not needed):\r\n\r\n```\r\n$ echo &#39;\r\n    {&quot;name&quot;: &quot;dns&quot;, &quot;ip&quot;: &quot;4.4.4.4&quot;}\r\n    {&quot;name&quot;: &quot;host1&quot;, &quot;ip&quot;: &quot;10.9.9.9&quot;}\r\n    {&quot;name&quot;: &quot;host2&quot;, &quot;ip&quot;: &quot;10.10.10.10&quot;}\r\n&#39; | jq -sr &#39;sort_by(.ip | split(&quot;.&quot;)[] | tonumber) | .[] | [.name, .ip] | @tsv&#39;\r\n\r\ndns\t4.4.4.4\r\nhost1\t10.9.9.9\r\nhost2\t10.10.10.10\r\n```",
                "title": "How can I sort by IP address in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1685131081,
        "creation_date": 1685130254,
        "question_id": 76343829,
        "body_markdown": "How can I use [jq](https://stedolan.github.io/jq/) to sort an array of objects by an IPv4 address value as a 32-bit integer rather than alphanumerically?\r\n\r\nAn illustration of what I mean with some extra formatting for visual clarity:\r\n\r\n```\r\n$ echo &#39;\r\n    {&quot;name&quot;: &quot;dns&quot;, &quot;ip&quot;: &quot;4.4.4.4&quot;}\r\n    {&quot;name&quot;: &quot;host1&quot;, &quot;ip&quot;: &quot;10.9.9.9&quot;}\r\n    {&quot;name&quot;: &quot;host2&quot;, &quot;ip&quot;: &quot;10.10.10.10&quot;}\r\n&#39; |jq -sr &#39;.|=sort_by(.ip) |.[] |[.name, .ip] |@tsv&#39;\r\n\r\nhost2\t10.10.10.10\r\nhost1\t10.9.9.9\r\ndns\t4.4.4.4\r\n```\r\n\r\nThis `|=sort_by(.ip)` sorts in alphanumeric order, but I&#39;d like the array sorted &quot;IPnumerically&quot;. If I have it in a TSV format like this, I can use external tools (such as this non-POSIX `-V` extension to `sort`) to do this externally afterward, but is there a way to do this within `jq`?\r\n\r\n```\r\n$ echo &#39;\r\n    {&quot;name&quot;: &quot;dns&quot;, &quot;ip&quot;: &quot;4.4.4.4&quot;}\r\n    {&quot;name&quot;: &quot;host1&quot;, &quot;ip&quot;: &quot;10.9.9.9&quot;}\r\n    {&quot;name&quot;: &quot;host2&quot;, &quot;ip&quot;: &quot;10.10.10.10&quot;}\r\n    &#39; |jq -sr &#39;.|=sort_by(.ip) |.[] |[.name, .ip] |@tsv&#39; |sort -t$&#39;\\t&#39; -Vk2\r\ndns\t4.4.4.4\r\nhost1\t10.9.9.9\r\nhost2\t10.10.10.10\r\n```",
        "link": "https://stackoverflow.com/questions/76343829/how-can-i-sort-by-ip-address-in-jq",
        "title": "How can I sort by IP address in jq?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1685170718,
                "post_id": 76345607,
                "comment_id": 134626954,
                "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": 1685170756,
                "post_id": 76345607,
                "comment_id": 134626956,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1685196462,
                "last_edit_date": 1685196462,
                "creation_date": 1685170822,
                "answer_id": 76345723,
                "question_id": 76345607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since your example is sufficiently uniform, you could get away with:\r\n```\r\njq -r &#39;\r\n  to_entries\r\n  | (.[0].value[0]|keys_unsorted) as $keys\r\n  | .[]\r\n  | .key as $key\r\n  | .value[]\r\n  | [$key, .[$keys[]] ]\r\n  | @csv\r\n&#39;\r\n```\t\r\n\r\nWith your input, the first row would be:\r\n```\r\n&quot;1122595&quot;,&quot;103.100.159.212:443&quot;,&quot;ip:port&quot;,&quot;botnet_cc&quot;,&quot;win.cobalt_strike&quot;,&quot;Agentemis,BEACON,CobaltStrike,cobeacon&quot;,&quot;Cobalt Strike&quot;,&quot;2023-05-27 02:31:39&quot;,,100,,&quot;CLOUDIE-AS-AP Cloudie Limited,CobaltStrike,cs-watermark-666666&quot;,&quot;0&quot;,&quot;drb_ra&quot;\r\n```\r\n\r\nYou could also use `[&quot;key&quot;] + $keys` (for example) to produce a CVS header:\r\n```\r\nto_entries\r\n| (.[0].value[0]|keys_unsorted) as $keys\r\n| [&quot;key&quot;] + $keys,\r\n  (.[]\r\n   | .key as $key\r\n   | .value[]\r\n  | [$key, .[$keys[]] ])\r\n| @csv\r\n```\r\n\r\n",
                "title": "How to convert specific JSON file to CSV file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1687671174,
        "creation_date": 1685168582,
        "last_edit_date": 1685291976,
        "question_id": 76345607,
        "body_markdown": "I am trying to export a very large JSON file (zip compressed: [full_ip-port.json][1]) to CSV.\r\n\r\nThe file consists of a single JSON object that has a regular structure.  Here is a representative extract (obtained by `[to_entries[0,1]] | from_entries`):\r\n```\r\n{\r\n  &quot;1122595&quot;: [\r\n    {\r\n      &quot;ioc_value&quot;: &quot;103.100.159.212:443&quot;,\r\n      &quot;ioc_type&quot;: &quot;ip:port&quot;,\r\n      &quot;threat_type&quot;: &quot;botnet_cc&quot;,\r\n      &quot;malware&quot;: &quot;win.cobalt_strike&quot;,\r\n      &quot;malware_alias&quot;: &quot;Agentemis,BEACON,CobaltStrike,cobeacon&quot;,\r\n      &quot;malware_printable&quot;: &quot;Cobalt Strike&quot;,\r\n      &quot;first_seen_utc&quot;: &quot;2023-05-27 02:31:39&quot;,\r\n      &quot;last_seen_utc&quot;: null,\r\n      &quot;confidence_level&quot;: 100,\r\n      &quot;reference&quot;: null,\r\n      &quot;tags&quot;: &quot;CLOUDIE-AS-AP Cloudie Limited,CobaltStrike,cs-watermark-666666&quot;,\r\n      &quot;anonymous&quot;: &quot;0&quot;,\r\n      &quot;reporter&quot;: &quot;drb_ra&quot;\r\n    }\r\n  ],\r\n  &quot;1122593&quot;: [\r\n    {\r\n      &quot;ioc_value&quot;: &quot;167.172.72.193:23&quot;,\r\n      &quot;ioc_type&quot;: &quot;ip:port&quot;,\r\n      &quot;threat_type&quot;: &quot;botnet_cc&quot;,\r\n      &quot;malware&quot;: &quot;elf.bashlite&quot;,\r\n      &quot;malware_alias&quot;: &quot;gayfgt,Gafgyt,qbot,torlus,lizkebab&quot;,\r\n      &quot;malware_printable&quot;: &quot;Bashlite&quot;,\r\n      &quot;first_seen_utc&quot;: &quot;2023-05-27 01:40:04&quot;,\r\n      &quot;last_seen_utc&quot;: null,\r\n      &quot;confidence_level&quot;: 75,\r\n      &quot;reference&quot;: &quot;https://bazaar.abuse.ch/sample/6c901ba15327da68159712a9726807fb08868309726c55ef202818bfde22a5a7/&quot;,\r\n      &quot;tags&quot;: &quot;Gafgyt&quot;,\r\n      &quot;anonymous&quot;: &quot;0&quot;,\r\n      &quot;reporter&quot;: &quot;abuse_ch&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n  [1]: https://threatfox.abuse.ch/export/json/ip-port/full/\r\n\r\n\r\nWhat I have so far:\r\n\r\nInner Part:\r\n\r\n    jq -r &#39;.[] | .[] | to_entries | map(.value) | @csv&#39; full_ip-port.json\r\n\r\nMissing ID:\r\n\r\n    jq -r &#39;{id: (. | keys[])} | to_entries | map(.value) | @csv&#39; full_ip-port.json\r\n\r\nHow can I bring it together to a nice and clean CSV file?",
        "link": "https://stackoverflow.com/questions/76345607/how-to-convert-specific-json-file-to-csv-file",
        "title": "How to convert specific JSON file to CSV file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1685269352,
                "creation_date": 1685269352,
                "answer_id": 76351011,
                "question_id": 76350965,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `reduce` all `inputs` into an object with `.id` as key, deep-merge using `*`, then iterate over the fields `.[]` to obtain a stream again (use the `-c` flag for compact output):\r\n```sh\r\njq -nc &#39;reduce inputs as $i ({}; .[$i.id] |= (. // {}) * $i) | .[]&#39; file*.json\r\n```\r\n```json\r\n{&quot;test&quot;:{&quot;a&quot;:2,&quot;b&quot;:3,&quot;c&quot;:8},&quot;id&quot;:&quot;850303847&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:3,&quot;b&quot;:3,&quot;c&quot;:4},&quot;id&quot;:&quot;2742540872&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:4,&quot;b&quot;:4,&quot;c&quot;:5},&quot;id&quot;:&quot;1358887220&quot;}\r\n```\r\n[Demo](https://jqplay.org/s/jwv8RuOYJuM)",
                "title": "Merge JSON Files via Bash or JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1685269664,
                "creation_date": 1685269664,
                "answer_id": 76351027,
                "question_id": 76350965,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is one way:\r\n``` sh\r\njq -nc &#39;\r\nreduce inputs as {$test, $id} ({};\r\n  .[$id] += $test\r\n)\r\n| keys_unsorted[] as $id\r\n| {test: .[$id], $id}&#39; files...\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/WknYLLZKi2n)&lt;/sup&gt;",
                "title": "Merge JSON Files via Bash or JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1685287906,
        "creation_date": 1685268718,
        "last_edit_date": 1685287906,
        "question_id": 76350965,
        "body_markdown": "I&#39;ve go files containing compressed JSONs. All JSONs having the same root fragments &quot;id&quot; and &quot;test&quot;:\r\n\r\n```\r\nfile1.json:\r\n{&quot;test&quot;:{&quot;a&quot;:2},&quot;id&quot;:&quot;850303847&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:3},&quot;id&quot;:&quot;2742540872&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:4},&quot;id&quot;:&quot;1358887220&quot;}\r\n\r\nfile2.json:\r\n{&quot;test&quot;:{&quot;b&quot;:3},&quot;id&quot;:&quot;850303847&quot;}\r\n{&quot;test&quot;:{&quot;b&quot;:3},&quot;id&quot;:&quot;2742540872&quot;}\r\n{&quot;test&quot;:{&quot;b&quot;:4},&quot;id&quot;:&quot;1358887220&quot;}\r\n\r\nfile3.json\r\n{&quot;test&quot;:{&quot;c&quot;:8},&quot;id&quot;:&quot;850303847&quot;}\r\n{&quot;test&quot;:{&quot;c&quot;:4},&quot;id&quot;:&quot;2742540872&quot;}\r\n{&quot;test&quot;:{&quot;c&quot;:5},&quot;id&quot;:&quot;1358887220&quot;}\r\n```\r\n\r\nI would like to merge these Files based on it&#39;s IDs resulting to:\r\n```\r\n{&quot;test&quot;:{&quot;a&quot;:2,&quot;b&quot;:3,&quot;c&quot;:8},&quot;id&quot;:&quot;850303847&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:3,&quot;b&quot;:3,&quot;c&quot;:4},&quot;id&quot;:&quot;2742540872&quot;}\r\n{&quot;test&quot;:{&quot;a&quot;:4,&quot;b&quot;:4,&quot;c&quot;:5},&quot;id&quot;:&quot;1358887220&quot;}\r\n```\r\n\r\nI&#39;ve looked into `jq -s` option for this but fail to find a way. Any ideas how to achieve in Bash (with or without JQ)? \r\n",
        "link": "https://stackoverflow.com/questions/76350965/merge-json-files-via-bash-or-jq",
        "title": "Merge JSON Files via Bash or JQ"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1685414722,
                "last_edit_date": 1685414722,
                "creation_date": 1685413996,
                "answer_id": 76361283,
                "question_id": 76361170,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Except for the ordering of the data rows, here&#39;s an all-jq solution:\r\n```\r\njq -r &#39;\r\n\r\ndef tocell:\r\n  &quot;&lt;td&gt;\\(.)&lt;/td&gt;&quot;;\r\n\r\ndef torow:\r\n  &quot;&lt;tr&gt;&quot;,\r\n  (.[]|tocell),\r\n  &quot;&lt;/tr&gt;&quot;;\r\n\r\ndef totable: \r\n  &quot;&lt;table border=1&gt;&quot;,\r\n  (.[] | torow),\r\n  &quot;&lt;/table&gt;&quot;;\r\n\r\n[[.[]] \r\n | (map(.date) | unique) as $dates\r\n | [&quot;NA&quot;] + $dates,  # header row\r\n   (group_by(.uid)\r\n    | .[]\r\n    | .[0].uid as $uid\r\n    | INDEX(.date) as $dict\r\n    | [$uid, $dict[$dates[]].reg]\r\n    | map(. // &quot;-&quot;) ) ]\r\n| totable\r\n&#39;\r\n```\r\n\r\nThe idea is first to produce one JSON array per row, and then to convert the result to HTML.",
                "title": "jq question regarding transposing json dataset"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1685420976,
        "creation_date": 1685411762,
        "last_edit_date": 1685420976,
        "question_id": 76361170,
        "body_markdown": "So I have an interesting issue. I have a json file that I need to convert in the following format preferably using Linux CLI tools. Is JQ a vehicle for that? if so I can use help with that. If not, I&#39;d love to know the logic with which to do it. My language of choice is PHP but I can convert pseudocode to actual code in php if you provide logic.\r\n\r\n# JSON FILE\r\n\r\n\r\n\r\n    {\r\n    &quot;30814&quot;: {\r\n        &quot;uid&quot;:       &quot;Joe.Jones&quot;,\r\n        &quot;date&quot;:       &quot;2023-05-02&quot;,\r\n        &quot;reg&quot;:       &quot;7.13&quot;,\r\n        &quot;ot&quot;:       &quot;0.00&quot;\r\n    },\r\n    &quot;30870&quot;: {\r\n        &quot;uid&quot;:       &quot;Joe.Jones&quot;,\r\n        &quot;date&quot;:       &quot;2023-05-03&quot;,\r\n        &quot;reg&quot;:       &quot;7.48&quot;,\r\n        &quot;ot&quot;:       &quot;0.00&quot;\r\n    },\r\n    &quot;30906&quot;: {\r\n        &quot;uid&quot;:       &quot;Hank.Joans&quot;,\r\n        &quot;date&quot;:       &quot;2023-05-02&quot;,\r\n        &quot;reg&quot;:       &quot;6.37&quot;,\r\n        &quot;ot&quot;:       &quot;0.00&quot;\r\n    },\r\n    &quot;31079&quot;: {\r\n        &quot;uid&quot;:       &quot;Some.User&quot;,\r\n        &quot;date&quot;:       &quot;2023-05-01&quot;,\r\n        &quot;reg&quot;:       &quot;5.82&quot;,\r\n        &quot;ot&quot;:       &quot;0.00&quot;\r\n    },\r\n    &quot;31125&quot;: {\r\n        &quot;uid&quot;:       &quot;Some.User&quot;,\r\n        &quot;date&quot;:       &quot;2023-05-02&quot;,\r\n        &quot;reg&quot;:       &quot;7.28&quot;,\r\n        &quot;ot&quot;:       &quot;0.00&quot;\r\n    }\r\n\r\n    }\r\n\r\n# EXPECTED OUTPUT\r\n\r\n    &lt;table border=1&gt;\r\n    &lt;tr&gt;\r\n     &lt;td&gt; NA\r\n     &lt;td&gt; 2023-05-01 &lt;td&gt; 2023-05-02 &lt;td&gt; 2023-05-03\r\n    &lt;tr&gt;\r\n      &lt;td&gt; Joe.Jones\r\n      &lt;td&gt; -  &lt;td&gt; 7.13/0.00  &lt;td&gt; 7.48/0.00\r\n    &lt;tr&gt;\r\n      &lt;td&gt; Hank.Jones\r\n      &lt;td&gt; - &lt;td&gt; 6.37/0.00 &lt;td&gt; -\r\n    &lt;tr&gt;\r\n      &lt;td&gt; Some.User\r\n      &lt;td&gt; 5.82/0.00 &lt;td&gt; 7.28/0.00 &lt;td&gt; -\r\n\r\n    &lt;/table&gt;\r\nI have a complete brainfog and don&#39;t even know what to try. I tried looking up google but this is a specific enough usecase where google searches are not helping me - or I am not searching for right things. The word transposing datasets keeps coming up in my searches but I don&#39;t know how to apply logic to solve this.",
        "link": "https://stackoverflow.com/questions/76361170/jq-question-regarding-transposing-json-dataset",
        "title": "jq question regarding transposing json dataset"
    },
    {
        "tags": [
            "json",
            "sorting",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11689602,
                    "reputation": 5139,
                    "user_id": 9568358,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/wUz4k.png?s=256",
                    "display_name": "Wimanicesir",
                    "link": "https://stackoverflow.com/users/9568358/wimanicesir"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685436146,
                "post_id": 76362983,
                "comment_id": 134655721,
                "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": 1685440746,
                "post_id": 76362983,
                "comment_id": 134656705,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1685457977,
                "last_edit_date": 1685457977,
                "creation_date": 1685438034,
                "answer_id": 76363305,
                "question_id": 76362983,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the current implementation of jq (meaning: this &quot;side-effect&quot; is not documented, it may change without notice), you could predetermine the order of the keys by successively building up your output object. To this end, you would iterate over the input object&#39;s keys in the order they are read using `keys_unsorted`, and set them in the output object, starting out with the empty object `{}`:\r\n```sh\r\njq &#39;input as $in | reduce keys_unsorted[] as $key ({}; .[$key] = $in[$key])&#39; \\\r\n  input.json output.json &gt; reordered_output.json\r\n```\r\n(Note that, confusingly, the second input file, here `output.json`, is referenced by the `input` filter.)\r\n\r\n---\r\nEdit: [It turned out](https://stackoverflow.com/questions/76362983/how-to-order-a-json-file-according-to-the-keys-of-another-json-file/76363305?noredirect=1#comment134660035_76363305) that the data is of a nested structure. While sample data is missing, let&#39;s consider all objects as nodes, and every other data type as leafs. In order to access both keys and values, change `keys_unsorted` to `to_entries` (which (for now, see above) has the same, desired &quot;side-effect&quot;), and elevate the logic into a named filter (function definition), so that it can be called recursively on `objects`.\r\n```sh\r\ndef reorder($in; $ref): $ref | reduce to_entries[] as {$key, $value} ({};\r\n  .[$key] = ($in[$key] | objects |= reorder(.; $value))\r\n);\r\nreorder(input; .)\r\n```\r\n",
                "title": "How to order a json file according to the keys of another json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1685583589,
        "creation_date": 1685435569,
        "last_edit_date": 1685583589,
        "question_id": 76362983,
        "body_markdown": "I have a translation management tool to which I upload a json file input.json. Next a translator does his/her translation job and the result is exported to a json file containing all the translations output.json. Both input.json and output.json contain the same keys but not the same values (these are the translations added/modified by the translator). More importantly the order of the keys in input.json and output.json is completely different. Functionally this does not matter but in pull requests the input.json is the &quot;old&quot; file that is compared to the &quot;new&quot; file being output.json. This generates a lot of diffs due to the changed order of the keys, mking reviews cumbersome. \r\nIs there an easy way to order output.json in the same way as input.json?\r\n\r\n \r\nI found that jq could be used to order input.json &quot;alphabetically&quot; so then I could afterwards order output.json alphabetically as well and this would kind of solve my problem but isn&#39;t it possible to use jq do actually take the order of the keys in input.json and apply that to output.json?\r\n\r\nHere is some demo data for input.json:\r\n```\r\n{\r\n  &quot;BathroomType&quot;: &quot;Type of bathroom&quot;,\r\n  &quot;BuildingType&quot;: &quot;Type of building&quot;,\r\n  &quot;enums&quot;: {\r\n    &quot;OrientationGarden&quot;: {\r\n      &quot;EAST&quot;: &quot;East&quot;,\r\n      &quot;SOUTH&quot;: &quot;South&quot;,\r\n      &quot;NORTH&quot;: &quot;North&quot;,\r\n      &quot;WEST&quot;: &quot;West&quot;\r\n    },\r\n    &quot;TerrainRecentDestination&quot;: {\r\n      &quot;EXTRACTION&quot;: &quot;extraction&quot;,\r\n      &quot;PARK&quot;: &quot;park&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nand for output:\r\n```\r\n{\r\n  &quot;BathroomType&quot;: &quot;Type of bathroom2&quot;,\r\n  &quot;enums&quot;: {\r\n    &quot;TerrainRecentDestination&quot;: {\r\n      &quot;EXTRACTION&quot;: &quot;extraction&quot;,\r\n      &quot;PARK&quot;: &quot;park&quot;\r\n    },\r\n    &quot;OrientationGarden&quot;: {\r\n      &quot;SOUTH&quot;: &quot;South&quot;,\r\n      &quot;EAST&quot;: &quot;East2&quot;,\r\n      &quot;NORTH&quot;: &quot;North&quot;,\r\n      &quot;WEST&quot;: &quot;West&quot;\r\n    }\r\n  },\r\n  &quot;BuildingType&quot;: &quot;Type of building&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76362983/how-to-order-a-json-file-according-to-the-keys-of-another-json-file",
        "title": "How to order a json file according to the keys of another json file"
    },
    {
        "tags": [
            "json",
            "jq",
            "parent"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1685466338,
                "creation_date": 1685466338,
                "answer_id": 76367105,
                "question_id": 76367028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Bind values to variables, so you can re-use them later:\r\n```sh\r\n.virtual_machines[] | .guest_name as $g | .mac_address[] as $m\r\n| .vm_network[$m].ipv4[] | [$g, $m, .] | join(&quot;,&quot;)\r\n```\r\n```csv\r\nguest1,00:01:02:03:04:05,192.168.2.23\r\nguest2,10:11:12:13:14:15,172.20.8.34\r\nguest2,30:31:32:33:34:35,172.16.172.34\r\nguest2,30:31:32:33:34:35,172.16.172.30\r\n```\r\n[Demo](https://jqplay.org/s/_QmW-kewGcT)",
                "title": "Get parent element reference in a json query"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685471043,
                "creation_date": 1685471043,
                "answer_id": 76367628,
                "question_id": 76367028,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution that does not use variables:\r\n\r\n```jq\r\n.virtual_machines\r\n| map(\r\n  { guest_name, mac_address: .mac_address[], ipv4: .vm_network | map_values(.ipv4) }\r\n  | { guest_name, mac_address, ipv4: (.ipv4[.mac_address] // [])[] }\r\n)\r\n| .[]\r\n| join(&quot;,&quot;)\r\n```\r\n\r\nCheck it [online](https://jqplay.org/s/jBEFPCaZGeS).\r\n",
                "title": "Get parent element reference in a json query"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1686638368,
        "creation_date": 1685465695,
        "last_edit_date": 1686638368,
        "question_id": 76367028,
        "body_markdown": "I have the following json:\r\n``` \r\n{\r\n  &quot;virtual_machines&quot;: [\r\n    {\r\n      &quot;guest_name&quot;: &quot;guest1&quot;,\r\n      &quot;mac_address&quot;: [\r\n        &quot;00:01:02:03:04:05&quot;\r\n      ],\r\n      &quot;vm_network&quot;: {\r\n        &quot;00:01:02:03:04:05&quot;: {\r\n          &quot;ipv4&quot;: [\r\n            &quot;192.168.2.23&quot;\r\n          ],\r\n          &quot;ipv6&quot;: [\r\n            &quot;fe80::896:2e12:c059:4237&quot;\r\n          ]\r\n        },\r\n        &quot;c2:e3:7c:ac:60:c5&quot;: {\r\n          &quot;ipv4&quot;: [\r\n            &quot;10.42.0.0&quot;\r\n          ],\r\n          &quot;ipv6&quot;: []\r\n        },\r\n        &quot;5a:00:fb:5e:3d:65&quot;: {\r\n          &quot;ipv4&quot;: [\r\n            &quot;10.42.0.1&quot;\r\n          ],\r\n          &quot;ipv6&quot;: []\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;guest_name&quot;: &quot;guest2&quot;,\r\n      &quot;ip_address&quot;: &quot;172.20.8.34&quot;,\r\n      &quot;mac_address&quot;: [\r\n        &quot;10:11:12:13:14:15&quot;,\r\n        &quot;30:31:32:33:34:35&quot;\r\n      ],\r\n      &quot;vm_network&quot;: {\r\n        &quot;10:11:12:13:14:15&quot;: {\r\n          &quot;ipv4&quot;: [\r\n            &quot;172.20.8.34&quot;\r\n          ],\r\n          &quot;ipv6&quot;: []\r\n        },\r\n        &quot;30:31:32:33:34:35&quot;: {\r\n          &quot;ipv4&quot;: [\r\n            &quot;172.16.172.34&quot;,\r\n            &quot;172.16.172.30&quot;\r\n          ],\r\n          &quot;ipv6&quot;: [\r\n            &quot;fe80::ad7f:c2:f621:e718&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\nFrom that JSON, I need to get all ipv4 from vm_network[] that have an entry at mac_address[] and I need to print that as \r\n$guest_name, $mac_address, $ipv4\r\n\r\nThe best I could get was the guest_name followed by the ipv4, but i can&#39;t find a way to get the mac_address for that ipv4:\r\n```\r\njq -r  &#39;.virtual_machines[] | .guest_name  + &quot;,&quot;+ (.vm_network[.mac_address[]] |.ipv4[])&#39; &lt; json_file\r\nguest1,192.168.2.23\r\nguest2,172.20.8.34\r\nguest2,172.16.172.34\r\nguest2,172.16.172.30\r\n```\r\n\r\n\r\nThe output i need is:\r\n```\r\nguest1,00:01:02:03:04:05,192.168.2.23\r\nguest2,10:11:12:13:14:15,172.20.8.34\r\nguest2,30:31:32:33:34:35,172.16.172.34\r\nguest2,30:31:32:33:34:35,172.16.172.30\r\n```\r\n\r\n\r\nCan anyone help me to acomplish that?\r\nPlease not that there can be more MAC keys in vm_network[] than in mac_address[], but I am only interested in those that have a matching entry in mac_address[].",
        "link": "https://stackoverflow.com/questions/76367028/get-parent-element-reference-in-a-json-query",
        "title": "Get parent element reference in a json query"
    },
    {
        "tags": [
            "variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1685529469,
                "post_id": 76372575,
                "comment_id": 134671918,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1091724,
                    "reputation": 402,
                    "user_id": 1107793,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/76FQI.jpg?s=256",
                    "display_name": "JdeHaan",
                    "link": "https://stackoverflow.com/users/1107793/jdehaan"
                },
                "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": 1685530115,
                "post_id": 76372575,
                "comment_id": 134672041,
                "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": 1685532677,
                "post_id": 76372575,
                "comment_id": 134672549,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1685535234,
                "last_edit_date": 1685535234,
                "creation_date": 1685530220,
                "answer_id": 76372698,
                "question_id": 76372575,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The left-hand side of an assignment operator must refers to a value inside of `.`.\r\n\r\nPut differently, the error you are getting is the result of an attempt to change `$options` without using an variable assignment. A variable assignment is done using `... as $var | ...`.\r\n\r\nAs such, your code should be\r\n\r\n```jq\r\n( $options + [ { &quot;c&quot;: &quot;d&quot; } ] ) as $options | $options\r\n```\r\n\r\nThat said, there&#39;s no reason to change `$options` here. The following would do:\r\n\r\n```jq\r\n$options + [ { &quot;c&quot;: &quot;d&quot; } ]\r\n```\r\n\r\n---\r\n\r\nLet&#39;s look at it from a different angle.\r\n\r\nYou have the following:\r\n\r\n```jq\r\n{ &quot;options&quot;: [ { &quot;a&quot;: &quot;b&quot; } ] } | .options += [ { &quot;c&quot;: &quot;d&quot; } ] | .options\r\n```\r\n\r\nBut you want to use `$options` instead of hardcoding the options. We would then use\r\n\r\n```jq\r\n{ &quot;options&quot;: $options } | .options += [ { &quot;c&quot;: &quot;d&quot; } ] | .options\r\n```\r\n\r\nThat&#39;s overly complicated, though. There&#39;s no need to construct an object to contain our options if we&#39;re only interested in the options. This simplifies to the following:\r\n\r\n```jq\r\n$options + [ { &quot;c&quot;: &quot;d&quot; } ]\r\n```\r\n\r\nSimilarly, your first snippet simplifies to\r\n\r\n```jq\r\n.options + [ { &quot;c&quot;: &quot;d&quot; } ]\r\n```\r\n",
                "title": "Can not manipulate a argjson argument in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1685545531,
        "creation_date": 1685529277,
        "last_edit_date": 1685545531,
        "question_id": 76372575,
        "body_markdown": "having a bigger problem that basically comes down to some difference between types of arguments.\r\n\r\nThese work:\r\n\r\n    $ echo &#39;{ &quot;options&quot;: [ { &quot;a&quot;: &quot;b&quot; } ] }&#39; | jq -c &#39;.options += [ { &quot;c&quot;: &quot;d&quot; } ] | .options&#39;\r\n    [{&quot;a&quot;:&quot;b&quot;},{&quot;c&quot;:&quot;d&quot;}]\r\n    $\r\n\r\nand\r\n\r\n    $ jq -c --null-input &#39;{ &quot;options&quot;: [ { &quot;a&quot;: &quot;b&quot; } ] } | .options += [ { &quot;c&quot;: &quot;d&quot; } ] | .options&#39;\r\n    [{&quot;a&quot;:&quot;b&quot;},{&quot;c&quot;:&quot;d&quot;}]\r\n    $\r\n\r\nand:\r\n\r\n    $ jq -c --null-input --argjson options &#39;[ { &quot;a&quot;: &quot;b&quot; } ]&#39; &#39;$options[0].a&#39;\r\n    &quot;b&quot;\r\n    $\r\n\r\nBut this does not:\r\n\r\n    $ jq -c --null-input --argjson options &#39;[ { &quot;a&quot;: &quot;b&quot; } ]&#39; &#39;$options += [ { &quot;c&quot;: &quot;d&quot; } ] | $options&#39;\r\n    jq: error (at &lt;unknown&gt;): Invalid path expression with result [{&quot;a&quot;:&quot;b&quot;}]\r\n    $\r\n\r\nI need the argjson defined var to gather objects mutually overriding each other, traversing a recursive JSON structure as that is the only way I found that, across functions, should work(tm).\r\n\r\nI&#39;m totally aware that I&#39;m doing something wrong, so the blame is all mine, but this costed me too much time already, so I will be eternally thankfull for some angel showing me the errors of my ways.\r\n",
        "link": "https://stackoverflow.com/questions/76372575/can-not-manipulate-a-argjson-argument-in-jq",
        "title": "Can not manipulate a argjson argument in jq"
    },
    {
        "tags": [
            "javascript",
            "json",
            "groovy",
            "jq",
            "apache-nifi"
        ],
        "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": 1685653012,
                "post_id": 76385616,
                "comment_id": 134694786,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7797973,
                    "reputation": 8177,
                    "user_id": 5898421,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/lTPC6.jpg?s=256",
                    "display_name": "Andrew Parks",
                    "link": "https://stackoverflow.com/users/5898421/andrew-parks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685654663,
                "post_id": 76385616,
                "comment_id": 134695033,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23152017,
                    "reputation": 11,
                    "user_id": 17253873,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJwgO8xcNwwhZ5c9FLLo8Fja9n7UF3hO0EzZtzvP=k-s256",
                    "display_name": "Christian M",
                    "link": "https://stackoverflow.com/users/17253873/christian-m"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685902748,
                "post_id": 76385616,
                "comment_id": 134722541,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685660019,
                "creation_date": 1685660019,
                "answer_id": 76386178,
                "question_id": 76385616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "How to optimize?  Since you don&#39;t seem to have shown the customized version of `walk` you&#39;re using, it&#39;s hard to say, but here is a more efficient version than the one in builtins.jq:\r\n\r\n```\r\ndef walk(f):\r\n  def w:\r\n    if type == &quot;object&quot;\r\n    then . as $in\r\n    | reduce keys_unsorted[] as $key\r\n        ( {}; . + { ($key):  ($in[$key] | w) } ) | f\r\n    elif type == &quot;array&quot; then map( w ) | f\r\n    else f\r\n    end;\r\n  w;\r\n```\r\n",
                "title": "Removing empty values, casting strings to bools and trimming whitespace recursively in JSON with jq - how to optimize?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685903663,
                "creation_date": 1685903663,
                "answer_id": 76401903,
                "question_id": 76385616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I did end up writing a small rust binary that does the aforementionded thing:\r\n```rust\r\nuse std::io::Read;\r\nuse serde_json::{Value, Map};\r\n\r\nfn clean_value(val: &amp;Value) -&gt; Option&lt;Value&gt; {\r\n    match val {\r\n        Value::Null =&gt; None,\r\n        Value::String(s) =&gt; {\r\n            let trimmed = s.trim().to_owned();\r\n            match trimmed.to_lowercase().as_str() {\r\n                &quot;true&quot; =&gt; Some(Value::Bool(true)),\r\n                &quot;false&quot; =&gt; Some(Value::Bool(false)),\r\n                _ =&gt; if trimmed.is_empty() { None } else { Some(Value::String(trimmed)) },\r\n            }\r\n        },\r\n        Value::Array(arr) =&gt; {\r\n            let cleaned: Vec&lt;Value&gt; = arr.iter()\r\n                .filter_map(clean_value)\r\n                .collect();\r\n            if cleaned.is_empty() { None } else { Some(Value::Array(cleaned)) }\r\n        },\r\n        Value::Object(map) =&gt; {\r\n            let cleaned: Map&lt;String, Value&gt; = map.iter()\r\n                .filter_map(|(k, v)| clean_value(v).map(|v| (k.trim().to_owned(), v)))\r\n                .collect();\r\n            if cleaned.is_empty() { None } else { Some(Value::Object(cleaned)) }\r\n        },\r\n        _ =&gt; Some(val.clone()),\r\n    }\r\n}\r\n\r\nfn clean_json(json: &amp;str) -&gt; Result&lt;String, serde_json::Error&gt; {\r\n    let value: Value = serde_json::from_str(json)?;\r\n    let cleaned = clean_value(&amp;value);\r\n    match cleaned {\r\n        Some(v) =&gt; Ok(serde_json::to_string(&amp;v)?),\r\n        None =&gt; Ok(String::new()),\r\n    }\r\n}\r\n\r\nfn main() {\r\n    let mut buffer = String::new();\r\n    std::io::stdin().read_to_string(&amp;mut buffer).unwrap();\r\n    match clean_json(&amp;buffer) {\r\n        Ok(json) =&gt; println!(&quot;{}&quot;, json),\r\n        Err(e) =&gt; eprintln!(&quot;Error cleaning json: {}&quot;, e),\r\n    }\r\n}\r\n\r\n#[cfg(test)]\r\nmod tests {\r\n    use super::*;\r\n\r\n    #[test]\r\n    fn it_works() {\r\n        let input = r#&quot;\r\n        {\r\n            &quot;  key  &quot;: &quot;  true  &quot;,\r\n            &quot;  empty array  &quot;: [],\r\n            &quot;  empty object  &quot;: {},\r\n            &quot;  empty string  &quot;: &quot;&quot;,\r\n            &quot;  null  &quot;: null,\r\n            &quot;  nested  &quot;: {\r\n                &quot;  key  &quot;: &quot;  false  &quot;,\r\n                &quot;  empty array  &quot;: [],\r\n                &quot;  empty object  &quot;: {},\r\n                &quot;  empty string  &quot;: &quot;&quot;,\r\n                &quot;  null  &quot;: null\r\n            }\r\n        }\r\n        &quot;#;\r\n        let expected = r#&quot;{&quot;key&quot;:true,&quot;nested&quot;:{&quot;key&quot;:false}}&quot;#;\r\n        let cleaned = clean_json(input).unwrap();\r\n        assert_eq!(cleaned, expected);\r\n    }\r\n}\r\n``` \r\nIt is significantly faster:\r\n```bash\r\ntime ./clean-json &lt; ~/test_small.json\r\nreal    0m0.022s\r\nuser    0m0.021s\r\nsys     0m0.001s\r\n```\r\nas opposed to the improved jq:\r\n```bash\r\nreal    0m0.365s\r\nuser    0m0.336s\r\nsys     0m0.031s\r\n```",
                "title": "Removing empty values, casting strings to bools and trimming whitespace recursively in JSON with jq - how to optimize?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685909570,
                "creation_date": 1685909570,
                "answer_id": 76402233,
                "question_id": 76385616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two variants of `walk` that might be of interest\r\nif the main targets of transformation are scalars and/or keys.\r\n\r\nNote that `scalar_walk` should be very fast,\r\nwhereas `with_entries` will tend to make `atomic_walk` relatively slow\r\nwhen processing JSON objects.\r\n\r\n```\r\n# Apply f to keys and scalars only\r\n# To speed things up, do not apply f to objects or arrays themselves\r\ndef atomic_walk(f):\r\n  def w:\r\n    if type == &quot;object&quot;\r\n    then with_entries( .key |= f | .value |= w)\r\n    elif type == &quot;array&quot; then map( w )\r\n    else f\r\n    end;\r\n  w;\r\n```\r\n\r\n```\r\n# Apply f to scalars (excluding keys) only\r\ndef scalar_walk(f):\r\n  def w:\r\n    if type == &quot;object&quot;\r\n    then map_values(w)\r\n    elif type == &quot;array&quot; then map( w )\r\n    else f\r\n    end;\r\n  w;\r\n```",
                "title": "Removing empty values, casting strings to bools and trimming whitespace recursively in JSON with jq - how to optimize?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1685909570,
        "creation_date": 1685652556,
        "last_edit_date": 1685653074,
        "question_id": 76385616,
        "body_markdown": "As part of data preprocessing I need to remove all empty values from an input JSON like empty arrays `[]`, empty objects `{}`, empty strings `&quot;&quot;`/`&quot;   &quot;`/`&quot;\\t&quot;`, objects with empty keys `{&quot;&quot;:5}` and I need to do that recursively. I also need to trim all the whitespaces of all strings (also if they are object keys). I built a solution using jq 1.6 and a custom `walk()` function. I was wondering if I could improve the performance of my query somehow since I am quite new to advanced jq stuff. Memory is not the problem I would like it to be less CPU intensive (so I do not consider jq stream). Currently I run it through executeScript on a 10 nodes 4 CPU cluster with 16GB RAM each and it is mostly hitting the CPU the hardest. Memory is only at around 60%.\r\n\r\n    jq &#39;walk(\r\n      if type == &quot;string&quot; then\r\n        (sub(&quot;^[[:space:]]+&quot;; &quot;&quot;) | sub(&quot;[[:space:]]+$&quot;; &quot;&quot;) | if . == &quot;true&quot; then . |= true else . end | if . == &quot;false&quot; then . |= false else . end)\r\n      elif type == &quot;object&quot; then\r\n        with_entries(select(.value | IN(&quot;&quot;,null, [], {}) | not) | .key |= sub(&quot;^[[:space:]]+&quot;; &quot;&quot;) | .key |= sub(&quot;[[:space:]]+$&quot;; &quot;&quot;) |select(.key | IN(&quot;&quot;) | not ))\r\n      elif type == &quot;array&quot; then\r\n          map(select(. | IN(&quot;&quot;,null, [], {}) | not))\r\n      else . end)&#39;\r\n\r\nThat is what I have now. I also cast `&quot;true&quot;` to boolean `true` and `&quot;false&quot;` to boolean `false`. Are there any obvious query improvements?\r\n\r\nI tried doing the whole thing in plain JavaScript or Groovy but I did not feel like reinventing the wheel when recursing nested JSON object is already handled that gracefully by jq. I am open for JavaScript or Groovy implementation if the jq query cannot be improved substantially.",
        "link": "https://stackoverflow.com/questions/76385616/removing-empty-values-casting-strings-to-bools-and-trimming-whitespace-recursiv",
        "title": "Removing empty values, casting strings to bools and trimming whitespace recursively in JSON with jq - how to optimize?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 385974,
                    "reputation": 32217,
                    "user_id": 743464,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/b3a21f6147bcc6bd9d997d5cc5b5f87c?s=256&d=identicon&r=PG",
                    "display_name": "Andy Ray",
                    "link": "https://stackoverflow.com/users/743464/andy-ray"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685813219,
                "post_id": 76397168,
                "comment_id": 134714838,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1685815774,
                "creation_date": 1685815774,
                "answer_id": 76397392,
                "question_id": 76397168,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `walk` through the document tree, and `if` you encounter a string `type`, try to convert it `tonumber`. If it fails (`?`), leave it as it was (`// .`). Likewise, if it wasn&#39;t a string in the first place (`else .`).\r\n\r\n```sh\r\nwalk(if type == &quot;string&quot; then tonumber? // . else . end)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;firstName&quot;: &quot;Charles&quot;,\r\n    &quot;lastName&quot;: &quot;Doe&quot;,\r\n    &quot;age&quot;: 65,\r\n    &quot;postalCode&quot;: 943,\r\n    &quot;habitants&quot;: 5\r\n  },\r\n  {\r\n    &quot;firstName&quot;: &quot;Charles&quot;,\r\n    &quot;lastName&quot;: &quot;Doe&quot;,\r\n    &quot;age&quot;: 41,\r\n    &quot;postalCode&quot;: 94103,\r\n    &quot;habitants&quot;: 2\r\n  },\r\n  {\r\n    &quot;firstName&quot;: &quot;Charles&quot;,\r\n    &quot;lastName&quot;: &quot;Doe&quot;,\r\n    &quot;age&quot;: 23,\r\n    &quot;postalCode&quot;: 94103,\r\n    &quot;habitants&quot;: 3,\r\n    &quot;animals&quot;: 1\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/uX-Nn7kpMUj)",
                "title": "Convert numbers stored as strings from array of objects using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1685815774,
        "creation_date": 1685812884,
        "question_id": 76397168,
        "body_markdown": "Given an array of json objects such as \r\n```js\r\n[\r\n{\r\n  &quot;firstName&quot;: &quot;Charles&quot;,\r\n  &quot;lastName&quot;: &quot;Doe&quot;,\r\n  &quot;age&quot;: &quot;65&quot;,\r\n  &quot;postalCode&quot;: &quot;943&quot;,\r\n  &quot;habitants&quot;: &quot;5&quot;\r\n},\r\n{\r\n  &quot;firstName&quot;: &quot;Charles&quot;,\r\n  &quot;lastName&quot;: &quot;Doe&quot;,\r\n  &quot;age&quot;: 41,\r\n  &quot;postalCode&quot;: &quot;94103&quot;,\r\n  &quot;habitants&quot;: &quot;2&quot;\r\n},\r\n{\r\n  &quot;firstName&quot;: &quot;Charles&quot;,\r\n  &quot;lastName&quot;: &quot;Doe&quot;,\r\n  &quot;age&quot;: 23,\r\n  &quot;postalCode&quot;: &quot;94103&quot;,\r\n  &quot;habitants&quot;: &quot;3&quot;,\r\n  &quot;animals&quot;: &quot;1&quot;\r\n}\r\n]\r\n```\r\n\r\nHow to make sure all numbers are converted back to numbers ? (without corrupting rightful strings) \r\n\r\nNote: other stackoverflow question don&#39;t answer this question, neither can ChatGPT.",
        "link": "https://stackoverflow.com/questions/76397168/convert-numbers-stored-as-strings-from-array-of-objects-using-jq",
        "title": "Convert numbers stored as strings from array of objects using jq?"
    },
    {
        "tags": [
            "c",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1685917972,
                "post_id": 76402614,
                "comment_id": 134724082,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23863702,
                    "reputation": 69,
                    "user_id": 17866323,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f076215f53b97ecd0ac0bd49131a21e?s=256&d=identicon&r=PG",
                    "display_name": "bungee1980",
                    "link": "https://stackoverflow.com/users/17866323/bungee1980"
                },
                "reply_to_user": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685918673,
                "post_id": 76402614,
                "comment_id": 134724133,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6095312,
                    "reputation": 1,
                    "user_id": 4756299,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6fe43a9d31f2308c4e64a62cf0c310d1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrew Henle",
                    "link": "https://stackoverflow.com/users/4756299/andrew-henle"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1685918846,
                "post_id": 76402614,
                "comment_id": 134724152,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25916036,
                    "reputation": 4473,
                    "user_id": 19639413,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MSnEM.png?s=256",
                    "display_name": "pmacfarlane",
                    "link": "https://stackoverflow.com/users/19639413/pmacfarlane"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1685919643,
                "post_id": 76402614,
                "comment_id": 134724219,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23863702,
                    "reputation": 69,
                    "user_id": 17866323,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f076215f53b97ecd0ac0bd49131a21e?s=256&d=identicon&r=PG",
                    "display_name": "bungee1980",
                    "link": "https://stackoverflow.com/users/17866323/bungee1980"
                },
                "reply_to_user": {
                    "account_id": 6095312,
                    "reputation": 1,
                    "user_id": 4756299,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6fe43a9d31f2308c4e64a62cf0c310d1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrew Henle",
                    "link": "https://stackoverflow.com/users/4756299/andrew-henle"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685920118,
                "post_id": 76402614,
                "comment_id": 134724249,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23863702,
                    "reputation": 69,
                    "user_id": 17866323,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f076215f53b97ecd0ac0bd49131a21e?s=256&d=identicon&r=PG",
                    "display_name": "bungee1980",
                    "link": "https://stackoverflow.com/users/17866323/bungee1980"
                },
                "reply_to_user": {
                    "account_id": 25916036,
                    "reputation": 4473,
                    "user_id": 19639413,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MSnEM.png?s=256",
                    "display_name": "pmacfarlane",
                    "link": "https://stackoverflow.com/users/19639413/pmacfarlane"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685920433,
                "post_id": 76402614,
                "comment_id": 134724284,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 25916036,
                    "reputation": 4473,
                    "user_id": 19639413,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MSnEM.png?s=256",
                    "display_name": "pmacfarlane",
                    "link": "https://stackoverflow.com/users/19639413/pmacfarlane"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1685921748,
                "post_id": 76402614,
                "comment_id": 134724386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 23863702,
                    "reputation": 69,
                    "user_id": 17866323,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7f076215f53b97ecd0ac0bd49131a21e?s=256&d=identicon&r=PG",
                    "display_name": "bungee1980",
                    "link": "https://stackoverflow.com/users/17866323/bungee1980"
                },
                "reply_to_user": {
                    "account_id": 25916036,
                    "reputation": 4473,
                    "user_id": 19639413,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MSnEM.png?s=256",
                    "display_name": "pmacfarlane",
                    "link": "https://stackoverflow.com/users/19639413/pmacfarlane"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1685923804,
                "post_id": 76402614,
                "comment_id": 134724525,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1685983576,
                "last_edit_date": 1685983576,
                "creation_date": 1685945838,
                "answer_id": 76403910,
                "question_id": 76402614,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As noted it&#39;s a much better idea to use a JSON library to parse the output.  A library provides you with an API which is a more direct way to express what you are trying to do, and will provide you with better error handling.  That said, I was curious, so here is how you could pass the data to `jq`:\r\n\r\n```\r\n#define _POSIX_C_SOURCE 2\r\n#include &lt;curl/curl.h&gt;\r\n#include &lt;stdio.h&gt;\r\n#include &lt;sys/wait.h&gt;\r\n#include &lt;unistd.h&gt;\r\n\r\nint main(void) {\r\n\tFILE *f = popen(&quot;jq .userId&quot;, &quot;w&quot;);\r\n\tif(!f) {\r\n\t\tprintf(&quot;jq failed\\n&quot;);\r\n\t\treturn 1;\r\n\t}\r\n\tdup2(fileno(f), STDOUT_FILENO);\r\n\tCURL *ch = curl_easy_init();\r\n\tcurl_easy_setopt(ch, CURLOPT_URL, &quot;https://jsonplaceholder.typicode.com/todos/2&quot;);\r\n\tCURLcode res = curl_easy_perform(ch);\r\n\tcurl_easy_cleanup(ch);\r\n\tfclose(stdout);\r\n\treturn pclose(f);\r\n}\r\n```\r\n\r\nand output:\r\n\r\n```\r\n1\r\n```\r\n",
                "title": "curl in c, output in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1685983576,
        "creation_date": 1685916972,
        "question_id": 76402614,
        "body_markdown": "I make a curl call in c like so:\r\n```\r\n#include &lt;curl/curl.h&gt;\r\n\r\n#include &lt;stdio.h&gt;\r\n\r\nint main(){\r\n\r\n   \tCURL *ch;\r\n\r\n\tCURLcode res;\r\n\r\n   \tch = curl_easy_init();\r\n\r\n\tcurl_easy_setopt(ch, CURLOPT_URL, &quot;https://jsonplaceholder.typicode.com/todos/2&quot;);\r\n\r\n\tres = curl_easy_perform(ch);\r\n\r\n   \tcurl_easy_cleanup(ch);\r\n\r\n\t}\r\n```\r\n\r\nit prints to the command line just fine:\r\n\r\n``` \r\n$./mycurl\r\n{\r\n  &quot;userId&quot;: 1,\r\n  &quot;id&quot;: 2,\r\n  &quot;title&quot;: &quot;quis ut nam facilis et officia qui&quot;,\r\n  &quot;completed&quot;: false\r\n} \r\n``` \r\nbut I would like to use jq to parse the json and output from one compiled c file. how do i do this without doing: ``` ./mycurl | jq ```\r\n\r\nbut rather compile it all in one?",
        "link": "https://stackoverflow.com/questions/76402614/curl-in-c-output-in-jq",
        "title": "curl in c, output in jq"
    },
    {
        "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": 1685920078,
                "post_id": 76402740,
                "comment_id": 134724243,
                "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": 1685983590,
                "post_id": 76402740,
                "comment_id": 134734142,
                "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": 1685983635,
                "post_id": 76402740,
                "comment_id": 134734145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 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": 1686123838,
                "post_id": 76402740,
                "comment_id": 134754349,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 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": 1686134436,
                "post_id": 76402740,
                "comment_id": 134756516,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1685983506,
                "last_edit_date": 1685983506,
                "creation_date": 1685944964,
                "answer_id": 76403831,
                "question_id": 76402740,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I *think* you want the following:\r\n\r\n```\r\n.Reservations[].Instances[] | { publicIp: .PublicIpAddress }\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;publicIp&quot;: &quot;54.11.101.63&quot;\r\n}\r\n```\r\n\r\nNote that multiple elements in any of the arrays will produce separate output elements.\r\n\r\nAlternative spellings of the same program:\r\n\r\n```\r\n.Reservations[].Instances[].PublicIpAddress | { publicIp: . }\r\n.Reservations[] | { publicIp: .Instances[].PublicIpAddress }\r\n{ publicIp: .Reservations[].Instances[].PublicIpAddress }\r\n```\r\n\r\nBut maybe you are really looking for this?\r\n\r\n```\r\njq -r &#39;.Reservations[].Instances[].PublicIpAddress&#39;\r\n```\r\n\r\nWhich will simply output `54.11.101.63` (one IP address per line, if there are multiple in your input document).",
                "title": "How to get value from json using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1685983506,
        "creation_date": 1685919801,
        "question_id": 76402740,
        "body_markdown": "I am new to jq and running into a bit of an issue trying to get a value from the json response. I want to get the value of the `PublicIpAddress`\r\n\r\n    {\r\n      &quot;Reservations&quot;: [\r\n        {\r\n          &quot;Groups&quot;: [],\r\n          &quot;Instances&quot;: [\r\n            {\r\n              &quot;AmiLaunchIndex&quot;: 0,\r\n              &quot;ImageId&quot;: &quot;ami-XXX&quot;,\r\n              &quot;InstanceId&quot;: &quot;i-XXX&quot;,\r\n              &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n              &quot;KeyName&quot;: &quot;dev&quot;,\r\n              &quot;LaunchTime&quot;: &quot;2022-06-04T22:30:04+00:00&quot;,\r\n              &quot;Monitoring&quot;: {\r\n                &quot;State&quot;: &quot;disabled&quot;\r\n              },\r\n              &quot;Placement&quot;: {\r\n                &quot;AvailabilityZone&quot;: &quot;us-east-1d&quot;,\r\n                &quot;GroupName&quot;: &quot;&quot;,\r\n                &quot;Tenancy&quot;: &quot;default&quot;\r\n              },\r\n              &quot;PrivateDnsName&quot;: &quot;ip-172-28-99-112.ec2.internal&quot;,\r\n              &quot;PrivateIpAddress&quot;: &quot;172.28.99.112&quot;,\r\n              &quot;ProductCodes&quot;: [],\r\n              &quot;PublicDnsName&quot;: &quot;ec2-54-11-101-63.compute-1.amazonaws.com&quot;,\r\n              &quot;PublicIpAddress&quot;: &quot;54.11.101.63&quot;,\r\n              &quot;State&quot;: {\r\n                &quot;Code&quot;: 16,\r\n                &quot;Name&quot;: &quot;running&quot;\r\n              },\r\n\r\nSo far i&#39;ve tried `aws ec2 describe-instances | jq &#39;.[] | {publicIP : .Reservations.Instances[].PublicIpAddress}&#39;` as well as `aws ec2 describe-instances | jq &#39;.[] | {publicIP : .Reservations.Instances.PublicIpAddress}&#39;` but i keep running into `jq: error (at &lt;stdin&gt;:151): Cannot index array with string &quot;Reservations&quot;`",
        "link": "https://stackoverflow.com/questions/76402740/how-to-get-value-from-json-using-jq",
        "title": "How to get value from json using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1685968128,
                "last_edit_date": 1685968128,
                "creation_date": 1685954883,
                "answer_id": 76404795,
                "question_id": 76404598,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could iterate over the outer array using `.[]`, then construct the objects using `? //` to provide alternatives if one evaluates to `null`.\r\n\r\nIf you are okay with `null`s in the comlpete absence of a key (as with `.name` in your first format), try this:\r\n```sh\r\n.[] | {title} + (.data | {\r\n  ids: map(.ids[]? // . | .id),\r\n  names: map(.names[]? // . | .name)\r\n})\r\n```\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    null,\r\n    null\r\n  ]\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/AE9Agq7T9I_s)\r\n\r\nBut you could also filter out `null`s using `values`:\r\n```sh\r\n.[] | {title} + (.data | {\r\n  ids: map(.ids[]? // . | .id | values),\r\n  names: map(.names[]? // . | .name | values)\r\n})\r\n```\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: []\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/KnG5gUSEGAw)\r\n\r\nIf you want to get rid of keys with empty arrays altogether, filter them out using `map_values` on a comparison using `select`:\r\n```sh\r\n.[] | {title} + (.data | {\r\n  ids: map(.ids[]? // . | .id | values),\r\n  names: map(.names[]? // . | .name | values)\r\n} | map_values(select(. != [])))\r\n```\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/tMgti7417fz)\r\n\r\n---\r\nEdit using the modified input files: As the deeper levels use the same (relative) path (here `.specs[].spec`), we need some other distinction criteria to rule out the level with &quot;Some title you don&#39;t care about&quot;. Checking for the presence of a `.data` key seems to fit with the new sample data.\r\n```sh\r\n.specs[].spec | select(has(&quot;data&quot;)), .specs[]?.spec\r\n| {title} + (.data | {\r\n  ids: map(.ids[]?.id // .i | values),\r\n  names: map(.names[]? // . | .name | values)\r\n} | map_values(select(. != [])))\r\n```\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/et8BDz8LaXc)",
                "title": "Use jq to unify unknown JSON to known schema"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1685970528,
                "last_edit_date": 1685970528,
                "creation_date": 1685968402,
                "answer_id": 76406454,
                "question_id": 76404598,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are okay with having `names: null` or `names: []` in the final document for your first example, the following looks like a simple solution:\r\n\r\n```\r\n{ title }\r\n+ (.data | {\r\n    ids: map(.ids[].id),\r\n    names: (map(.names[].name)? // []) # or // null\r\n})\r\n```\r\n\r\nor equivalent:\r\n\r\n```\r\n{\r\n    title,\r\n    ids: (.data | map(.ids[].id)),\r\n    names: (.data | map(.names[].name)? // [])\r\n}\r\n```\r\n\r\nOutput 1:\r\n\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: []\r\n}\r\n```\r\n\r\nOutput 2:\r\n\r\n```json\r\n{\r\n  &quot;title&quot;: &quot;Some more data&quot;,\r\n  &quot;ids&quot;: [\r\n    &quot;123&quot;,\r\n    &quot;abc&quot;\r\n  ],\r\n  &quot;names&quot;: [\r\n    &quot;A&quot;,\r\n    &quot;B&quot;\r\n  ]\r\n}\r\n```",
                "title": "Use jq to unify unknown JSON to known schema"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1685970528,
        "creation_date": 1685952956,
        "last_edit_date": 1685967236,
        "question_id": 76404598,
        "body_markdown": "I&#39;m not really sure on how to phrase this question so lemme give an example: I have two types of JSON document formats for a large amount of files. Most of the contents apart from one object is irrelevant to me. I want to create a normalised version of each file. These are the two objects I care about (in each of the formats):\r\n\r\n    {\r\n        &quot;title&quot;: &quot;Some data&quot;,\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;id&quot;: &quot;123&quot;,\r\n                ...\r\n            },\r\n            {\r\n                &quot;id&quot;: &quot;abc&quot;,\r\n                ...\r\n            }\r\n        ]\r\n    }\r\n\r\nand\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Some more data&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;ids&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;123&quot;,\r\n              ...\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;abc&quot;,\r\n              ...\r\n            }\r\n          ],\r\n          &quot;names&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;A&quot;,\r\n              ...\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;B&quot;,\r\n              ...\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nEach of those &quot;object formats&quot; is an object inside a JSON array in a file. I want to convert each of the files I have into a list of objects that captures the `title`, list of `id` and list of `name` in a single object:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Some more data&quot;,\r\n      &quot;ids&quot;: [\r\n          &quot;123&quot;,\r\n          &quot;abc&quot;\r\n      ],\r\n      &quot;names&quot;: [\r\n          &quot;A&quot;,\r\n          &quot;B&quot;\r\n      ]\r\n    }\r\n\r\nI use the following `jq`, but it doesn&#39;t work (it creates multiple objects with the same title per `name` or `id`:\r\n\r\n    for f in $(find * -wholename &quot;*.json&quot; | sort); do\r\n    cat $f | jq &#39;..\r\n    | if type == &quot;object&quot; then\r\n        if has(&quot;data&quot;) then {\r\n            &quot;name&quot;: .title,\r\n            &quot;ids&quot;: (.data[] | [\r\n                if has(&quot;id&quot;) then {\r\n                    &quot;id&quot;: .id\r\n                } else if has(&quot;ids&quot;) then {\r\n                    &quot;ids&quot;: .ids[],\r\n                    &quot;names&quot;: .names?\r\n                } else null end\r\n            end\r\n        ])} else null end\r\n    else null end\r\n    | select(type != &quot;null&quot;)&#39; &gt; &quot;$f&quot; ; done\r\n\r\nEDIT: https://jqplay.org/s/uWC80Qoixxd.",
        "link": "https://stackoverflow.com/questions/76404598/use-jq-to-unify-unknown-json-to-known-schema",
        "title": "Use jq to unify unknown JSON to known schema"
    },
    {
        "tags": [
            "unix",
            "curl",
            "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": 1,
                "creation_date": 1685967115,
                "post_id": 76406175,
                "comment_id": 134730208,
                "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": 1686042588,
                "post_id": 76406175,
                "comment_id": 134741448,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28273961,
                    "reputation": 9,
                    "user_id": 21616733,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AGNmyxbOpeFfyrab0ktLzLdiUSNsIDB8epJ-REOjWsN0=k-s256",
                    "display_name": "Auly",
                    "link": "https://stackoverflow.com/users/21616733/auly"
                },
                "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": 1686107280,
                "post_id": 76406175,
                "comment_id": 134752396,
                "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": 1686115322,
                "post_id": 76406175,
                "comment_id": 134753072,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28273961,
                    "reputation": 9,
                    "user_id": 21616733,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AGNmyxbOpeFfyrab0ktLzLdiUSNsIDB8epJ-REOjWsN0=k-s256",
                    "display_name": "Auly",
                    "link": "https://stackoverflow.com/users/21616733/auly"
                },
                "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": 1686135784,
                "post_id": 76406175,
                "comment_id": 134756819,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1685968564,
                "last_edit_date": 1685968564,
                "creation_date": 1685966426,
                "answer_id": 76406211,
                "question_id": 76406175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Start by verifying that curl produces any data at all. Perhaps:\r\n\r\n    curl -s &quot;https://www.wikidata.org/w/api.php?action=wbgetentities&amp;format=json&amp;ids=Q111&quot; &gt;testcurl.json\r\n\r\nThen examine the file. Perhaps your URL is incorrect.\r\n\r\nYou might also consider using jsonlint to examine the resulting file.\r\n",
                "title": "curl | jq error:0A000126:SSL routines::unexpected eof while reading"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1686107609,
        "creation_date": 1685966138,
        "last_edit_date": 1686107609,
        "question_id": 76406175,
        "body_markdown": "The command line is:\r\n```bash\r\n$ curl -v -k &quot;https://www.wikidata.org/w/api.php?action=wbgetentities&amp;format=json&amp;ids=Q111&quot; | \r\n&gt; jq .\r\n```\r\nI use WSL2 to type above command. It show error.\r\n```bash\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0*   Trying 103.102.166.224:443...\r\n* Connected to www.wikidata.org (103.102.166.224) port 443 (#0)\r\n  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0* ALPN, offering h2\r\n* ALPN, offering http/1.1\r\n*  CAfile: /etc/ssl/certs/ca-certificates.crt\r\n*  CApath: /etc/ssl/certs\r\n* TLSv1.0 (OUT), TLS header, Certificate Status (22):\r\n} [5 bytes data]\r\n* TLSv1.3 (OUT), TLS handshake, Client hello (1):\r\n} [512 bytes data]\r\n  0     0    0     0    0     0      0      0 --:--:--  0:01:59 --:--:--     0* TLSv1.0 (OUT), TLS header, Unknown (21):\r\n} [5 bytes data]\r\n* TLSv1.3 (OUT), TLS alert, decode error (562):\r\n} [2 bytes data]\r\n* error:0A000126:SSL routines::unexpected eof while reading\r\n  0     0    0     0    0     0      0      0 --:--:--  0:02:00 --:--:--     0\r\n* Closing connection 0\r\ncurl: (35) error:0A000126:SSL routines::unexpected eof while reading\r\n```\r\nI have used `sudo apt update` and `sudo apt upgrade`, `curl -V` display curl&#39;s version and openssl&#39;s version:\r\n```\r\ncurl 7.81.0 (x86_64-pc-linux-gnu) libcurl/7.81.0 OpenSSL/3.0.2 zlib/1.2.11 brotli/1.0.9 zstd/1.4.8 libidn2/2.3.2 libpsl/0.21.0 (+libidn2/2.3.2) libssh/0.9.6/openssl/zlib nghttp2/1.43.0 librtmp/2.3 OpenLDAP/2.5.14\r\nRelease-Date: 2022-01-05\r\nProtocols: dict file ftp ftps gopher gophers http https imap imaps ldap ldaps mqtt pop3 pop3s rtmp rtsp scp sftp smb smbs smtp smtps telnet tftp\r\nFeatures: alt-svc AsynchDNS brotli GSS-API HSTS HTTP2 HTTPS-proxy IDN IPv6 Kerberos Largefile libz NTLM NTLM_WB PSL SPNEGO SSL TLS-SRP UnixSockets zstd\r\n``` \r\nI type the command on cygwin too. It shows different error:\r\n```bash\r\n % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0*   Trying 103.102.166.224:443...\r\n* Connected to www.wikidata.org (103.102.166.224) port 443 (#0)\r\n* schannel: disabled automatic use of client certificate\r\n* ALPN: offers http/1.1\r\n  0     0    0     0    0     0      0      0 --:--:--  0:00:19 --:--:--     0* Recv failure: Connection was reset\r\n* schannel: failed to receive handshake, SSL/TLS connection failed\r\n  0     0    0     0    0     0      0      0 --:--:--  0:00:19 --:--:--     0\r\n* Closing connection 0\r\n* schannel: shutting down SSL/TLS connection with www.wikidata.org port 443\r\n* Send failure: Connection was reset\r\n* schannel: failed to send close msg: Failed sending data to the peer (bytes written: -1)\r\ncurl: (35) Recv failure: Connection was reset\r\n\r\n```\r\nHow can I solve it?",
        "link": "https://stackoverflow.com/questions/76406175/curl-jq-error0a000126ssl-routinesunexpected-eof-while-reading",
        "title": "curl | jq error:0A000126:SSL routines::unexpected eof while reading"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1685993380,
                "last_edit_date": 1685993380,
                "creation_date": 1685975981,
                "answer_id": 76407557,
                "question_id": 76407533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Update `|=` each item in the `.items` array by adding up `.details` and `.properties`:\r\n```sh\r\njq &#39;.items[] |= .details + .properties&#39;\r\n```\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;description&quot;: &quot;description&quot;,\r\n      &quot;property1&quot;: &quot;someValue&quot;,\r\n      &quot;property2&quot;: &quot;someOtherValue&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;description&quot;: &quot;description2&quot;,\r\n      &quot;property1&quot;: &quot;someValue2&quot;,\r\n      &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/EncmEdXWIxR)\r\n\r\n---\r\nEdit: With the updated input files, just add `{properties}` as is (replacing `.properties`):\r\n```sh\r\njq &#39;.items[] |= .details + {properties}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;description&quot;: &quot;description&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;description&quot;: &quot;description2&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue2&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/MVk2Gv3DU91)\r\n",
                "title": "Concatenate nested JSON structures using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685978684,
                "last_edit_date": 1685978684,
                "creation_date": 1685976110,
                "answer_id": 76407579,
                "question_id": 76407533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `*` operator:\r\n\r\n    jq &#39;.items[] |= (.details * .properties[])&#39; test.json\r\n\r\n\r\n----------\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;test&quot;,\r\n          &quot;description&quot;: &quot;description&quot;,\r\n          &quot;property1&quot;: &quot;someValue&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;test2&quot;,\r\n          &quot;description&quot;: &quot;description2&quot;,\r\n          &quot;property1&quot;: &quot;someValue2&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Concatenate nested JSON structures using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685978892,
                "creation_date": 1685978892,
                "answer_id": 76407914,
                "question_id": 76407533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have managed to get the desired output with the following:\r\n\r\n```\r\njq &#39;.items[] |= .details + {&quot;properties&quot;: .properties}&#39;\r\n```\r\n\r\nideally I don&#39;t want to specify the key &quot;properties&quot; but am yet to find another way",
                "title": "Concatenate nested JSON structures using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1685989682,
                "creation_date": 1685989682,
                "answer_id": 76409102,
                "question_id": 76407533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are many possible solutions as evidenced by the existing great answers. One solution takes the constructive, albeit slightly repetetive, approach:\r\n\r\n```\r\n{\r\n    items: .items | map({\r\n        name: .details.name,\r\n        description: .details.description,\r\n        properties\r\n    })\r\n}\r\n```\r\n\r\nSimilarly, you can re-construct the items of the array and then update-assign them:\r\n\r\n```\r\n.items[] |= {\r\n    name: .details.name,\r\n    description: .details.description,\r\n    properties\r\n}\r\n```",
                "title": "Concatenate nested JSON structures using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1685993380,
        "creation_date": 1685975780,
        "last_edit_date": 1685976932,
        "question_id": 76407533,
        "body_markdown": "Edit: updated question as example was too simplified to cover specific case:\r\n\r\nSuppose I have a json object:\r\n\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;details&quot;: {\r\n        &quot;name&quot;: &quot;test&quot;,\r\n        &quot;description&quot;: &quot;description&quot;\r\n      },\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue&quot;\r\n        }\r\n      ],\r\n      &quot;additionalProperties&quot;: {\r\n        &quot;other&quot;: &quot;stuff&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;details&quot;: {\r\n        &quot;name&quot;: &quot;test2&quot;,\r\n        &quot;description&quot;: &quot;description2&quot;\r\n      },\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue2&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n        }\r\n      ],\r\n      &quot;additionalProperties&quot;: {\r\n        &quot;other&quot;: &quot;stuff&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI would like to extract the two json objects `details` and `properties` and and insert into `item`, replacing all other properties. In this example there are `additionalProperties` that should be ignored, but there could be up to `n` other properties that should also be ignored.\r\n\r\nDesired output:\r\n\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;description&quot;: &quot;description&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue2&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;test2&quot;,\r\n      &quot;description&quot;: &quot;description2&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;property1&quot;: &quot;someValue2&quot;,\r\n          &quot;property2&quot;: &quot;someOtherValue2&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI have tried a few different ways using map - but I&#39;m not sure if this is the correct approach. I&#39;ve seen similar solutions involving `reduce` too, however I am yet to get something that works. Any help would be appreciated!",
        "link": "https://stackoverflow.com/questions/76407533/concatenate-nested-json-structures-using-jq",
        "title": "Concatenate nested JSON structures using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1704436604,
                "last_edit_date": 1704436604,
                "creation_date": 1685992606,
                "answer_id": 76409402,
                "question_id": 76409375,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way:\r\n```\r\n{(.k1): .k2}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Vr3nh_bWMG1)&lt;/sup&gt;",
                "title": "jq: create object from values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1704436604,
        "creation_date": 1685992258,
        "question_id": 76409375,
        "body_markdown": "I have this input:\r\n\r\n    { &quot;k1&quot;: &quot;v1&quot;, &quot;k2&quot;: &quot;v2&quot; }\r\n\r\nI want to get this:\r\n\r\n    { &quot;v1&quot;: &quot;v2&quot; }\r\n\r\nSo, basically, I want to create an object out of another object&#39;s values without knowing values but only their keys.\r\n\r\nI have tried several `map()` but got no luck. Any hint?\r\n",
        "link": "https://stackoverflow.com/questions/76409375/jq-create-object-from-values",
        "title": "jq: create object from values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1686144003,
                "creation_date": 1686144003,
                "answer_id": 76423742,
                "question_id": 76423585,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `to_entries` to get simultaneous access to both the `.key` and the `.value`, test the existence of a (sub-)key using `has`, and use `?` to suppress errors if it is not an object (thus has no key, and would error out). Using the `-r` flag gives you a raw-text output.\r\n```sh\r\njq -r &#39;.variables | to_entries[] | select(.value | has(&quot;description&quot;)?).key&#39;\r\n```\r\n```\r\nAWS_REGION\r\nENVIRONMENT\r\n```\r\n[Demo](https://jqplay.org/s/NyCo9uirTSt)\r\n\r\n---\r\nThe same technique using `keys`, iterated over and stored in a variable:\r\n```sh\r\njq -r &#39;.variables | keys[] as $k | .[$k] | select(has(&quot;description&quot;)?) | $k&#39;\r\n```\r\n[Demo](https://jqplay.org/s/OwLkpEgTJWf)",
                "title": "Selecting key name of parent objects when child object contains a specific key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686144003,
        "creation_date": 1686142926,
        "last_edit_date": 1686143299,
        "question_id": 76423585,
        "body_markdown": "Given the following JSON containing 3 variables:\r\n\r\n```json\r\n{\r\n  &quot;variables&quot;: {\r\n    &quot;AWS_ROLE&quot;: &quot;DevOpsAccessRole&quot;,\r\n    &quot;AWS_REGION&quot;: {\r\n      &quot;description&quot;: &quot;AWS region&quot;,\r\n      &quot;value&quot;: &quot;us-west-2&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;us-west-2&quot;,\r\n        &quot;us-east-1&quot;\r\n      ]\r\n    },\r\n    &quot;ENVIRONMENT&quot;: {\r\n      &quot;description&quot;: &quot;Environment to deploy to&quot;,\r\n      &quot;value&quot;: &quot;dev&quot;,\r\n      &quot;options&quot;: [\r\n        &quot;dev&quot;,\r\n        &quot;qa&quot;,\r\n        &quot;prod&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nMy goal is to select only the variable names containing the `description` field.\r\n\r\nSo the desired output is (don&#39;t care about the order):\r\n\r\n```json\r\nAWS_REGION\r\nENVIRONMENT\r\n```\r\n\r\n`AWS_ROLE` should be left out since it does not contain the `description` key.\r\n\r\nI&#39;ve initially tried:\r\n\r\n`jq -r &#39;.variables | keys []&#39;`\r\n\r\nWhich returns:\r\n\r\n```\r\nAWS_ROLE\r\nAWS_REGION\r\nENVIRONMENT\r\n```\r\n\r\nBut I&#39;m stuck removing the ones without `description`.\r\n\r\nAlso tried:\r\n\r\n`jq -r &#39;.variables |..| select(.description?)&#39;`\r\n\r\nbut the problem here is that I loose access to the variable names.\r\n\r\nHow can I do this in `jq` ?",
        "link": "https://stackoverflow.com/questions/76423585/selecting-key-name-of-parent-objects-when-child-object-contains-a-specific-key",
        "title": "Selecting key name of parent objects when child object contains a specific key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1686163976,
                "creation_date": 1686163976,
                "answer_id": 76426280,
                "question_id": 76426251,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could update `|=` the `.data` array by applying a transformation to each of its elements, using the `.key` and `.value` from the original item:\r\n```\r\n.addresses.data |= map({value, remoteRef: {key, courrierStrategy: &quot;Auto&quot;}})\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Ted Mosby&quot;,\r\n  &quot;addresses&quot;: {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;value&quot;: &quot;any xpto&quot;,\r\n        &quot;remoteRef&quot;: {\r\n          &quot;key&quot;: &quot;address key&quot;,\r\n          &quot;courrierStrategy&quot;: &quot;Auto&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/QNAI4Ouqk83)",
                "title": "jq - how to transform a nested structure into another?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686290318,
        "creation_date": 1686163752,
        "last_edit_date": 1686290318,
        "question_id": 76426251,
        "body_markdown": "I have a like 950 json files that I need to transform but I&#39;m kinda stuck. I have right a shell script to iterate over files, delete somekeys but I got stuck on how transform it. Here I have my original file:\r\n\r\n```\r\n{ \r\n  &quot;name&quot;: &quot;Ted Mosby&quot;,\r\n  &quot;addresses&quot;: {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;address key&quot;,\r\n        &quot;value&quot;: &quot;any xpto&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI need to transform `data` into another format and output must be:\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Ted Mosby&quot;,\r\n  &quot;addresses&quot;: {\r\n      &quot;data&quot;: [{\r\n        &quot;value&quot;: &quot;any xpto&quot;,\r\n        &quot;remoteRef&quot;: {\r\n            &quot;key&quot;: &quot;address key&quot;,\r\n            &quot;courrierStrategy&quot;: &quot;Auto&quot;\r\n        }\r\n      }]\r\n  }\r\n}\r\n```\r\n\r\nIs there any way to achieve it using jq? I am trying to avoid write a python to perform it.",
        "link": "https://stackoverflow.com/questions/76426251/jq-how-to-transform-a-nested-structure-into-another",
        "title": "jq - how to transform a nested structure into another?"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1686215132,
                "creation_date": 1686215132,
                "answer_id": 76430261,
                "question_id": 76430218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace the `last` item (or equally the `.[1]` item) with each of its own items (`.[]`), then turn all of it into tab-separated values using `@tsv`:\r\n```sh\r\njq -r &#39;last = last[] | @tsv&#39; input.json\r\n```\r\n```csv\r\nalice\tfoo\r\nalice\tbar\r\nalice\tbaz\r\nbob\tqux\r\nbob\tquux\r\n```\r\n[Demo](https://jqplay.org/s/OKU1ZcNn29V)",
                "title": "Convert json-lines to tsv, producing a separate line for each array item"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1686237144,
                "last_edit_date": 1686237144,
                "creation_date": 1686236797,
                "answer_id": 76433273,
                "question_id": 76430218,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way to do it by placing the first element in an array and then using the built-in [`combinations`](https://jqlang.github.io/jq/manual/v1.6/#combinations,combinations(n)).\r\n```lang-bash\r\njq --raw-output &#39;.[0]=[.[0]] | combinations | @tsv&#39; input.json\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/0jRNnm3RdVH &quot;Click me!&quot;).",
                "title": "Convert json-lines to tsv, producing a separate line for each array item"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1686284248,
        "creation_date": 1686214806,
        "last_edit_date": 1686284248,
        "question_id": 76430218,
        "body_markdown": "I have the following input file\r\n```\r\n[&quot;alice&quot;, [&quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot;]]\r\n[&quot;bob&quot;, [&quot;qux&quot;, &quot;quux&quot;]]\r\n⋮\r\n```\r\nand I want to convert it to a tab separated file that looks like the following (note the lack of quotes)\r\n```\r\nalice   foo\r\nalice   bar\r\nalice   baz\r\nbob     qux\r\nbob     quux\r\n⋮\r\n```\r\nAll the array elements are guaranteed to be strings (no nulls).\r\nCan you help me come up with a jq script to achieve this?",
        "link": "https://stackoverflow.com/questions/76430218/convert-json-lines-to-tsv-producing-a-separate-line-for-each-array-item",
        "title": "Convert json-lines to tsv, producing a separate line for each array item"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1686234898,
                "creation_date": 1686234898,
                "answer_id": 76432957,
                "question_id": 76432932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s no need for `select()`, you can use the branch as the desired key in `buildByBranchName`:\r\n```\r\n.buildsByBranchName[.lastBuiltRevision.branch[0].name].buildNumber\r\n```\r\n\r\nOutput: `28694`\r\n\r\n\r\n----------\r\n\r\n\r\nShould you need to use the `.lastBuiltRevision.branch[0].name` on more places, consider setting a variable:\r\n```\r\n.lastBuiltRevision.branch[0].name as $branch | .buildsByBranchName[$branch].buildNumber\r\n```",
                "title": "Select an object based on the value of another object in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1686289723,
        "creation_date": 1686234727,
        "last_edit_date": 1686289723,
        "question_id": 76432932,
        "body_markdown": "Given the following (simplified) JSON.\r\n\r\n``` lang-json\r\n{\r\n  &quot;buildsByBranchName&quot;: {\r\n    &quot;origin/master&quot;: { &quot;buildNumber&quot;: 28694 },\r\n    &quot;master&quot;: { &quot;buildNumber&quot;: 28563 },\r\n    &quot;refs/remotes/origin/master&quot;: { &quot;buildNumber&quot;: 4094 }\r\n  },\r\n  &quot;lastBuiltRevision&quot;: {\r\n    &quot;branch&quot;: [\r\n      { &quot;name&quot;: &quot;origin/master&quot; }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nI want to find the build number of the last branch that was built.\r\n\r\nThe logic to do so is to find the name of the branch `.lastBuiltRevision.branch[0].name` = `origin/master`. Then use the branch name to find the build number `.buildsByBranchName | to_entries[] | select(.&quot;key&quot; == &quot;origin/master&quot;) .value.buildNumber` = `28694`. But I don&#39;t know how to combine them.\r\n\r\nAfter `.buildsByBranchName` I have no access to `lastBuiltRevision` in my select. Or is there any way?\r\n\r\nI can probably do this with two calls to jq. But I&#39;d really like to do this with only one.",
        "link": "https://stackoverflow.com/questions/76432932/select-an-object-based-on-the-value-of-another-object-in-jq",
        "title": "Select an object based on the value of another object in jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686343417,
                "creation_date": 1686343417,
                "answer_id": 76443522,
                "question_id": 76443318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    let data = [\r\n        {\r\n          &quot;key11&quot;: &quot;value11&quot;,\r\n          &quot;key12&quot;: &quot;value12&quot;,\r\n          &quot;key13&quot;: &quot;value13&quot;,\r\n          &quot;key14&quot;: &quot;value14&quot;\r\n        },\r\n        {\r\n          &quot;key21&quot;: &quot;value21&quot;,\r\n          &quot;key22&quot;: &quot;value22&quot;,\r\n          &quot;key23&quot;: &quot;value23&quot;,\r\n          &quot;key24&quot;: &quot;value24&quot;\r\n        },\r\n        {\r\n          &quot;key31&quot;: &quot;value31&quot;,\r\n          &quot;key32&quot;: &quot;value32&quot;,\r\n          &quot;key33&quot;: &quot;value33&quot;,\r\n          &quot;key34&quot;: &quot;value34&quot;\r\n        }\r\n       ];\r\n       \r\n       //https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/reduce\r\n       let result = data.reduce((acc,next) =&gt; {\r\n            let [first_val,second_val] = Object.values(next);\r\n            acc[first_val] = second_val;\r\n            return acc;\r\n       },{});\r\n    \r\n       console.log(JSON.stringify(result));",
                "title": "Map array of objects to object of key value pairs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1686398306,
                "creation_date": 1686398306,
                "answer_id": 76446102,
                "question_id": 76443318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; is there an option to use a string as index instead of a numeric index?\r\n\r\nYes, you could, for example, read the string keys as arguments, and resolve them in an iterative (or mapping) context.\r\n\r\nOne way would be to `reduce` the input into an initially empty output object `{}`, using the key of `to_entries` to access the iteration index, which in turn can be used to index into the argument list:\r\n```sh\r\njq &#39;reduce to_entries[] as {$key, $value} ({};\r\n  $ARGS.positional[$key *2:] as [$k, $v] | .[$value[$k]] = $value[$v]\r\n)&#39; input.json --args key11 key12 key21 key22 key31 key32\r\n```\r\n\r\nWith this effort, however, you could also just map the input array, and use `from_entries` to generate the output object, enabling you to use the `with_entries` shortcut:\r\n```sh\r\njq &#39;with_entries(\r\n  $ARGS.positional[.key *2:] as [$k, $v] | {key:.value[$k], value:.value[$v]}\r\n)&#39; input.json --args key11 key12 key21 key22 key31 key32\r\n```\r\n",
                "title": "Map array of objects to object of key value pairs"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1686428572,
                "creation_date": 1686428572,
                "answer_id": 76448033,
                "question_id": 76443318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I&#39;m sorry, my initial JSON structure was wrong: Each object in the array has the same keys.\r\n\r\nSo, assuming your input with all objects having the same keys looks like\r\n```json\r\n[\r\n  {\r\n    &quot;key1&quot;: &quot;value11&quot;,\r\n    &quot;key2&quot;: &quot;value12&quot;,\r\n    &quot;key3&quot;: &quot;value13&quot;,\r\n    &quot;key4&quot;: &quot;value14&quot;\r\n  },\r\n  {\r\n    &quot;key1&quot;: &quot;value21&quot;,\r\n    &quot;key2&quot;: &quot;value22&quot;,\r\n    &quot;key3&quot;: &quot;value23&quot;,\r\n    &quot;key4&quot;: &quot;value24&quot;\r\n  },\r\n  {\r\n    &quot;key1&quot;: &quot;value31&quot;,\r\n    &quot;key2&quot;: &quot;value32&quot;,\r\n    &quot;key3&quot;: &quot;value33&quot;,\r\n    &quot;key4&quot;: &quot;value34&quot;\r\n  }\r\n]\r\n```\r\n\r\nThen, you could either use `map` to turn each array item to a single-field object, and then `add` to combine these objects into one ([Demo](https://jqplay.org/s/J-BW2nCRLon)):\r\n```sh\r\njq &#39;map({(.key1): .key2}) | add&#39; input.json\r\n```\r\n\r\nOr you could `reduce` the array&#39;s items into an initially empty output object `{}` by iteratively setting another of its keys ([Demo](https://jqplay.org/s/eqhRNYclfP8)):\r\n```sh\r\njq &#39;reduce .[] as $i ({}; .[$i.key1] = $i.key2)&#39; input.json\r\n```\r\n\r\nBoth approaches return:\r\n```json\r\n{\r\n  &quot;value11&quot;: &quot;value12&quot;,\r\n  &quot;value21&quot;: &quot;value22&quot;,\r\n  &quot;value31&quot;: &quot;value32&quot;\r\n}\r\n```\r\n\r\n\r\n",
                "title": "Map array of objects to object of key value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1686428572,
        "creation_date": 1686340670,
        "question_id": 76443318,
        "body_markdown": "I have the following JSON structure:\r\n\r\n```json\r\n[\r\n {\r\n   &quot;key11&quot;: &quot;value11&quot;,\r\n   &quot;key12&quot;: &quot;value12&quot;,\r\n   &quot;key13&quot;: &quot;value13&quot;,\r\n   &quot;key14&quot;: &quot;value14&quot;\r\n },\r\n {\r\n   &quot;key21&quot;: &quot;value21&quot;,\r\n   &quot;key22&quot;: &quot;value22&quot;,\r\n   &quot;key23&quot;: &quot;value23&quot;,\r\n   &quot;key24&quot;: &quot;value24&quot;\r\n },\r\n {\r\n   &quot;key31&quot;: &quot;value31&quot;,\r\n   &quot;key32&quot;: &quot;value32&quot;,\r\n   &quot;key33&quot;: &quot;value33&quot;,\r\n   &quot;key34&quot;: &quot;value34&quot;\r\n }\r\n]\r\n```\r\n\r\nHow do I convert it to the following structure:\r\n\r\n```json\r\n{\r\n  &quot;value11&quot;: &quot;value12&quot;,\r\n  &quot;value21&quot;: &quot;value22&quot;, \r\n  &quot;value31&quot;: &quot;value32&quot;\r\n}\r\n```\r\n\r\nI have tried a few JQ operators, but nothing seems to work.",
        "link": "https://stackoverflow.com/questions/76443318/map-array-of-objects-to-object-of-key-value-pairs",
        "title": "Map array of objects to object of key value pairs"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686394019,
                "post_id": 76445806,
                "comment_id": 134794756,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686394063,
                "creation_date": 1686394063,
                "answer_id": 76445881,
                "question_id": 76445806,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Supposing you only want the modified item to be added to the array in `sub_meta.json`: You can load `full_meta.json` as a variable, modify it as you see fit, read `sub_meta.json` as input, append the modification to it, write the result into a temporary file, and if all was successful, replace the old `sub_meta.json` file with the new (temporary) output file.\r\n```sh\r\njq --argfile f full_meta.json \\\r\n  &#39;. + [$f[] | select(.product_id == &quot;881&quot;) | .product_id = &quot;881-new&quot;]&#39; \\\r\n  sub_meta.json &gt; sub_meta.tmp &amp;&amp; mv sub_meta.tmp sub_meta.json\r\n```",
                "title": "How to append an array of json into a json file using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686394063,
        "creation_date": 1686392914,
        "question_id": 76445806,
        "body_markdown": "I have an array of json objects in a file (full_meta.json).&lt;br/&gt;\r\n\r\n&lt;b&gt;full_meta.json:&lt;/b&gt;\r\n\r\n&gt; `[{&quot;product_id&quot;:&quot;xxx&quot;,&quot;name&quot;:&quot;yyy&quot;,&quot;qty&quot;:111},{&quot;product_id&quot;:&quot;881&quot;,&quot;name&quot;:&quot;aaa&quot;,&quot;qty&quot;:200}]`\r\n\r\nI want to filter a subset of this, modify it and append it to a file (sub_meta.json).&lt;br/&gt;\r\nsub_meta:json would contain an empty array to start with. I need to keep appending such values to fill it up&lt;br/&gt;&lt;br/&gt;\r\n&lt;b&gt;sub_meta.json:&lt;/b&gt;\r\n\r\n&gt; `[]`\r\n\r\nI am using the following commands to:&lt;br/&gt;\r\n1.Filter and modify id&lt;br/&gt;\r\n\r\n      d=$(jq &#39;[.[] | select(.product_id == &quot;881&quot;)] | map(.product_id =&quot;881-new&quot;)&#39; full_meta.json)\r\n\r\n2.Append it to another file\r\n\r\n      jq --argjson tmp &quot;$d&quot; &#39;.+=$tmp&#39; sub_meta.json\r\n\r\nI got the following error:\r\n\r\n    parse error: Invalid numeric literal at line 1, column 6\r\n\r\nWhat is the best way to achieve this using bash scripting?",
        "link": "https://stackoverflow.com/questions/76445806/how-to-append-an-array-of-json-into-a-json-file-using-jq",
        "title": "How to append an array of json into a json file using jq?"
    },
    {
        "tags": [
            "json",
            "xml",
            "jq",
            "xmlstarlet"
        ],
        "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": 1686565125,
                "post_id": 76455292,
                "comment_id": 134810887,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1507078,
                    "reputation": 4133,
                    "user_id": 1410218,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://www.gravatar.com/avatar/042b7423187499585dac9be396a6b95b?s=256&d=identicon&r=PG",
                    "display_name": "Krishan Gopal",
                    "link": "https://stackoverflow.com/users/1410218/krishan-gopal"
                },
                "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": 1686570429,
                "post_id": 76455292,
                "comment_id": 134811925,
                "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": 1686572551,
                "post_id": 76455292,
                "comment_id": 134812406,
                "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": 1686600838,
                "post_id": 76455292,
                "comment_id": 134818486,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1507078,
                    "reputation": 4133,
                    "user_id": 1410218,
                    "user_type": "registered",
                    "accept_rate": 14,
                    "profile_image": "https://www.gravatar.com/avatar/042b7423187499585dac9be396a6b95b?s=256&d=identicon&r=PG",
                    "display_name": "Krishan Gopal",
                    "link": "https://stackoverflow.com/users/1410218/krishan-gopal"
                },
                "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": 1686639502,
                "post_id": 76455292,
                "comment_id": 134822642,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1686674931,
                "creation_date": 1686674931,
                "answer_id": 76467102,
                "question_id": 76455292,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Highly unclear about how and which elements relate to each other (especially on iterations, as your sample provides only one set, and falls short on many edge cases), but here&#39;s (at least for starters) one way how to transform your sample JSON structure into your sample XML using [xq](https://github.com/kislyuk/yq) (which performs JSON &lt;-&gt; XML transformations, and uses jq under the hood):\r\n```sh\r\necho &#39;&lt;x/&gt;&#39; | xq -xn --argfile in input.json &#39;\r\n  def print: strings /= &quot;&lt;/p&gt;&lt;p&gt;&quot; | map(ltrimstr(&quot;&lt;p&gt;&quot;) | rtrimstr(&quot;&lt;/p&gt;&quot;)) | join(&quot; - &quot;);\r\n  $in | {\r\n    testsuites: {\r\n      testsuite: {\r\n        &quot;@tests&quot;: (.site | length),\r\n        &quot;@failures&quot;: ([.site[].alerts[]] | length),\r\n        &quot;@name&quot;: &quot;\\([.site[].&quot;@host&quot;] | print) - \\(.&quot;@programName&quot;)&quot;,\r\n        properties: [{\r\n          property: {\r\n            &quot;@name&quot;: &quot;type&quot;,\r\n            &quot;@value&quot;: .&quot;@programName&quot;\r\n          }\r\n        }],\r\n        &quot;testcase&quot;: [.site[] | {\r\n          &quot;@classname&quot;: ([.alerts[].name] | print),\r\n          &quot;@failures&quot;: ([.alerts[].instances[]] | length),\r\n          &quot;@name&quot;: ([.alerts[] | &quot;[\\((.riskdesc / &quot; &quot;)[0])] - \\(.name)&quot;] | print),\r\n          &quot;@file&quot;: &quot;&quot;,\r\n          failure: [.alerts[] | {\r\n            &quot;@message&quot;: .alert,\r\n            &quot;@type&quot;: &quot;failure&quot;,\r\n            &quot;#text&quot;: (\r\n              &quot;Description: \\(.desc | print) &quot; +\r\n              &quot;URIs Reported(\\(.count)): - \\([.instances[].uri] | print) &quot; +\r\n              &quot;Solution: \\(.solution | print) &quot; +\r\n              &quot;OtherInfo: \\(.otherinfo) &quot; +\r\n              &quot;Reference: - \\(.reference | print)&quot;\r\n            )\r\n          }]\r\n        }]\r\n      }\r\n    }\r\n  }\r\n&#39;\r\n```\r\n```xml\r\n&lt;testsuites&gt;\r\n  &lt;testsuite tests=&quot;1&quot; failures=&quot;1&quot; name=&quot;127.0.0.1 - OWASP ZAP&quot;&gt;\r\n    &lt;properties&gt;\r\n      &lt;property name=&quot;type&quot; value=&quot;OWASP ZAP&quot;&gt;&lt;/property&gt;\r\n    &lt;/properties&gt;\r\n    &lt;testcase classname=&quot;Content Security Policy (CSP) Header Not Set&quot; failures=&quot;3&quot; name=&quot;[Medium] - Content Security Policy (CSP) Header Not Set&quot; file=&quot;&quot;&gt;\r\n      &lt;failure message=&quot;Content Security Policy (CSP) Header Not Set&quot; type=&quot;failure&quot;&gt;Description: Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files. URIs Reported(3): - http://127.0.0.1:8000 - http://127.0.0.1:8000/robots.txt - http://127.0.0.1:8000/sitemap.xml Solution: Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header. OtherInfo:  Reference: - https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy - https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html - http://www.w3.org/TR/CSP/ - http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html - http://www.html5rocks.com/en/tutorials/security/content-security-policy/ - http://caniuse.com/#feat=contentsecuritypolicy - http://content-security-policy.com/&lt;/failure&gt;\r\n    &lt;/testcase&gt;\r\n  &lt;/testsuite&gt;\r\n&lt;/testsuites&gt;\r\n```",
                "title": "Problem when converting JSON to XML using jq and xmlstarlet"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1686674931,
        "creation_date": 1686562330,
        "last_edit_date": 1686648901,
        "question_id": 76455292,
        "body_markdown": "I am trying to convert JSON file into XML using following command which used JQ and XMSTARTLET\r\n\r\n    jq -r &#39;def walk(f): . as $in | if type == &quot;object&quot; then reduce keys_unsorted[] as $key (.; .[$key] = ($in[$key] | walk(f))) | f else f end; walk(tostring) | gsub(&quot;&amp;&quot;; &quot;&amp;amp;&quot;)&#39; input.json | xmlstarlet fo --omit-decl --indent-tab &gt; output.xml\r\n\r\nbut it fails with following error\r\n\r\n    -:1.1: Start tag expected, &#39;&lt;&#39; not found\r\n    {&quot;@programName&quot;:&quot;OWASP ZAP&quot;,&quot;@version&quot;:&quot;D-2023-05-30&quot;,&quot;@generated&quot;:&quot;Wed, 31 May\r\n    ^\r\nI verified my JSON file through online validator and it looks correct.\r\n\r\nmy input.json as follows \r\n\r\n```lang-json\r\n{\r\n\t&quot;@programName&quot;: &quot;OWASP ZAP&quot;,\r\n\t&quot;@version&quot;: &quot;D-2023-05-30&quot;,\r\n\t&quot;@generated&quot;: &quot;Wed, 31 May 2023 16:25:43&quot;,\r\n\t&quot;site&quot;:[ \r\n\t\t{\r\n\t\t\t&quot;@name&quot;: &quot;http://127.0.0.1:8000&quot;,\r\n\t\t\t&quot;@host&quot;: &quot;127.0.0.1&quot;,\r\n\t\t\t&quot;@port&quot;: &quot;8000&quot;,\r\n\t\t\t&quot;@ssl&quot;: &quot;false&quot;,\r\n\t\t\t&quot;alerts&quot;: [ \r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;pluginid&quot;: &quot;10038&quot;,\r\n\t\t\t\t\t&quot;alertRef&quot;: &quot;10038-1&quot;,\r\n\t\t\t\t\t&quot;alert&quot;: &quot;Content Security Policy (CSP) Header Not Set&quot;,\r\n\t\t\t\t\t&quot;name&quot;: &quot;Content Security Policy (CSP) Header Not Set&quot;,\r\n\t\t\t\t\t&quot;riskcode&quot;: &quot;2&quot;,\r\n\t\t\t\t\t&quot;confidence&quot;: &quot;3&quot;,\r\n\t\t\t\t\t&quot;riskdesc&quot;: &quot;Medium (High)&quot;,\r\n\t\t\t\t\t&quot;desc&quot;: &quot;&lt;p&gt;Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page \\u2014 covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.&lt;/p&gt;&quot;,\r\n\t\t\t\t\t&quot;instances&quot;:[ \r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;uri&quot;: &quot;http://127.0.0.1:8000&quot;,\r\n\t\t\t\t\t\t\t&quot;method&quot;: &quot;GET&quot;,\r\n\t\t\t\t\t\t\t&quot;param&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;attack&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;evidence&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;otherinfo&quot;: &quot;&quot;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;uri&quot;: &quot;http://127.0.0.1:8000/robots.txt&quot;,\r\n\t\t\t\t\t\t\t&quot;method&quot;: &quot;GET&quot;,\r\n\t\t\t\t\t\t\t&quot;param&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;attack&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;evidence&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;otherinfo&quot;: &quot;&quot;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;uri&quot;: &quot;http://127.0.0.1:8000/sitemap.xml&quot;,\r\n\t\t\t\t\t\t\t&quot;method&quot;: &quot;GET&quot;,\r\n\t\t\t\t\t\t\t&quot;param&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;attack&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;evidence&quot;: &quot;&quot;,\r\n\t\t\t\t\t\t\t&quot;otherinfo&quot;: &quot;&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\t\t\t&quot;count&quot;: &quot;3&quot;,\r\n\t\t\t\t\t&quot;solution&quot;: &quot;&lt;p&gt;Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header.&lt;/p&gt;&quot;,\r\n\t\t\t\t\t&quot;otherinfo&quot;: &quot;&quot;,\r\n\t\t\t\t\t&quot;reference&quot;: &quot;&lt;p&gt;https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy&lt;/p&gt;&lt;p&gt;https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html&lt;/p&gt;&lt;p&gt;http://www.w3.org/TR/CSP/&lt;/p&gt;&lt;p&gt;http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html&lt;/p&gt;&lt;p&gt;http://www.html5rocks.com/en/tutorials/security/content-security-policy/&lt;/p&gt;&lt;p&gt;http://caniuse.com/#feat=contentsecuritypolicy&lt;/p&gt;&lt;p&gt;http://content-security-policy.com/&lt;/p&gt;&quot;,\r\n\t\t\t\t\t&quot;cweid&quot;: &quot;693&quot;,\r\n\t\t\t\t\t&quot;wascid&quot;: &quot;15&quot;,\r\n\t\t\t\t\t&quot;sourceid&quot;: &quot;1&quot;\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t]\r\n}\r\n\r\n\r\n```\r\n\r\nI was not able to figure out what I am doing wrong here?\r\n\r\nI actually wanted to convert the JSON into XML in following Junit format\r\n\r\n\r\n```\r\n&lt;testsuites&gt;\r\n&lt;testsuite tests=&quot;1&quot; failures=&quot;1&quot; name=&quot;127.0.0.1 - OWASP ZAP&quot;&gt;\r\n&lt;properties&gt;\r\n&lt;property name=&quot;type&quot; value=&quot;OWASP ZAP&quot;/&gt;\r\n&lt;/properties&gt;\r\n&lt;testcase classname=&quot;Content Security Policy (CSP) Header Not Set&quot; failures=&quot;3&quot; name=&quot;[Medium] - Content Security Policy (CSP) Header Not Set&quot; file=&quot;&quot;&gt;\r\n&lt;failure message=&quot;Content Security Policy (CSP) Header Not Set&quot; type=&quot;failure&quot;&gt;Description: Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files. URIs Reported(3): - http://127.0.0.1:8000 - http://127.0.0.1:8000/robots.txt - http://127.0.0.1:8000/sitemap.xml Solution: Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header. OtherInfo: Reference: - https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy - https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html - http://www.w3.org/TR/CSP/ - http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html - http://www.html5rocks.com/en/tutorials/security/content-security-policy/ - http://caniuse.com/#feat=contentsecuritypolicy - http://content-security-policy.com/&lt;/failure&gt;\r\n&lt;/testcase&gt;\r\n&lt;/testsuite&gt;\r\n&lt;/testsuites&gt;\r\n```\r\n\r\nNumber of alerts becomes the failure and tests count for &lt;testsuite&gt; tag\r\n&quot;count&quot;: &quot;3&quot; becomes failure count for &lt;testcase&gt; tag\r\nUrls are concatenated and shown under  &lt;failure&gt; tag after &quot;URIs Reported(3):&quot;\r\n\r\n\r\nMoving further I found this question and some interesting answers. https://stackoverflow.com/questions/73038301/is-it-possible-to-convert-from-json-or-yaml-to-xml-using-jq-yq-xq  \r\n\r\nI tried using the filter &quot;json_to_xml.jq&quot; mentioned over there with following command\r\n\r\njq -Rf json_to_xml.jq input.json &gt; output.xml\r\n\r\nwhich gave XML results in following format, but I need result in above mentioned desired format\r\n\r\n```\r\n&lt;site name=&quot;http://127.0.0.1:8000&quot; host=&quot;127.0.0.1&quot; port=&quot;8000&quot; ssl=&quot;false&quot;&gt;&lt;alerts&gt;&lt;pluginid&gt;10038&lt;/pluginid&gt;&lt;alertRef&gt;10038-1&lt;/alertRef&gt;&lt;alert&gt;Content Security Policy (CSP) Header Not Set&lt;/alert&gt;&lt;name&gt;Content Security Policy (CSP) Header Not Set&lt;/name&gt;&lt;riskcode&gt;2&lt;/riskcode&gt;&lt;confidence&gt;3&lt;/confidence&gt;&lt;riskdesc&gt;Medium (High)&lt;/riskdesc&gt;&lt;desc&gt;&amp;lt;p&amp;gt;Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page — covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.&amp;lt;/p&amp;gt;&lt;/desc&gt;&lt;instances&gt;&lt;uri&gt;http://127.0.0.1:8000&lt;/uri&gt;&lt;method&gt;GET&lt;/method&gt;&lt;param&gt;&lt;/param&gt;&lt;attack&gt;&lt;/attack&gt;&lt;evidence&gt;&lt;/evidence&gt;&lt;otherinfo&gt;&lt;/otherinfo&gt;&lt;/instances&gt;&lt;instances&gt;&lt;uri&gt;http://127.0.0.1:8000/robots.txt&lt;/uri&gt;&lt;method&gt;GET&lt;/method&gt;&lt;param&gt;&lt;/param&gt;&lt;attack&gt;&lt;/attack&gt;&lt;evidence&gt;&lt;/evidence&gt;&lt;otherinfo&gt;&lt;/otherinfo&gt;&lt;/instances&gt;&lt;instances&gt;&lt;uri&gt;http://127.0.0.1:8000/sitemap.xml&lt;/uri&gt;&lt;method&gt;GET&lt;/method&gt;&lt;param&gt;&lt;/param&gt;&lt;attack&gt;&lt;/attack&gt;&lt;evidence&gt;&lt;/evidence&gt;&lt;otherinfo&gt;&lt;/otherinfo&gt;&lt;/instances&gt;&lt;count&gt;3&lt;/count&gt;&lt;solution&gt;&amp;lt;p&amp;gt;Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header.&amp;lt;/p&amp;gt;&lt;/solution&gt;&lt;otherinfo&gt;&lt;/otherinfo&gt;&lt;reference&gt;&amp;lt;p&amp;gt;https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;http://www.w3.org/TR/CSP/&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;http://www.html5rocks.com/en/tutorials/security/content-security-policy/&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;http://caniuse.com/#feat=contentsecuritypolicy&amp;lt;/p&amp;gt;&amp;lt;p&amp;gt;http://content-security-policy.com/&amp;lt;/p&amp;gt;&lt;/reference&gt;&lt;cweid&gt;693&lt;/cweid&gt;&lt;wascid&gt;15&lt;/wascid&gt;&lt;sourceid&gt;1&lt;/sourceid&gt;&lt;/alerts&gt;&lt;/site&gt;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76455292/problem-when-converting-json-to-xml-using-jq-and-xmlstarlet",
        "title": "Problem when converting JSON to XML using jq and xmlstarlet"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686566372,
                "post_id": 76455811,
                "comment_id": 134811139,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 47029,
                    "reputation": 32474,
                    "user_id": 139150,
                    "user_type": "registered",
                    "accept_rate": 84,
                    "profile_image": "https://i.sstatic.net/zCFCDh5n.png?s=256",
                    "display_name": "shantanuo",
                    "link": "https://stackoverflow.com/users/139150/shantanuo"
                },
                "reply_to_user": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686566477,
                "post_id": 76455811,
                "comment_id": 134811160,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686566687,
                "post_id": 76455811,
                "comment_id": 134811198,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686567413,
                "post_id": 76455811,
                "comment_id": 134811340,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1686567566,
                "creation_date": 1686567566,
                "answer_id": 76455989,
                "question_id": 76455811,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want to use the [`@csv`](https://jqlang.github.io/jq/manual/#Formatstringsandescaping) filter with [`-r`/`--raw-output`](https://jqlang.github.io/jq/manual/#Invokingjq) on a [sorted array](https://jqlang.github.io/jq/manual/#sort,sort_by(path_expression)) (and probably [apply rounding](https://stackoverflow.com/q/74152553/112968) to numbers, if I read your question right)\r\n\r\n```\r\njq -r &#39;.Datapoints\r\n| sort_by(.Timestamp)[]\r\n| [.Timestamp, (.Average*100|round/100)]\r\n| @csv&#39; output.txt\r\n```\r\n\r\nExample output:\r\n\r\n```csv\r\n&quot;2023-06-12T04:10:00+00:00&quot;,0.03\r\n&quot;2023-06-12T07:42:00+00:00&quot;,0.03\r\n&quot;2023-06-12T08:19:00+00:00&quot;,0.18\r\n```",
                "title": "convert code written in python to be compatible with jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1686567566,
        "creation_date": 1686566202,
        "last_edit_date": 1686567523,
        "question_id": 76455811,
        "body_markdown": "I have this python code that works.\r\nBut I will like to use jq command line utility so that it can be part of shell script.\r\n```\r\nimport pandas as pd\r\nimport json\r\n\r\nwith open(&#39;output.txt&#39;) as f:\r\n    x = json.load(f)\r\n\t\r\ndf = pd.DataFrame(x[&#39;Datapoints&#39;])\r\n\r\ndf.sort_values(&#39;Timestamp&#39;)\r\n\r\n```\r\n_____\r\n\r\nUpdate:\r\n\r\nI am getting correct output as shown below:\r\n\r\n```\r\n$ cat output.txt  | jq &#39; .Datapoints[] | {cidr: .Timestamp, comment: .Average} | join(&quot;,&quot;)&#39; | more\r\n\r\n&quot;2023-06-12T08:19:00+00:00,0.18333333333333332&quot;\r\n&quot;2023-06-12T04:10:00+00:00,0.03333333333333333&quot;\r\n&quot;2023-06-12T07:42:00+00:00,0.03333333333333333&quot;\r\n&quot;2023-06-12T03:33:00+00:00,0&quot;\r\n\r\n```\r\n\r\nBut I do not need double quotes and second field should be 0.18 instead of 0.1833\r\n_____\r\n\r\nUpdate 2:\r\n```\r\n# head -20 output.txt\r\n{\r\n    &quot;Label&quot;: &quot;DBLoad&quot;,\r\n    &quot;Datapoints&quot;: [\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2023-06-12T08:19:00+00:00&quot;,\r\n            &quot;Average&quot;: 0.18333333333333332,\r\n            &quot;Unit&quot;: &quot;None&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2023-06-12T04:10:00+00:00&quot;,\r\n            &quot;Average&quot;: 0.03333333333333333,\r\n            &quot;Unit&quot;: &quot;None&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2023-06-12T07:42:00+00:00&quot;,\r\n            &quot;Average&quot;: 0.03333333333333333,\r\n            &quot;Unit&quot;: &quot;None&quot;\r\n        },\r\n        {\r\n            &quot;Timestamp&quot;: &quot;2023-06-12T03:33:00+00:00&quot;,\r\n```",
        "link": "https://stackoverflow.com/questions/76455811/convert-code-written-in-python-to-be-compatible-with-jq-command",
        "title": "convert code written in python to be compatible with jq command"
    },
    {
        "tags": [
            "json",
            "jq",
            "filenames"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1686584147,
                "creation_date": 1686584147,
                "answer_id": 76458195,
                "question_id": 76458159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `input_filename` to get the file names, string interpolation `&quot;\\(...)&quot;` to compose and the `-r` flag to output text:\r\n```sh\r\njq -r &#39;&quot;\\(input_filename),\\(.score)&quot;&#39; /path/to/*/*.json\r\n```\r\n```\r\n/path/to/dir1/f12.json,0.98\r\n/path/to/dir1/f1.json,0.76\r\n/path/to/dir2/f1.json,0.89\r\n```",
                "title": "processing a list of files using jq and saving output to file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686595161,
        "creation_date": 1686583819,
        "last_edit_date": 1686595161,
        "question_id": 76458159,
        "body_markdown": "I have a list of files like so:\r\n\r\n```\r\n/path/to/dir1/f1.json\r\n/path/to/dir2/f1.json\r\n/path/to/dir1/f12.json\r\n..\r\n```\r\n\r\nthe json is like so:\r\n\r\n```\r\n{&quot;score&quot;: 0.98}\r\n```\r\n\r\nI would like to use `jq` to process all these files and produce an output:\r\n\r\n```\r\n/path/to/dir1/f1.json,0.76\r\n/path/to/dir2/f1.json,0.89\r\n/path/to/dir1/f12.json,0.98\r\n..\r\n```\r\n\r\nI know how to use `jq` on a single file, but would like to automate this for the list of files and produce the above output if this is possible.\r\n\r\nAny tips on how to pipe correctly to `jq` and assemble the output would be great\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76458159/processing-a-list-of-files-using-jq-and-saving-output-to-file",
        "title": "processing a list of files using jq and saving output to file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1686761005,
                "creation_date": 1686761005,
                "answer_id": 76475823,
                "question_id": 76475789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.projects | map({(.): {name: .}}) | add\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/_K8ncs_OXu7)&lt;/sup&gt;",
                "title": "How to use jq to create a JSON object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1686761890,
                "creation_date": 1686761890,
                "answer_id": 76475925,
                "question_id": 76475789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have a bit of a functional mindset, so I&#39;d reach for [`reduce`](https://jqlang.github.io/jq/manual/v1.6/#Reduce) here:\r\n```jq\r\nreduce .projects[] as $name ({}; . + {($name): {name: $name}})\r\n```\r\noutputs\r\n```json\r\n{\r\n  &quot;abc&quot;: {\r\n    &quot;name&quot;: &quot;abc&quot;\r\n  },\r\n  &quot;xyz&quot;: {\r\n    &quot;name&quot;: &quot;xyz&quot;\r\n  }\r\n}\r\n```",
                "title": "How to use jq to create a JSON object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1686767181,
        "creation_date": 1686760739,
        "last_edit_date": 1686767181,
        "question_id": 76475789,
        "body_markdown": "I have the following JSON object:\r\n\r\n```json\r\n{\r\n...,\r\n&quot;projects&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;xyz&quot;\r\n  ],\r\n...\r\n}\r\n```\r\n\r\nAnd I want it transformed to:\r\n```json\r\n{\r\n  &quot;abc&quot;: {\r\n    &quot;name&quot;: &quot;abc&quot;\r\n  },\r\n  &quot;xyz&quot;: {\r\n    &quot;name&quot;: &quot;xyz&quot;\r\n  },\r\n}\r\n```\r\n\r\nI&#39;m having trouble creating this. I&#39;ve tried using `map` as `.projects | map({(.): { &quot;name&quot;: (.) }} )` but it&#39;s not in the format I want and ends up in an array. ",
        "link": "https://stackoverflow.com/questions/76475789/how-to-use-jq-to-create-a-json-object",
        "title": "How to use jq to create a JSON object"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1686764428,
                "creation_date": 1686764428,
                "answer_id": 76476234,
                "question_id": 76476166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create a map from strings to numbers; look up the strings and sort by the resulting numbers.\r\n\r\n```jq\r\n{ &quot;CRITICAL&quot;: 0, &quot;HIGH&quot;: 1, &quot;MEDIUM&quot;: 2, &quot;LOW&quot;: 3} as $priority_orders |\r\n.vulnerabilities | sort_by($priority_orders[.Severity])\r\n```\r\n\r\n...properly returns, given your input data:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n    &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n    &quot;Severity&quot;: &quot;CRITICAL&quot;,\r\n    &quot;Version&quot;: &quot;6.3-2&quot;,\r\n    &quot;Description&quot;: &quot;example&quot;\r\n  },\r\n  {\r\n    &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n    &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n    &quot;Severity&quot;: &quot;HIGH&quot;,\r\n    &quot;Version&quot;: &quot;6.3-2&quot;,\r\n    &quot;Description&quot;: &quot;example&quot;\r\n  },\r\n  {\r\n    &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n    &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n    &quot;Severity&quot;: &quot;MEDIUM&quot;,\r\n    &quot;Version&quot;: &quot;6.3-2&quot;,\r\n    &quot;Description&quot;: &quot;example&quot;\r\n  },\r\n  {\r\n    &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n    &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n    &quot;Severity&quot;: &quot;LOW&quot;,\r\n    &quot;Version&quot;: &quot;6.3-2&quot;,\r\n    &quot;Description&quot;: &quot;example&quot;\r\n  }\r\n]\r\n```\r\n\r\n(You might want to instead sort by a list or tuple, such as `[$priority_orders[.Severity], .Product, .Version]`, to come up with data that&#39;s usefully ordered when there&#39;s more than one thing at each severity level; consider it left as an exercise to the reader).",
                "title": "JQ Sorting by value"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1686764798,
                "creation_date": 1686764798,
                "answer_id": 76476283,
                "question_id": 76476166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could create a stream of booleans, and sort by that. (Use `!=` for the same order, `==` for reversed order.)\r\n```sh\r\n.vulnerabilities |= sort_by(.Severity != (&quot;CRITICAL&quot;,&quot;HIGH&quot;,&quot;MEDIUM&quot;,&quot;LOW&quot;))\r\n```\r\n```json\r\n{\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;CRITICAL&quot;,\r\n      &quot;Version&quot;: &quot;6.3-2&quot;,\r\n      &quot;Description&quot;: &quot;example&quot;\r\n    },\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;HIGH&quot;,\r\n      &quot;Version&quot;: &quot;6.3-2&quot;,\r\n      &quot;Description&quot;: &quot;example&quot;\r\n    },\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;MEDIUM&quot;,\r\n      &quot;Version&quot;: &quot;6.3-2&quot;,\r\n      &quot;Description&quot;: &quot;example&quot;\r\n    },\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;LOW&quot;,\r\n      &quot;Version&quot;: &quot;6.3-2&quot;,\r\n      &quot;Description&quot;: &quot;example&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/XPs3Yh9RUc3)",
                "title": "JQ Sorting by value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1686826610,
        "creation_date": 1686763803,
        "last_edit_date": 1686826610,
        "question_id": 76476166,
        "body_markdown": "I am looking to sort an array in JQ by a custom map of values and struggling to figure it out. Hoping someone here can point out a way to do this.\r\n\r\nI have an array of objects that describe software vulnerabilities and want to sort the objects in order by Severity value: CRITICAL, HIGH, MEDIUM, LOW\r\n\r\nThe array looks like this:\r\n\r\n    {\r\n      &quot;vulnerabilities&quot;: [\r\n        {\r\n          &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n          &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n          &quot;Severity&quot;: &quot;MEDIUM&quot;,\r\n          &quot;Version&quot;: &quot;6.3-2&quot;,\r\n          &quot;Description&quot;: &quot;example&quot;\r\n        },\r\n        {\r\n          &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n          &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n          &quot;Severity&quot;: &quot;HIGH&quot;,\r\n          &quot;Version&quot;: &quot;6.3-2&quot;,\r\n          &quot;Description&quot;: &quot;example&quot;\r\n        },\r\n        {\r\n          &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n          &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n          &quot;Severity&quot;: &quot;CRITICAL&quot;,\r\n          &quot;Version&quot;: &quot;6.3-2&quot;,\r\n          &quot;Description&quot;: &quot;example&quot;\r\n        },\r\n        {\r\n          &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n          &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n          &quot;Severity&quot;: &quot;LOW&quot;,\r\n          &quot;Version&quot;: &quot;6.3-2&quot;,\r\n          &quot;Description&quot;: &quot;example&quot;\r\n        }\r\n      ]\r\n    }\r\nIs there an easy-ish way to do this with JQ?\r\n\r\nThank you!\r\n\r\nI have tried using the sort_by() function in JQ but can&#39;t seem to figure out how to apply a custom order (not looking to organize alphabetically)",
        "link": "https://stackoverflow.com/questions/76476166/jq-sorting-by-value",
        "title": "JQ Sorting by value"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "miller"
        ],
        "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": 1686777826,
                "post_id": 76477520,
                "comment_id": 134847693,
                "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": 1686790430,
                "post_id": 76477520,
                "comment_id": 134849022,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1686817857,
                "post_id": 76477520,
                "comment_id": 134852399,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1686818654,
                "creation_date": 1686818654,
                "answer_id": 76480692,
                "question_id": 76477520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you run in your sample input\r\n\r\n```\r\n&lt;input.txt sed &#39;/name,/d&#39; | jq -cr &#39;.field2.subfield.subfield2 | keys[]&#39; | paste -s -d &#39; &#39; | mlr --csv --implicit-csv-header then label name\r\n```\r\n\r\nyou get\r\n\r\n```\r\nname\r\nactive passive running\r\n```\r\n\r\nThe sample output you write, is wrong, because if it&#39;s a one field CSV, you do not have the `,` after name, there are no other fields\r\n\r\n```\r\nname, \r\nactive passive running\r\n```\r\n\r\n\r\nBut I probably didn&#39;t understand what you want",
                "title": "How to select value from CSV containing JSON as a column"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1686823624,
                "creation_date": 1686823624,
                "answer_id": 76481405,
                "question_id": 76477520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use your favorite CSV-to-TSV translator to convert the CSV to TSV and then run it through jq like so:\r\n\r\n    jq -rR &#39;\r\n      split(&quot;\\t&quot;) \r\n      | [[.0], \r\n         ( .[1]|fromjson|.field2.subfield.subfield2 | keys_unsorted|join(&quot; &quot;))] \r\n      | @csv&#39;\r\n\r\n",
                "title": "How to select value from CSV containing JSON as a column"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1686849238,
                "creation_date": 1686849238,
                "answer_id": 76484044,
                "question_id": 76477520,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I spent some time with sed and it got me what I needed using the below:\r\n\r\n    sed -e &#39;s/.*subfield2\\(.*\\)}}}.*/\\1/&#39; input.txt\r\n\r\n",
                "title": "How to select value from CSV containing JSON as a column"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1686856941,
        "creation_date": 1686776632,
        "last_edit_date": 1686856941,
        "question_id": 76477520,
        "body_markdown": "I have a weird CSV with one column being JSON data of quite a large size and one is a name. Showing proper JSON formatting for clarity, but the actual file is flat with no newline chars.\r\n\r\n\r\n```\r\nname, \r\n{\r\n&quot;field1&quot;:\r\n   {&quot;name&quot;:&quot;foo&quot;,\r\n   &quot;email&quot;:&quot;test@gmail.com&quot;},\r\n&quot;field2&quot;:{\r\n     &quot;subfield&quot;:{\r\n          &quot;subfield2&quot;:{\r\n               &quot;active&quot;:1,\r\n               &quot;passive&quot;:11,\r\n               &quot;running&quot;:111\r\n                       }\r\n                  }\r\n           }\r\n}\r\n\r\n```\r\n\r\nThe input without pretty formatting…\r\n\r\n```txt\r\nname,{&quot;field1&quot;:{&quot;name&quot;:&quot;foo&quot;,&quot;email&quot;:&quot;test@gmail.com&quot;},&quot;field2&quot;:{&quot;subfield&quot;:{&quot;subfield2&quot;:{&quot;active&quot;:1,&quot;passive&quot;:11,&quot;running&quot;:111}}}}\r\n```\r\n\r\nI am trying to get the name and all unique values for the subfield 2 into a output (ideally CSV).\r\n\r\n\r\n```\r\nname, \r\nactive passive running\r\n\r\n```\r\n\r\n\r\nThe issue is that the number of fields is not constant and the names of the subfields are not constant either. I have tried using jq, Miller, and sed/awk without much luck since it combines a huge JSON blob and CSV data.\r\n",
        "link": "https://stackoverflow.com/questions/76477520/how-to-select-value-from-csv-containing-json-as-a-column",
        "title": "How to select value from CSV containing JSON as a column"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1686783120,
                "post_id": 76477940,
                "comment_id": 134848396,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1686783211,
                "post_id": 76477940,
                "comment_id": 134848404,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18313268,
                    "reputation": 3,
                    "user_id": 13335608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03708cfd1c41cbe9be71d0a649378fe7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "The Crusher",
                    "link": "https://stackoverflow.com/users/13335608/the-crusher"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686789953,
                "post_id": 76477940,
                "comment_id": 134848986,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686791794,
                "post_id": 76477940,
                "comment_id": 134849154,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18313268,
                    "reputation": 3,
                    "user_id": 13335608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03708cfd1c41cbe9be71d0a649378fe7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "The Crusher",
                    "link": "https://stackoverflow.com/users/13335608/the-crusher"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686795907,
                "post_id": 76477940,
                "comment_id": 134849550,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686796286,
                "post_id": 76477940,
                "comment_id": 134849579,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686799593,
                "post_id": 76477940,
                "comment_id": 134849826,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18313268,
                    "reputation": 3,
                    "user_id": 13335608,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/03708cfd1c41cbe9be71d0a649378fe7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "The Crusher",
                    "link": "https://stackoverflow.com/users/13335608/the-crusher"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686844223,
                "post_id": 76477940,
                "comment_id": 134857047,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686844926,
                "post_id": 76477940,
                "comment_id": 134857196,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686845504,
                "post_id": 76477940,
                "comment_id": 134857320,
                "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": 1686846643,
                "post_id": 76477940,
                "comment_id": 134857577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "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": 1686850523,
                "post_id": 76477940,
                "comment_id": 134858358,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686852514,
                "post_id": 76477940,
                "comment_id": 134858750,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686852669,
                "post_id": 76477940,
                "comment_id": 134858776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686867308,
                "last_edit_date": 1686867308,
                "creation_date": 1686846401,
                "answer_id": 76483716,
                "question_id": 76477940,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My understanding is that JSON can only contain escaped double-quotes inside double-quoted strings. This leads me to believe it is safe to append newlines after something of form `&quot;`**key**`&quot;:&quot;`**value**`&quot;`.\r\n\r\nIf you can choose a key/value pair that occurs sufficiently often, then you can use gawk to insert newlines.\r\n\r\nTaking an example from your &quot;standard&quot; that seems to appear quite often in your test file:\r\n\r\n```\r\ngawk -v RS=&#39;&quot;negotiation_arrangement&quot;:&quot;(ffs|bundle|capitation)&quot;&#39; \\\r\n     &#39;ORS=RT&quot;\\n&quot;&#39; &lt;infile &gt;outfile\r\n```\r\n\r\ninserts a newline after every occurrence of this regex. \r\n\r\ngawk read records one at a time, delimited by the regex in `RS`, and sets `ORS` to be the actual string (`RT`) followed by newline. Since the `ORS` assignment result is always &quot;truthy&quot;, the default print action occurs.\r\n\r\nMemory usage will be some small multiple of the maximum length between occurrences of the regex.\r\n\r\nFor the test file provided, my 5-year old laptop took half an hour to run `zcat | gawk | wc -l` while I was using the machine for other things, needed &lt;44MB virtual memory, was CPU-bound, and finally reported 333443 lines. `zcat | wc -c` took 5 minutes.",
                "title": "How can I convert extremely large json files (150GB +) that have line lengths greater than 2GB?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1686867308,
        "creation_date": 1686781376,
        "last_edit_date": 1686853441,
        "question_id": 76477940,
        "body_markdown": "Every month I receive extremely large and complex json files. The files are routinely 1-50GB and sometimes larger than 150GB. The files are loaded into aws emr hive tables, then processed using hive json functions. \r\nWhen the process attempts to load a json file that contains a line with a length greater than 2GB the process fails. \r\n\r\n\r\nI tried using jq (jq -c . &lt; source.json &gt; output.json ) to compact and format the files. This worked on smaller test files but does not scale. I tried jq&#39;s stream function but the process used up memory when rebuilding the structure.\r\n\r\nI am looking for a way to reformat a json file, that has line lengths exceeding 2GB, that does not require loading the entire file into memory. \r\n\r\nCan this be accomplished with jq? \r\n\r\n[50GB test file] (https://webtpa-public-access.s3.us-west-2.amazonaws.com/subfolder/2023_06_430_65B0_in_network_rates.json.gz)\r\n",
        "link": "https://stackoverflow.com/questions/76477940/how-can-i-convert-extremely-large-json-files-150gb-that-have-line-lengths-gr",
        "title": "How can I convert extremely large json files (150GB +) that have line lengths greater than 2GB?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 22051129,
                    "reputation": 86,
                    "user_id": 16315413,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GhuDZYp7uEEh9T9U24kS2fY0E8C-zlLWCpUgaT3qA=k-s256",
                    "display_name": "Krunal Jethi",
                    "link": "https://stackoverflow.com/users/16315413/krunal-jethi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686807385,
                "post_id": 76479372,
                "comment_id": 134850536,
                "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": 1686808916,
                "post_id": 76479372,
                "comment_id": 134850718,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28418592,
                    "reputation": 3,
                    "user_id": 21740976,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9cc84274df0123c4ecfed9fb85a6870b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Spliced Anomaly",
                    "link": "https://stackoverflow.com/users/21740976/spliced-anomaly"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686882920,
                "post_id": 76479372,
                "comment_id": 134862624,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1686809294,
                "creation_date": 1686809294,
                "answer_id": 76479559,
                "question_id": 76479372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you just want to translate certain keys to certain other keys (with slight modifications sometimes), just create a new object, and assign the corresponding values (I didn&#39;t get where `uuid` is supposed to come from):\r\n```\r\n{\r\n  type: .kind | ascii_downcase,\r\n  uuid: &quot;???&quot;,\r\n  name: .account,\r\n  issuer,\r\n  note: &quot;&quot;,\r\n  icon: null,\r\n  info: {\r\n    secret,\r\n    algo: .algorithm,\r\n    digits: .digits | tonumber,\r\n    period: .timer | tonumber\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/tz0xF7ITpHy)\r\n\r\nIf you wanto pursue the &quot;middle man&quot; approach from the linked article, also show the intermediate srtructure you want to convert to/from.",
                "title": "Adding an object to output w/ flat input"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1686809294,
        "creation_date": 1686807004,
        "last_edit_date": 1686807390,
        "question_id": 76479372,
        "body_markdown": "I&#39;m trying to get data from one app into a format that another app will accept. I&#39;m actualy trying to do exactly what this blog post is about but with jq instead of their program. https://www.tygertec.com/aegis-raivo-otp-translator/\r\n\r\nSample input data:\r\n\r\n    {\r\n    \t&quot;kind&quot;: &quot;TOTP&quot;,\r\n    \t&quot;account&quot;: &quot;google@gmail.com&quot;,\r\n    \t&quot;secret&quot;: &quot;GoogleSecret&quot;,\r\n    \t&quot;iconType&quot;: &quot;raivo_repository&quot;,\r\n    \t&quot;issuer&quot;: &quot;Google.com&quot;,\r\n    \t&quot;timer&quot;: &quot;30&quot;,\r\n    \t&quot;digits&quot;: &quot;6&quot;,\r\n    \t&quot;counter&quot;: &quot;0&quot;,\r\n    \t&quot;algorithm&quot;: &quot;SHA1&quot;,\r\n    \t&quot;iconValue&quot;: &quot;google.com/google-gmail.png&quot;\r\n    },\r\n\r\nI&#39;d like the output to look like this:\r\n\r\n    {\r\n    \t&quot;type&quot;: &quot;totp&quot;,\r\n    \t&quot;uuid&quot;: &quot;b33ca6f5-7661-4289-afcc-ee9847c3e59a&quot;,\r\n    \t&quot;name&quot;: &quot;google@gmail.com&quot;,\r\n    \t&quot;issuer&quot;: &quot;Google.com&quot;,\r\n    \t&quot;note&quot;: &quot;&quot;,\r\n    \t&quot;icon&quot;: null,\r\n    \t&quot;info&quot;: {\r\n    \t  &quot;secret&quot;: &quot;GoogleSecret&quot;,\r\n    \t  &quot;algo&quot;: &quot;SHA1&quot;,\r\n    \t  &quot;digits&quot;: 6,\r\n    \t  &quot;period&quot;: 30\r\n    \t}\r\n    }\r\n\r\n\r\n\r\nMost of this is just relabelling the fields, like from &quot;kind&quot; to &quot;type&quot; (I would like to figure out how to capitalize, but that is not my question), but I&#39;m having a hell of a time figuring out how to make the &quot;info&quot; object.\r\n\r\nI found some similar questions where map/reduce are used and tried reworking those into what I need, but I don&#39;t want to make an object for every key, and I&#39;m generally confused about how to construct an object combining a) the keys I just need to do a simple &quot;rename&quot; (ex: type: .kind) on and a) the new (nested) &quot;info&quot; object.\r\n\r\nThank you for any help.",
        "link": "https://stackoverflow.com/questions/76479372/adding-an-object-to-output-w-flat-input",
        "title": "Adding an object to output w/ flat input"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686828164,
                "post_id": 76481941,
                "comment_id": 134854524,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "reply_to_user": {
                    "account_id": 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": 1686828458,
                "post_id": 76481941,
                "comment_id": 134854581,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686830106,
                "post_id": 76481941,
                "comment_id": 134854947,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686832020,
                "post_id": 76481941,
                "comment_id": 134855376,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1976031,
                    "reputation": 30404,
                    "user_id": 1773798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/4Ljqn.png?s=256",
                    "display_name": "Renaud Pacalet",
                    "link": "https://stackoverflow.com/users/1773798/renaud-pacalet"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686832962,
                "post_id": 76481941,
                "comment_id": 134855619,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1976031,
                    "reputation": 30404,
                    "user_id": 1773798,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/4Ljqn.png?s=256",
                    "display_name": "Renaud Pacalet",
                    "link": "https://stackoverflow.com/users/1773798/renaud-pacalet"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1686833437,
                "post_id": 76481941,
                "comment_id": 134855730,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1686832665,
                "creation_date": 1686832665,
                "answer_id": 76482561,
                "question_id": 76481941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, JQ can do all that. Here is how I&#39;d write it: \r\n```\r\njq -nr &#39;\r\ndef valid_key: test(&quot;^[A-Za-z_][0-9A-Za-z_]*$&quot;);\r\ndef valid_value:\r\n    type != &quot;array&quot; and type != &quot;object&quot; and (\r\n        type != &quot;string&quot; or (test(&quot;\\u0000&quot;) | not)\r\n    );\r\ndef valid_input:\r\n    type == &quot;object&quot; and (\r\n        to_entries | all(\r\n            (.key | valid_key) and (.value | valid_value)\r\n        )\r\n    );\r\ninput |\r\n    if valid_input and isempty(inputs) then\r\n        to_entries[] | &quot;\\(.key)=\\(.value | @sh)&quot;\r\n    else\r\n        &quot;bad input\\n&quot; | halt_error(1)\r\n    end&#39;\r\n```",
                "title": "How to validate a JSON with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1686832699,
                "creation_date": 1686832699,
                "answer_id": 76482566,
                "question_id": 76481941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a demo how to do the testing. For production, however, it&#39;d obviously need more refinement.\r\n```sh\r\nif type != &quot;object&quot; then &quot;\\(@json) is not an object (#1)&quot;\r\nelse to_entries[] |\r\n  if .key | test(&quot;\\\\A[_a-zA-Z]\\\\w*\\\\z&quot;) | not then &quot;\\(.key | @json) is illegal (#2)&quot;\r\n  else .value |\r\n    if isempty(scalars) then &quot;\\(.) is not a scalar (#3)&quot;\r\n    else tostring |\r\n      if test(&quot;\\u0000&quot;) then &quot;\\(.[index(&quot;\\u0000&quot;)+1:] | @json) is preceded by NUL (#4)&quot;\r\n      else empty\r\n      end\r\n    end\r\n  end\r\nend // (to_entries[] | .key + &quot;=&quot; + (.value | @sh))\r\n```\r\n```\r\n&quot;&quot; is illegal (#2)\r\n&quot;illegal key shall fail&quot; is illegal (#2)\r\n[1,2] is not a scalar (#3)\r\n{&quot;k&quot;:&quot;v&quot;} is not a scalar (#3)\r\n&quot;.txt&quot; is preceded by NUL (#4)\r\ntask_uuid=&#39;5d7ea654-b649-452b-a8fd-002b56be9a59&#39;\r\ntask_name=&#39;hello world&#39;\r\nuser_email=null\r\nmin=7\r\nmax=100\r\nave=2.5\r\nfile_in=&#39;data.txt&#39;\r\nfile_out=&#39;results.txt&#39;\r\n```\r\n[Demo](https://jqplay.org/s/vxIUfvTdgMW)",
                "title": "How to validate a JSON with jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1687065207,
                "last_edit_date": 1687065207,
                "creation_date": 1687057881,
                "answer_id": 76498905,
                "question_id": 76481941,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following is a variant of @oguzismail&#39;s answer.  The main difference is that the &quot;driver&quot; program identifies all validation errors in the input, so long as it is a valid stream of JSON entities.\r\n\r\nAssuming 1.json and 2.json are the files corresponding to the two sample JSON objects in the Q:\r\n\r\n```\r\n(cat 1.json 2.json 1.json1) | jq -n &#39;\r\n\r\n# If cond is falsey, then (msg|debug); in all cases, emit .\r\ndef verify(cond; msg): \r\n  . as $in\r\n  | if cond then . else (msg | debug) | $in end;\r\n\r\ndef valid_key: test(&quot;^[A-Za-z_][0-9A-Za-z_]*$&quot;);\r\n\r\ndef valid_value:\r\n  type != &quot;array&quot; and \r\n  type != &quot;object&quot; and\r\n  (type != &quot;string&quot; or (test(&quot;\\u0000&quot;) | not) );\r\n\r\n# $count is for the messages and for the return value\r\ndef validate($count):\r\n   if type == &quot;object&quot;\r\n   then to_entries[]\r\n   | verify(.key | valid_key; &quot;invalid key in entity #\\($count): \\(.key)&quot;)\r\n   | verify(.value | valid_value; &quot;invalid value in entity #\\($count): \\(.value)&quot;)\r\n   else &quot;entity #\\($count) is not a JSON object&quot; | debug\r\n   end\r\n   | $count;\r\n\r\nreduce inputs as $in (0;\r\n  .+1\r\n  | . as $count\r\n  | $in | validate($count) )\r\n| verify(.==1; &quot;only one entity is allowed&quot;)\r\n| empty\r\n&#39;\r\n```\r\nproduces:\r\n```\r\n[&quot;DEBUG:&quot;,&quot;invalid key in entity #1: &quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid key in entity #1: illegal key shall fail&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #1: [1,2]&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #1: {\\&quot;k\\&quot;:\\&quot;v\\&quot;}&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #1: file.php\\u0000.txt&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid key in entity #3: &quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid key in entity #3: illegal key shall fail&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #3: [1,2]&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #3: {\\&quot;k\\&quot;:\\&quot;v\\&quot;}&quot;]\r\n[&quot;DEBUG:&quot;,&quot;invalid value in entity #3: file.php\\u0000.txt&quot;]\r\n[&quot;DEBUG:&quot;,&quot;only one entity is allowed&quot;]\r\n```\r\n",
                "title": "How to validate a JSON with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1687065207,
        "creation_date": 1686827984,
        "last_edit_date": 1686908825,
        "question_id": 76481941,
        "body_markdown": "I&#39;m writing a bash library where I need to read a JSON file that contains user input; the JSON won&#39;t be forged but it might contain armful values for bash scripts, depending on how the form was validated upstream.\r\n\r\nIn the function that loads the JSON into a bash array, I&#39;m not aware of the keys that must exist yet; still, there are some rules that I would like to enforce here:\r\n\r\n1. The JSON must contain a single object\r\n2. All keys shall be named like shell variables\r\n3. All values must be scalars\r\n4. No `NUL` byte in values\r\n\r\n```json\r\n{\r\n  &quot;&quot;: &quot;empty key shall fail&quot;,\r\n  &quot;illegal key shall fail&quot;: &quot;keys shall follow the naming convention of shell variables&quot;,\r\n  &quot;non_scalar_shall_fail_1&quot;: [1,2],\r\n  &quot;non_scalar_shall_fail_2&quot;: {&quot;k&quot;:&quot;v&quot;},\r\n  &quot;nul_byte_shall_fail&quot;: &quot;file.php\\u0000.txt&quot;\r\n}\r\n{\r\n  &quot;task_uuid&quot;: &quot;5d7ea654-b649-452b-a8fd-002b56be9a59&quot;,\r\n  &quot;task_name&quot;: &quot;hello world&quot;,\r\n  &quot;user_email&quot;: null,\r\n  &quot;min&quot;: 7,\r\n  &quot;max&quot;: 100,\r\n  &quot;ave&quot;: 2.5,\r\n  &quot;file_in&quot;: &quot;data.txt&quot;,\r\n  &quot;file_out&quot;: &quot;results.txt&quot;\r\n}\r\n```\r\n\r\nI can enforce **#2** and **#4** but I don&#39;t know how to do it for **#1** and **#3**:\r\n\r\n```sh\r\njq -r &#39;\r\n    to_entries[] |\r\n    if (.key | test(&quot;\\\\A[_a-zA-Z]\\\\w*\\\\z&quot;) | not)\r\n    then\r\n        (&quot;error: illegal key &quot; + (.key | tojson) + &quot;\\n&quot; |\r\n        halt_error(1))\r\n    else\r\n        if (.value | tostring | test(&quot;\\u0000&quot;))\r\n        then\r\n            (&quot;error: NUL byte in value &quot; + (.value | tojson) + &quot;\\n&quot; |\r\n            halt_error(1))\r\n        else\r\n            # dummy output\r\n            .key + &quot;=&quot; + (.value | @sh)\r\n        end\r\n    end\r\n&#39;\r\n```\r\n\r\nThe result is quite unexpected: the `halt_error` half-works and I get a coredump...\r\n\r\n```none\r\nerror: illegal key &quot;&quot;\r\ntask_uuid=&#39;5d7ea654-b649-452b-a8fd-002b56be9a59&#39;\r\ntask_name=&#39;hello world&#39;\r\nuser_email=null\r\nmin=7\r\nmax=100\r\nave=2.5\r\nfile_in=&#39;data.txt&#39;\r\nfile_out=&#39;results.txt&#39;\r\n*** Error in `jq&#39;: corrupted double-linked list ***\r\n...\r\nAborted                 (core dumped)\r\n```\r\n\r\nIs it even possible to do all those validations with `jq` or do I need to switch to an other tool?",
        "link": "https://stackoverflow.com/questions/76481941/how-to-validate-a-json-with-jq",
        "title": "How to validate a JSON with jq?"
    },
    {
        "tags": [
            "amazon-web-services",
            "jq",
            "aws-cli",
            "amazon-ecr"
        ],
        "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": 1686835138,
                "post_id": 76482895,
                "comment_id": 134856165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686835467,
                "post_id": 76482895,
                "comment_id": 134856250,
                "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": 1686845434,
                "post_id": 76482895,
                "comment_id": 134857305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2679463,
                    "reputation": 2854,
                    "user_id": 2315104,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/67897548b9d55c6e2f8e3171fa7ca20d?s=256&d=identicon&r=PG",
                    "display_name": "user2315104",
                    "link": "https://stackoverflow.com/users/2315104/user2315104"
                },
                "reply_to_user": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686846163,
                "post_id": 76482895,
                "comment_id": 134857464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2679463,
                    "reputation": 2854,
                    "user_id": 2315104,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/67897548b9d55c6e2f8e3171fa7ca20d?s=256&d=identicon&r=PG",
                    "display_name": "user2315104",
                    "link": "https://stackoverflow.com/users/2315104/user2315104"
                },
                "reply_to_user": {
                    "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": 1686846182,
                "post_id": 76482895,
                "comment_id": 134857472,
                "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": 1686846876,
                "post_id": 76482895,
                "comment_id": 134857628,
                "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": 1686847543,
                "post_id": 76482895,
                "comment_id": 134857765,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2679463,
                    "reputation": 2854,
                    "user_id": 2315104,
                    "user_type": "registered",
                    "accept_rate": 42,
                    "profile_image": "https://www.gravatar.com/avatar/67897548b9d55c6e2f8e3171fa7ca20d?s=256&d=identicon&r=PG",
                    "display_name": "user2315104",
                    "link": "https://stackoverflow.com/users/2315104/user2315104"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1686853357,
                "post_id": 76482895,
                "comment_id": 134858899,
                "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": 1686865103,
                "post_id": 76482895,
                "comment_id": 134860974,
                "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": 1686945539,
                "post_id": 76482895,
                "comment_id": 134873566,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1686902172,
                "creation_date": 1686902172,
                "answer_id": 76488085,
                "question_id": 76482895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the built in `--query` parameter of AWS cli. So this is what you need:\r\n\r\n```\r\naws ecr list-images --repository-name plat --query &#39;imageIds[].imageTag&#39; --output text\r\n```\r\n\r\n",
                "title": "how to list image tags using aws cli on windows"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1686997758,
                "creation_date": 1686997758,
                "answer_id": 76495773,
                "question_id": 76482895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "here is the command on windows \r\n\r\nFor Windows : \r\n\r\n    powershell.exe aws ecr list-images --repository-name &lt;repo-name&gt; | jq &#39;.imageIds | map (.imageTag) | sort | reverse | first&#39;&quot;\r\n\r\nsame is mentioned here \r\n\r\nhttps://eduwebmonster.com/how-to-list-aws-ecr-images-with-latest-tag-on-windows-and-linux/\r\n",
                "title": "how to list image tags using aws cli on windows"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1686997758,
        "creation_date": 1686834994,
        "last_edit_date": 1686846148,
        "question_id": 76482895,
        "body_markdown": "Im trying to list the image tags from ECR repo using below command on windows  \r\n\r\n    aws ecr list-images --repository-name plat   | jq &#39;.imageIds   | map (.imageTag)  | sort | .[]&#39;   | sort -r   | head -1\r\n\r\nI installed jq utility , however , it says `&#39;map&#39; is not recognized as an internal or external command,`\r\n\r\ni tried lot finding map utility for windows but did not get . how can I make this entire command work on windows ? it worked perfectly on linux. \r\n\r\nany workaround ?\r\ndo we have any equivalent command on windows ? please suggest  \r\n\r\n**UPDATE 1** \r\n\r\n**on windows** \r\n\r\n    C:\\Users\\ik\\Downloads&gt;aws ecr list-images --repository-name plat   | jq &#39;.imageIds   | map (.imageTag)  | sort | .[]&#39;   | sort -r   | head -1\r\n    &#39;map&#39; is not recognized as an internal or external command,\r\n    operable program or batch file.\r\n    PS C:\\Users\\ik\\Downloads&gt;\r\n\r\n**on linux** \r\n\r\n    root@CSX-Ik:~# aws ecr list-images --repository-name plat | jq &#39;.imageIds | map (.imageTag)|sort|.[]&#39; | sort -r | head -1\r\n    &quot;19617.1&quot;\r\n    root@CSX-Ik:~#\r\n\r\n\r\n**UPDATE 2** \r\n\r\n    PS C:\\Users\\ik\\Downloads&gt; aws ecr list-images --repository-name plat\r\n    {\r\n        &quot;imageIds&quot;: [\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:5fd06c0b6c6349324343232432429e8bf6b1ce62d810c2eef1eca&quot;,\r\n                &quot;imageTag&quot;: &quot;20230421.001&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:d7a28e9e62c5465465465469080eeae6a8308c99ec032a845119202f6d427ef8&quot;,\r\n                &quot;imageTag&quot;: &quot;33345.1&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:681ae17a52a4c673cc8c62d50823432432432432432432497789879c37a4&quot;,\r\n                &quot;imageTag&quot;: &quot;3445.2&quot;\r\n            },\r\n            {\r\n                &quot;imageDigest&quot;: &quot;sha256:ff7090d214ac72334323243209809809803e8af&quot;,\r\n                &quot;imageTag&quot;: &quot;33456.1&quot;\r\n            }\r\n    }\r\n    ]\r\n    }\r\n\r\n\r\nafter putting map equivalent\r\n\r\n\r\n    C:\\Users\\ik\\Downloads&gt;aws ecr list-images --repository-name plat   | jq &#39;.imageIds   | [.[]   | .imageTag]   | sort | .[]&#39;   | sort -r   | head -1\r\n    &#39;[.[]&#39; is not recognized as an internal or external command,\r\n    operable program or batch file.\r\n    PS C:\\Users\\ik\\Downloads&gt; ",
        "link": "https://stackoverflow.com/questions/76482895/how-to-list-image-tags-using-aws-cli-on-windows",
        "title": "how to list image tags using aws cli on windows"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "whitelist"
        ],
        "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": 1686950322,
                "post_id": 76493615,
                "comment_id": 134874199,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1686952306,
                "last_edit_date": 1686952306,
                "creation_date": 1686951329,
                "answer_id": 76493703,
                "question_id": 76493615,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could `walk` through the structure, and update all `objects` by using `with_entries` to temporarily convert them into an array of key-value pairs, and filter them for those entries with matching keys (i.e. `select` it if its `.key` is `IN` a given list of positives).\r\n```sh\r\nwalk(objects |= with_entries(select(IN(.key;\r\n  &quot;children&quot;, &quot;type&quot;, &quot;root&quot;, &quot;title&quot;, &quot;uri&quot;\r\n))))\r\n```\r\n[Demo](https://jqplay.org/s/6FjlfPw944T)\r\n\r\n&gt; Extra question : is it possible to combine this with depth filtering, e.g. only when depth&gt;3\r\n\r\nYou could apply the above to only those at your desired depth:\r\n```sh\r\n.[]?[]?[]? |= walk(…)\r\n```",
                "title": "Keep only given attributes names, at all levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1687033780,
        "creation_date": 1686950249,
        "last_edit_date": 1687033780,
        "question_id": 76493615,
        "body_markdown": "Using JSON format, for bookmarks in my case, it&#39;s nice to able to clean them and **retain only useful (a list of named) attributes** (these occur at all levels of the structure).\r\nAs output, the whole JSON hierarchy has to be preserved.\r\n\r\nCan that be done using the &quot;JQ&quot; tool?\r\n\r\nSo far, I have only been able to name attributes to be removed:\r\n\r\n```\r\njq -c &#39;del(..| .index?,.guid?,.id?,.dateAdded?,.lastModified?,.typeCode?,.iconUri?)&#39; in.json &gt;out.json\r\n```\r\n\r\nThe need is to **specify the attributes to be kept**, instead : e.g.  {children,type,root,title,uri}.\r\n\r\nCan one use the del() function and somehow &quot;negate&quot; this list, or use select() while recursing? I tried some combos but all failed.\r\n\r\nNote that the &quot;children&quot; attribute has a special role in this example, as it defines JSON subtrees, but I hope for a solution in which it is treated just as other attributes.\r\n\r\n(Extra question: is it possible to **combine this with depth filtering**, e.g. only when depth&gt;3?)\r\n\r\nSample input JSON :\r\n\r\n    {\r\n      &quot;guid&quot;: &quot;toolbar_____&quot;,\r\n      &quot;title&quot;: &quot;toolbar&quot;,\r\n      &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;guid&quot;: &quot;Y-lVXPFXlF15&quot;,\r\n          &quot;title&quot;: &quot;&quot;,\r\n          &quot;iconUri&quot;: &quot;https://fr.wikipedia.org/static/apple-touch/wikipedia.png&quot;,\r\n          &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n          &quot;uri&quot;: &quot;https://fr.wikipedia.org/&quot;\r\n        },\r\n        {\r\n          &quot;guid&quot;: &quot;S7ow_jYLOBlX&quot;,\r\n          &quot;title&quot;: &quot;tmp&quot;,\r\n          &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;guid&quot;: &quot;IFQ7EJXc-eNH&quot;,\r\n              &quot;title&quot;: &quot;Logiciel Attentes&quot;,\r\n              &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;guid&quot;: &quot;l-CtLEfkIatC&quot;,\r\n                  &quot;title&quot;: &quot;LMMS v122&quot;,\r\n                  &quot;iconUri&quot;: &quot;https://lmms.io/img/logo_sm.png&quot;,\r\n                  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n                  &quot;uri&quot;: &quot;https://lmms.io/download#collapse_linpre&quot;\r\n                },\r\n                {\r\n                  &quot;guid&quot;: &quot;a5HfcSy3k_sT&quot;,\r\n                  &quot;title&quot;: &quot;Slax UEFI apres v9.11&quot;,\r\n                  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n                  &quot;uri&quot;: &quot;https://www.slax.org/&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;guid&quot;: &quot;FUt5BsHdDl2Y&quot;,\r\n              &quot;title&quot;: &quot;Firewalls – MX Linux&quot;,\r\n              &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n              &quot;uri&quot;: &quot;https://mxlinux.org/wiki/networking/firewalls/&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nExpected output :\r\n\r\n    {\r\n      &quot;title&quot;: &quot;toolbar&quot;,\r\n      &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n      &quot;children&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;&quot;,\r\n          &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n          &quot;uri&quot;: &quot;https://fr.wikipedia.org/&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;tmp&quot;,\r\n          &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n          &quot;children&quot;: [\r\n            {\r\n              &quot;title&quot;: &quot;Logiciel Attentes&quot;,\r\n              &quot;type&quot;: &quot;text/x-moz-place-container&quot;,\r\n              &quot;children&quot;: [\r\n                {\r\n                  &quot;title&quot;: &quot;LMMS v122&quot;,\r\n                  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n                  &quot;uri&quot;: &quot;https://lmms.io/download#collapse_linpre&quot;\r\n                },\r\n                {\r\n                  &quot;title&quot;: &quot;Slax UEFI apres v9.11&quot;,\r\n                  &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n                  &quot;uri&quot;: &quot;https://www.slax.org/&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;title&quot;: &quot;Firewalls – MX Linux&quot;,\r\n              &quot;type&quot;: &quot;text/x-moz-place&quot;,\r\n              &quot;uri&quot;: &quot;https://mxlinux.org/wiki/networking/firewalls/&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76493615/keep-only-given-attributes-names-at-all-levels",
        "title": "Keep only given attributes names, at all levels"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "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": 1687169356,
                "post_id": 76505533,
                "comment_id": 134894479,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3849838,
                    "reputation": 41,
                    "user_id": 3190278,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/100000014377630/picture?type=large",
                    "display_name": "user3190278",
                    "link": "https://stackoverflow.com/users/3190278/user3190278"
                },
                "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": 1687169525,
                "post_id": 76505533,
                "comment_id": 134894512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3849838,
                    "reputation": 41,
                    "user_id": 3190278,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/100000014377630/picture?type=large",
                    "display_name": "user3190278",
                    "link": "https://stackoverflow.com/users/3190278/user3190278"
                },
                "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": 1687169572,
                "post_id": 76505533,
                "comment_id": 134894520,
                "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": 1687169694,
                "post_id": 76505533,
                "comment_id": 134894550,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1687177684,
                "creation_date": 1687177684,
                "answer_id": 76506633,
                "question_id": 76505533,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [`{}` Object Construction](https://jqlang.github.io/jq/manual/#ObjectConstruction:{}) filter to map the array elements to new objects. If key in the input and output are identical, you can use the shorthand form `{key}`, which is equivalent to `{key: .key}`.\r\n\r\nThe first_name of the nested object can be accessed with the [.foo Object Identifier-Index](https://jqlang.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar) filter:\r\n\r\n```\r\nmap({id, status, total, first_name: .billing.first_name})\r\n```",
                "title": "How to get a property from a array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1687177684,
        "creation_date": 1687168707,
        "question_id": 76505533,
        "body_markdown": "i want to convert a json File like this:\r\n\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 727,\r\n    &quot;parent_id&quot;: 0,\r\n    &quot;number&quot;: &quot;727&quot;,\r\n    &quot;order_key&quot;: &quot;wc_order_58d2d042d1d&quot;,\r\n    &quot;created_via&quot;: &quot;rest-api&quot;,\r\n    &quot;version&quot;: &quot;3.0.0&quot;,\r\n    &quot;status&quot;: &quot;processing&quot;,\r\n    &quot;currency&quot;: &quot;USD&quot;,\r\n    &quot;date_created&quot;: &quot;2017-03-22T16:28:02&quot;,\r\n    &quot;date_created_gmt&quot;: &quot;2017-03-22T19:28:02&quot;,\r\n    &quot;date_modified&quot;: &quot;2017-03-22T16:28:08&quot;,\r\n    &quot;date_modified_gmt&quot;: &quot;2017-03-22T19:28:08&quot;,\r\n    &quot;discount_total&quot;: &quot;0.00&quot;,\r\n    &quot;discount_tax&quot;: &quot;0.00&quot;,\r\n    &quot;shipping_total&quot;: &quot;10.00&quot;,\r\n    &quot;shipping_tax&quot;: &quot;0.00&quot;,\r\n    &quot;cart_tax&quot;: &quot;1.35&quot;,\r\n    &quot;total&quot;: &quot;29.35&quot;,\r\n    &quot;total_tax&quot;: &quot;1.35&quot;,\r\n    &quot;prices_include_tax&quot;: false,\r\n    &quot;customer_id&quot;: 0,\r\n    &quot;customer_ip_address&quot;: &quot;&quot;,\r\n    &quot;customer_user_agent&quot;: &quot;&quot;,\r\n    &quot;customer_note&quot;: &quot;&quot;,\r\n    &quot;billing&quot;: {\r\n      &quot;first_name&quot;: &quot;John&quot;,\r\n      &quot;last_name&quot;: &quot;Doe&quot;,\r\n      &quot;company&quot;: &quot;&quot;,\r\n```\r\n\r\nand i want just some properties like: id, satus, total and from billing first_name.\r\n\r\nHow do i geht the first name from billing array?\r\n\r\n\r\nthis does not work?\r\n-Thanks\r\n\r\n\r\n\r\ni tried this:\r\n\r\n\r\n```\r\njq -r map({id,number,date_created,status,.billing[].first_name}) | (first | keys_unsorted) as $keys | map([to_entries[] | .value]) as $rows | $keys,$rows[] | @csv\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76505533/how-to-get-a-property-from-a-array",
        "title": "How to get a property from a array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1687217571,
                "creation_date": 1687217571,
                "answer_id": 76510588,
                "question_id": 76510577,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq &#39;{ alpha, epsilon: { beta, delta }, gamma }&#39; input.json &gt; output.json```",
                "title": "jq: Move subset of fields under a new field"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1687218507,
                "creation_date": 1687218507,
                "answer_id": 76510625,
                "question_id": 76510577,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; define a subset of fields that I want to extract and move\r\n\r\nHere&#39;s a programmatic way:\r\n```\r\njq --argjson fields &#39;[&quot;beta&quot;, &quot;delta&quot;]&#39; &#39;\r\n def project($fields): . as $in | reduce $fields[] as $k ({}; .[$k] = $in[$k]);\r\n\r\n .epsilon = project($fields)\r\n | delpaths( [$fields[]| [.]] )\r\n &#39;\r\n```",
                "title": "jq: Move subset of fields under a new field"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1687233328,
        "creation_date": 1687217368,
        "last_edit_date": 1687233328,
        "question_id": 76510577,
        "body_markdown": "I have JSON data files that I&#39;d like to modify somewhat. From:\r\n\r\n```json\r\n{\r\n    &quot;alpha&quot;: &quot;...&quot;,\r\n    &quot;beta&quot;: [ ... ],\r\n    &quot;delta&quot;: { ... },\r\n    &quot;gamma&quot;: &quot;...&quot;\r\n}\r\n```\r\nto:\r\n```json\r\n{\r\n    &quot;alpha&quot;: &quot;...&quot;,\r\n    &quot;epsilon&quot; : {\r\n        &quot;beta&quot;: [ ... ],\r\n        &quot;delta&quot;: { ... }\r\n    },\r\n    &quot;gamma&quot;: &quot;...&quot;\r\n}\r\n```\r\n\r\nThis is, I want to define a subset of fields that I want to extract and move into a new sub-object with a specific name. How do I perform such a task with `jq`?",
        "link": "https://stackoverflow.com/questions/76510577/jq-move-subset-of-fields-under-a-new-field",
        "title": "jq: Move subset of fields under a new field"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1687360570,
                "creation_date": 1687360570,
                "answer_id": 76524830,
                "question_id": 76524798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nmap(select(.result==&quot;succeeded&quot;) | { id, date: .finishedDate, state, result }) | sort_by(.date)\r\n```\r\n\r\nGives the following:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1557,\r\n    &quot;date&quot;: &quot;2023-06-14T07:36:16.8346765Z&quot;,\r\n    &quot;state&quot;: &quot;completed&quot;,\r\n    &quot;result&quot;: &quot;succeeded&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1569,\r\n    &quot;date&quot;: &quot;2023-06-14T08:20:34.0988263Z&quot;,\r\n    &quot;state&quot;: &quot;completed&quot;,\r\n    &quot;result&quot;: &quot;succeeded&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1566,\r\n    &quot;date&quot;: &quot;2023-06-14T08:29:32.1229317Z&quot;,\r\n    &quot;state&quot;: &quot;completed&quot;,\r\n    &quot;result&quot;: &quot;succeeded&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1902,\r\n    &quot;date&quot;: &quot;2023-06-19T13:08:17.6903656Z&quot;,\r\n    &quot;state&quot;: &quot;completed&quot;,\r\n    &quot;result&quot;: &quot;succeeded&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n* `id: .id` can be shorten to just `id`\r\n* The `select()` needs to be inside the `map()`\r\n* `sort_by()` after the `select()` so we don&#39;t need to sort those we&#39;re removing\r\n\r\n----------\r\n\r\n\r\n#### [Online Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/5j3DnnGXe1i",
                "title": "Filtering json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1687360570,
        "creation_date": 1687360320,
        "question_id": 76524798,
        "body_markdown": "Within an Azure DevOps pipeline, running via a linux build agent, I&#39;m looking to use jq to take specific keys/values from a json file containing an array of data, sort the array by date and filter out unnecessary results based on one of the values.\r\n\r\nSo far I have the below which does a lot of this for me. test2.json is just a test example for now while I do a proof of concept. This will change to an API call.\r\n\r\n```\r\njq &#39;[.value[] | {id: .id, date: .finishedDate, state: .state, result: .result}] | sort_by(.finishedDate)&#39; $(Build.SourcesDirectory)/test2.json\r\n```\r\n\r\nThe above code works. It reduces the larger array in test2.json to just the fields for id, finishedDate, state and result. It also sorted the result by finishedDate which is what I need it to do. Below is an example of the json off the back of the above code. \r\n\r\n```\r\n[\r\n    {\r\n        &quot;id&quot;: 1902,\r\n        &quot;date&quot;: &quot;2023-06-19T13:08:17.6903656Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;succeeded&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1668,\r\n        &quot;date&quot;: &quot;2023-06-19T13:00:18.9255899Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1621,\r\n        &quot;date&quot;: &quot;2023-06-14T12:11:10.2714172Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1569,\r\n        &quot;date&quot;: &quot;2023-06-14T08:20:34.0988263Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;succeeded&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1566,\r\n        &quot;date&quot;: &quot;2023-06-14T08:29:32.1229317Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;succeeded&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1564,\r\n        &quot;date&quot;: &quot;2023-06-14T07:48:54.1384016Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1557,\r\n        &quot;date&quot;: &quot;2023-06-14T07:36:16.8346765Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;succeeded&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1555,\r\n        &quot;date&quot;: &quot;2023-06-14T07:24:19.5030833Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1553,\r\n        &quot;date&quot;: &quot;2023-06-14T07:11:50.4071939Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    },\r\n    {\r\n        &quot;id&quot;: 1551,\r\n        &quot;date&quot;: &quot;2023-06-14T06:58:34.3160857Z&quot;,\r\n        &quot;state&quot;: &quot;completed&quot;,\r\n        &quot;result&quot;: &quot;failed&quot;\r\n    }\r\n]\r\n```\r\nThe final part I need to do is select only entries where result = &quot;succeeded&quot;. I believe I need to add something like `select(.result=&quot;succeeded&quot;)` based on the documentation I read online however depending on where I add this into my jq query I either get an error e.g. no such file found or I get the same results as above with the select(.result=&quot;succeeded&quot;) having no impact (see below jq query).\r\n\r\n```\r\njq &#39;[.value[] | select(.result=&quot;succeeded&quot;) | {id: .id, date: .finishedDate, state: .state, result: .result}] | sort_by(.finishedDate)&#39; $(Build.SourcesDirectory)/test2.json\r\n```\r\n\r\nI&#39;m fairly new to using jq so I imagine I&#39;m missing something small to get this working and I&#39;m hoping someone can help.",
        "link": "https://stackoverflow.com/questions/76524798/filtering-json-using-jq",
        "title": "Filtering json using 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": 0,
                "creation_date": 1687378471,
                "post_id": 76526793,
                "comment_id": 134930138,
                "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": 1687378546,
                "post_id": 76526793,
                "comment_id": 134930151,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28821979,
                    "reputation": 37,
                    "user_id": 22074305,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c436ed9467f77412c3168de1c73a7be?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "z3plike",
                    "link": "https://stackoverflow.com/users/22074305/z3plike"
                },
                "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": 1687380840,
                "post_id": 76526793,
                "comment_id": 134930508,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28821979,
                    "reputation": 37,
                    "user_id": 22074305,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c436ed9467f77412c3168de1c73a7be?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "z3plike",
                    "link": "https://stackoverflow.com/users/22074305/z3plike"
                },
                "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": 1687380972,
                "post_id": 76526793,
                "comment_id": 134930524,
                "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": 1687381463,
                "post_id": 76526793,
                "comment_id": 134930605,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28821979,
                    "reputation": 37,
                    "user_id": 22074305,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6c436ed9467f77412c3168de1c73a7be?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "z3plike",
                    "link": "https://stackoverflow.com/users/22074305/z3plike"
                },
                "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": 1687381879,
                "post_id": 76526793,
                "comment_id": 134930664,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1687383270,
                "creation_date": 1687383270,
                "answer_id": 76527299,
                "question_id": 76526793,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`|=` can be used to replace an element with a new value without deleting prior parts of the tree. Thus, consider:\r\n\r\n```jq\r\n.vulnerabilities |= map(\r\n  if .CVEID? != null then\r\n    . + {MITRE_URL: &quot;\\($MITRE_URL)\\(.CVEID)&quot;,\r\n         NIST_URL:  &quot;\\($NIST_URL)\\(.CVEID)&quot;}\r\n  else . end\r\n)\r\n```",
                "title": "JQ and adding keys with other key values and string interpolation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1687383270,
        "creation_date": 1687378090,
        "question_id": 76526793,
        "body_markdown": "I am  using JQ with bash and looking to add a URL for a vulnerability output and I am building the string based on one of the JSON object keys. Been pretty stumped figuring out how to get this to work.\r\n\r\nSample of the data looks like this:\r\n\r\n```\r\n{\r\n  &quot;count&quot;: 2,\r\n  &quot;os&quot;: &quot;Debian GNU 11&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2023-29491&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;HIGH&quot;,\r\n      &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n      &quot;Description&quot;: &quot;ncurses before 6.4 20230408, when used by a setuid application, allows local users to trigger security-relevant memory corruption via malformed data in a terminfo database file that is found in $HOME/.terminfo or reached via the TERMINFO or TERM environment variable.\\n&quot;\r\n    },\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;HIGH&quot;,\r\n      &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n      &quot;Description&quot;: &quot;ncurses 6.3 before patch 20220416 has an out-of-bounds read and segmentation violation in convert_strings in tinfo/read_entry.c in the terminfo library.\\n&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nBasically what I am looking to do is have the data come out looking like this with a MITRE and NIST URL built based on the &quot;CVEID&quot; value:\r\n\r\n```\r\n{\r\n  &quot;count&quot;: 2,\r\n  &quot;os&quot;: &quot;Debian GNU 11&quot;,\r\n  &quot;vulnerabilities&quot;: [\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2023-29491&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;HIGH&quot;,\r\n      &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n      &quot;Description&quot;: &quot;ncurses before 6.4 20230408, when used by a setuid application, allows local users to trigger security-relevant memory corruption via malformed data in a terminfo database file that is found in $HOME/.terminfo or reached via the TERMINFO or TERM environment variable.\\n&quot;\r\n      &quot;MITRE_URL&quot;: &quot;https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-29491&quot;,\r\n      &quot;NIST_URL&quot;: &quot;https://nvd.nist.gov/vuln/detail/CVE-2023-29491&quot;\r\n    },\r\n    {\r\n      &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n      &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n      &quot;Severity&quot;: &quot;HIGH&quot;,\r\n      &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n      &quot;Description&quot;: &quot;ncurses 6.3 before patch 20220416 has an out-of-bounds read and segmentation violation in convert_strings in tinfo/read_entry.c in the terminfo library.\\n&quot;\r\n      &quot;MITRE_URL&quot;: &quot;https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-29458&quot;,\r\n      &quot;NIST_URL&quot;: &quot;https://nvd.nist.gov/vuln/detail/CVE-2022-29458&quot; \r\n   }\r\n  ]\r\n}\r\n```\r\n\r\nDoing something like this does work, but it extracts the objects from .vulnerabilities[] so I cannot pipe them to TSV for my final output: \r\n\r\n```\r\njq -r \\\r\n  --arg MITRE_URL &quot;https://cve.mitre.org/cgi-bin/cvename.cgi?name=&quot; \\\r\n  --arg NIST_URL &quot;https://nvd.nist.gov/vuln/detail/&quot; \\\r\n  &#39;.vulnerabilities[] | select(.CVEID) += {MITRE_URL: &quot;\\($MITRE_URL)\\(.CVEID)&quot;, NIST_URL: &quot;\\($NIST_URL)\\(.CVEID)&quot;}&#39; &lt;&lt;&lt;&quot;$ASSESSMENT_RESULTS&quot;\r\n```\r\n\r\nOutput of above ^ :  \r\n\r\n```\r\n{\r\n  &quot;CVEID&quot;: &quot;CVE-2023-29491&quot;,\r\n  &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n  &quot;Severity&quot;: &quot;HIGH&quot;,\r\n  &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n  &quot;Description&quot;: &quot;ncurses before 6.4 20230408, when used by a setuid application, allows local users to trigger security-relevant memory corruption via malformed data in a terminfo database file that is found in $HOME/.terminfo or reached via the TERMINFO or TERM environment variable.\\n&quot;,\r\n  &quot;MITRE_URL&quot;: &quot;https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-29491&quot;,\r\n  &quot;NIST_URL&quot;: &quot;https://nvd.nist.gov/vuln/detail/CVE-2023-29491&quot;\r\n}\r\n{\r\n  &quot;CVEID&quot;: &quot;CVE-2022-29458&quot;,\r\n  &quot;Product&quot;: &quot;ncurses-base&quot;,\r\n  &quot;Severity&quot;: &quot;HIGH&quot;,\r\n  &quot;Version&quot;: &quot;6.2+20201114-2+deb11u1&quot;,\r\n  &quot;Description&quot;: &quot;ncurses 6.3 before patch 20220416 has an out-of-bounds read and segmentation violation in convert_strings in tinfo/read_entry.c in the terminfo library.\\n&quot;,\r\n  &quot;MITRE_URL&quot;: &quot;https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-29458&quot;,\r\n  &quot;NIST_URL&quot;: &quot;https://nvd.nist.gov/vuln/detail/CVE-2022-29458&quot;\r\n}\r\n```\r\n\r\nThank you!\r\n",
        "link": "https://stackoverflow.com/questions/76526793/jq-and-adding-keys-with-other-key-values-and-string-interpolation",
        "title": "JQ and adding keys with other key values and string interpolation"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 118083,
                    "reputation": 11830,
                    "user_id": 308851,
                    "user_type": "registered",
                    "accept_rate": 82,
                    "profile_image": "https://i.sstatic.net/lWWID.jpg?s=256",
                    "display_name": "chx",
                    "link": "https://stackoverflow.com/users/308851/chx"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1687463918,
                "post_id": 76535204,
                "comment_id": 134944408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1687464067,
                "creation_date": 1687464067,
                "answer_id": 76535273,
                "question_id": 76535204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works, but it&#39;s pretty messy\r\n```sh\r\njq &#39;\r\n  (.columns | map({(.id | tostring): .title}) | add) as $columnTitles\r\n  | .rows | map(\r\n      .cells | map({($columnTitles[.columnId | tostring]): .value}) | add\r\n    )\r\n&#39; file.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;column 1&quot;: &quot;foo&quot;,\r\n    &quot;column 2&quot;: &quot;bar&quot;\r\n  },\r\n  {\r\n    &quot;column 1&quot;: &quot;foo1&quot;,\r\n    &quot;column 2&quot;: &quot;bar1&quot;\r\n  }\r\n]\r\n```",
                "title": "Reformatting tabular data with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1687519343,
                "last_edit_date": 1687519343,
                "creation_date": 1687471060,
                "answer_id": 76535899,
                "question_id": 76535204,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a way that uses [`INDEX`](https://jqlang.github.io/jq/manual/#SQL-StyleOperators) and `JOIN` to perform the matching, one [`add`](https://jqlang.github.io/jq/manual/#add) to combine both sides of the match, and another `add` to create the final object (along with two other variants that each omit and compensate for an `add`).\r\n\r\n```sh\r\nINDEX(.columns[]; .id) as $map | .rows | map(\r\n  [JOIN($map; .cells[]; &quot;\\(.columnId)&quot;; add | {(.title): .value})] | add\r\n# [JOIN($map; .cells[]; &quot;\\(.columnId)&quot;; {(last.title): first.value})] | add\r\n# [JOIN($map; .cells[]; &quot;\\(.columnId)&quot;; add | .key = .title)] | from_entries\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/WXCzHq9HMg2)\r\n[Demo](https://jqplay.org/s/YKfZBSicr8s)\r\n[Demo](https://jqplay.org/s/_7OsqURS_PM)\r\n\r\n---\r\nAnd here&#39;s one that combines using `INDEX` with @Glenn&#39;s [shorter approach](https://stackoverflow.com/a/76535273/2158479) to `map` the `.cells` array using [string interpolation](https://jqlang.github.io/jq/manual/#Stringinterpolation%3A%5C%28exp%29) to look up the column id in the map:\r\n```sh\r\nINDEX(.columns[]; .id) as $map | .rows | map(\r\n  .cells | map({($map.&quot;\\(.columnId)&quot;.title): .value}) | add\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/qabXFY2NqDE)\r\n",
                "title": "Reformatting tabular data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1687519343,
        "creation_date": 1687463264,
        "last_edit_date": 1687490172,
        "question_id": 76535204,
        "body_markdown": "I have some JSON with structure like\r\n\r\n\r\n```\r\n{\r\n  &quot;columns&quot;: [\r\n    {\r\n      &quot;id&quot;: 123,\r\n      &quot;title&quot;: &quot;column 1&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: 456,\r\n      &quot;title&quot;: &quot;column 2&quot;\r\n    }\r\n  ],\r\n  &quot;rows&quot;: [\r\n    {\r\n      &quot;cells&quot;: [\r\n        {\r\n          &quot;columnId&quot;: 123,\r\n          &quot;value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;columnId&quot;: 456,\r\n          &quot;value&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;cells&quot;: [\r\n        {\r\n          &quot;columnId&quot;: 123,\r\n          &quot;value&quot;: &quot;foo1&quot;\r\n        },\r\n        {\r\n          &quot;columnId&quot;: 456,\r\n          &quot;value&quot;: &quot;bar1&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n```\r\n\r\nEach row has a cell for every column and columnId matches id in columns.\r\n\r\nHow could I get a list of objects looking like:\r\n\r\n```\r\n[\r\n{\r\n  &#39;column 1&#39;: &#39;foo&#39;,\r\n  &#39;column 2&#39;: &#39;bar&#39;\r\n},\r\n{\r\n  &#39;column 1&#39;: &#39;foo1&#39;,\r\n  &#39;column 2&#39;: &#39;bar1&#39;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76535204/reformatting-tabular-data-with-jq",
        "title": "Reformatting tabular data with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1687474155,
                "post_id": 76536090,
                "comment_id": 134945939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11603655,
                    "reputation": 544,
                    "user_id": 8500058,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QcycB.jpg?s=256",
                    "display_name": "Ashish Kumar",
                    "link": "https://stackoverflow.com/users/8500058/ashish-kumar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1687474626,
                "post_id": 76536090,
                "comment_id": 134945981,
                "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": 1687497591,
                "post_id": 76536090,
                "comment_id": 134947886,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1687475379,
                "last_edit_date": 1687475379,
                "creation_date": 1687474256,
                "answer_id": 76536128,
                "question_id": 76536090,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to use `paths` to traverse the document, and `getpath` to retrieve the value at that path:\r\n```sh\r\njq -r &#39;\r\n  paths(strings) as $path\r\n  | &quot;\\($path | map(ascii_upcase) | join(&quot;_&quot;))=\\(getpath($path) | @json)&quot;\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/xaHwNrW5wg8)\r\n\r\nAnother way would be using `.key` and `.value` from the items provided by `to_entries`, employed twice thus going down exactly two levels:\r\n```sh\r\njq -r &#39;\r\n  to_entries[] | &quot;\\(.key | ascii_upcase)_\\(.value\r\n    | to_entries[] | &quot;\\(.key | ascii_upcase)=\\(.value | @json)&quot;\r\n  )&quot;\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/MeR51zlq7sn)\r\n\r\nOutput (depending on its purpose, you might want to change `@json` to `@sh`):\r\n```\r\nES_HOST=&quot;https://es-host.ap-south-1.es.amazonaws.com&quot;\r\nES_USER=&quot;es_admin&quot;\r\nES_PASS=&quot;pa$$w0rd&quot;\r\nDB_HOST=&quot;https://db-host.ap-south-1.es.amazonaws.com&quot;\r\nDB_USER=&quot;db_admin&quot;\r\nDB_PASS=&quot;pa$$w0rd&quot;\r\n```\r\n",
                "title": "jq: Convert json to text"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1687475379,
        "creation_date": 1687473730,
        "last_edit_date": 1687474757,
        "question_id": 76536090,
        "body_markdown": "Below is the json content, need to create new key using `jq` via merging outer key with inner key and setting their value same as inner key value.\r\n```\r\n{\r\n  &quot;es&quot;: {\r\n    &quot;host&quot;: &quot;https://es-host.ap-south-1.es.amazonaws.com&quot;,\r\n    &quot;user&quot;: &quot;es_admin&quot;,\r\n    &quot;pass&quot;: &quot;pa$$w0rd&quot;\r\n  },\r\n  &quot;db&quot;: {\r\n    &quot;host&quot;: &quot;https://db-host.ap-south-1.es.amazonaws.com&quot;,\r\n    &quot;user&quot;: &quot;db_admin&quot;,\r\n    &quot;pass&quot;: &quot;pa$$w0rd&quot;\r\n  }   \r\n}\r\n```\r\n \r\nExpected output:\r\n```\r\nES_HOST=&quot;https://es-host.ap-south-1.es.amazonaws.com&quot;\r\nES_USER=&quot;es_admin&quot;\r\nES_PASS=&quot;pa$$w0rd&quot;\r\n\r\nDB_HOST=&quot;https://db-host.ap-south-1.es.amazonaws.com&quot;\r\nDB_USER=&quot;db_admin&quot;\r\nDB_PASS=&quot;pa$$w0rd&quot;\r\n```\r\n\r\nTried couple of combination with jq but unable to do needful. Thanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/76536090/jq-convert-json-to-text",
        "title": "jq: Convert json to text"
    },
    {
        "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": 1687516977,
                "post_id": 76539139,
                "comment_id": 134951319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2824172,
                    "reputation": 191,
                    "user_id": 2427137,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6ffc86cc82cda497394b338c0809db67?s=256&d=identicon&r=PG",
                    "display_name": "Daniel Resnick",
                    "link": "https://stackoverflow.com/users/2427137/daniel-resnick"
                },
                "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": 1687644228,
                "post_id": 76539139,
                "comment_id": 134966218,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1687515948,
                "creation_date": 1687515948,
                "answer_id": 76539220,
                "question_id": 76539139,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would the following work for you?\r\n\r\n```\r\n{ id }\r\n+ (\r\n    [.details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;) | .rows[] | {key, value:.val}]\r\n    | from_entries\r\n    | {\r\n        label1,\r\n        label2,\r\n        label3,\r\n        label4\r\n    }\r\n)\r\n```\r\n\r\nor equivalently:\r\n\r\n```\r\n.id as $id\r\n| [.details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;) | .rows[] | {key, value:.val}]\r\n| from_entries\r\n| {\r\n    $id,\r\n    label1,\r\n    label2,\r\n    label3,\r\n    label4\r\n}\r\n```\r\n\r\nOutput (after fixing &quot;deatils&quot; to &quot;details&quot;):\r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: &quot;abc&quot;,\r\n  &quot;label4&quot;: &quot;def&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;label1&quot;: &quot;foo&quot;,\r\n  &quot;label2&quot;: &quot;bar&quot;,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n```",
                "title": "Querying nested key-value pairs in jq without row-filtering"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1687738674,
                "last_edit_date": 1687738674,
                "creation_date": 1687518457,
                "answer_id": 76539509,
                "question_id": 76539139,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an approach which is dynamic wrt the set of labels. It first collects all labels across all objects (using `--slurp`) to prepare a &quot;base object&quot; with all labels preset to `null`. That way `label3` and `label4` will also be present in the second object, even though they&#39;re missing there in the input. This also assumes that in case of name clashes later occurrences should &quot;overwrite&quot; previous ones (as seen with the first occurrences of `label1` and `label2` in the second object). Then, the objects can be built up successively, filtering by the value of `.headerText`, and using that prepared base object (and `{id}`) as initial state.\r\n\r\n```sh\r\njq -s &#39;\r\n  (map(.details[].rows[]) | from_entries) as $labels | .[] | reduce (\r\n    .details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;).rows[]\r\n  ) as {$key, $val} ({id} + $labels; .[$key] = $val)\r\n&#39; input.json\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: &quot;abc&quot;,\r\n  &quot;label4&quot;: &quot;def&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;label1&quot;: &quot;foo&quot;,\r\n  &quot;label2&quot;: &quot;bar&quot;,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/olZybUZ-SVI)\r\n\r\n---\r\n\r\n**Edit:** With the updated input sample, `label5` will now be included in all of the objects, since this approach &quot;first collects all labels&quot; into a &quot;base object&quot;. Here&#39;s the updated output:\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: &quot;abc&quot;,\r\n  &quot;label4&quot;: &quot;def&quot;,\r\n  &quot;label5&quot;: &quot;qwe&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;label1&quot;: &quot;foo&quot;,\r\n  &quot;label2&quot;: &quot;bar&quot;,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null,\r\n  &quot;label5&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;789&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null,\r\n  &quot;label5&quot;: null\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/slD71m4v2gn)\r\n\r\n&gt;  I don&#39;t care about all KV pairs. So KV agnostic solutions are less ideal\r\n\r\nThen, how about statically predefining your preferred set of labels (either statically as part of the code, or on call using the `--args` option), which is then used to accordingly generate the &quot;base object&quot;, and to ignore all other keys from the input in a second filter. With this approach, the input also no longer needs to be &quot;slurped&quot;.\r\n\r\n```sh\r\n# statically as part the code\r\njq &#39;\r\n  [&quot;label1&quot;, &quot;label2&quot;, &quot;label3&quot;, &quot;label4&quot;] as $labels | reduce (\r\n    .details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;)\r\n    | .rows[] | select(IN(.key; $labels[]))\r\n  ) as {$key, $val} ({id} | .[$labels[]] = null; .[$key] = $val)\r\n&#39; input.json\r\n\r\n# on call using the `--args` option\r\njq &#39;\r\n  reduce (\r\n    .details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;)\r\n    | .rows[] | select(IN(.key; $ARGS.positional[]))\r\n  ) as {$key, $val} ({id} | .[$ARGS.positional[]] = null; .[$key] = $val)\r\n&#39; input.json --args label1 label2 label3 label4\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: &quot;abc&quot;,\r\n  &quot;label4&quot;: &quot;def&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;label1&quot;: &quot;foo&quot;,\r\n  &quot;label2&quot;: &quot;bar&quot;,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;789&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/ZZ8w5Db55Hl) (static version)",
                "title": "Querying nested key-value pairs in jq without row-filtering"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1687520790,
                "creation_date": 1687520790,
                "answer_id": 76539801,
                "question_id": 76539139,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might also be interested in a [`reduce`](https://jqlang.github.io/jq/manual/#Reduce)-based solution:\r\n\r\n```\r\nreduce (.details[] | select(.headerText == &quot;only_look_at_kvs_here&quot;))\r\nas $details (\r\n    {id, label1:null, label2:null, label3:null, label4:null};\r\n    . + ($details.rows | map({key, value:.val}) | from_entries)\r\n)\r\n```",
                "title": "Querying nested key-value pairs in jq without row-filtering"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1687738674,
        "creation_date": 1687515310,
        "last_edit_date": 1687644085,
        "question_id": 76539139,
        "body_markdown": "I&#39;m trying to query some JSON that requires unpacking key-value pairs into top-level fields in the output. However it&#39;s common for key-values to only appear in some rows in the input, in which case I want to fallback to null. Example (simplified) input:\r\n\r\n```lang-json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;headerText&quot;: &quot;ignore_me&quot;,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;label1&quot;,\r\n          &quot;val&quot;: &quot;sdhf&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label2&quot;,\r\n          &quot;val&quot;: &quot;fdgg&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;headerText&quot;: &quot;only_look_at_kvs_here&quot;,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;label3&quot;,\r\n          &quot;val&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label4&quot;,\r\n          &quot;val&quot;: &quot;def&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label5&quot;,\r\n          &quot;val&quot;: &quot;qwe&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;headerText&quot;: &quot;ignore_me&quot;,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;label1&quot;,\r\n          &quot;val&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label2&quot;,\r\n          &quot;val&quot;: &quot;def&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;headerText&quot;: &quot;only_look_at_kvs_here&quot;,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;label1&quot;,\r\n          &quot;val&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label2&quot;,\r\n          &quot;val&quot;: &quot;bar&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;id&quot;: &quot;789&quot;,\r\n  &quot;details&quot;: [\r\n    {\r\n      &quot;headerText&quot;: &quot;ignore_me&quot;,\r\n      &quot;rows&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;label1&quot;,\r\n          &quot;val&quot;: &quot;abc&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;label2&quot;,\r\n          &quot;val&quot;: &quot;def&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd expected output:\r\n\r\n```lang-json\r\n{\r\n  &quot;id&quot;: &quot;123&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: &quot;abc&quot;,\r\n  &quot;label4&quot;: &quot;def&quot;\r\n}\r\n{\r\n  &quot;id&quot;: &quot;345&quot;,\r\n  &quot;label1&quot;: &quot;foo&quot;,\r\n  &quot;label2&quot;: &quot;bar&quot;,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n{\r\n  &quot;id&quot;: &quot;789&quot;,\r\n  &quot;label1&quot;: null,\r\n  &quot;label2&quot;: null,\r\n  &quot;label3&quot;: null,\r\n  &quot;label4&quot;: null\r\n}\r\n```\r\n\r\nI&#39;ve tried a variety of patterns but I keep getting tripped up on jq&#39;s filtering behaviour when trying to select(...) the appropriate items in the nested arrays. My latest attempt:\r\n\r\n```lang-bash\r\njq &#39;{id, &quot;label1&quot;: (.details[] | select(.headerText==&quot;only_look_at_kvs_here&quot;) | .rows[] | select(.key==&quot;label1&quot;) | .val) }&#39;\r\n```\r\n\r\nAny pointers on how best to achieve this?",
        "link": "https://stackoverflow.com/questions/76539139/querying-nested-key-value-pairs-in-jq-without-row-filtering",
        "title": "Querying nested key-value pairs in jq without row-filtering"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1687859902,
                "creation_date": 1687859902,
                "answer_id": 76563707,
                "question_id": 76563529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use `transpose` with `reduce`:\r\n```\r\n[ .counts, .values ] | transpose | reduce .[] as $t ({}; .[$t[1]] = $t[0])\r\n```\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;5&quot;: 17,\r\n  &quot;10&quot;: 1014,\r\n  &quot;15&quot;: 22,\r\n  &quot;20&quot;: 9,\r\n  &quot;25&quot;: 11\r\n}\r\n```\r\n\r\n#### [Online Demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/PCKTPp9C5_V",
                "title": "Transfer two array content values of same count into key value pair"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1687872291,
                "last_edit_date": 1687872291,
                "creation_date": 1687871968,
                "answer_id": 76565321,
                "question_id": 76563529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two `transpose`-free solutions:\r\n```sh\r\n[(.counts | keys[]) as $i | {(.values[$i]): .counts[$i]}] | add\r\n```\r\n[Demo](https://jqplay.org/s/BvYM4HL07HA)\r\n\r\n```sh\r\n. as {$values} | .counts | with_entries(.key |= $values[.])\r\n```\r\n[Demo](https://jqplay.org/s/M_dZutsBnJR)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;5&quot;: 17,\r\n  &quot;10&quot;: 1014,\r\n  &quot;15&quot;: 22,\r\n  &quot;20&quot;: 9,\r\n  &quot;25&quot;: 11\r\n}\r\n```",
                "title": "Transfer two array content values of same count into key value pair"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695481523,
                "last_edit_date": 1695481523,
                "creation_date": 1690128912,
                "answer_id": 76749222,
                "question_id": 76563529,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Based on @pmf&#39;s answer here is a slight improvement:\r\n\r\n```\r\n. as $in\r\n| reduce (.values|keys[]) as $i (\r\n    {};\r\n    .[$in.values[$i]] = $in.counts[$i]\r\n)\r\n```\r\n\r\nIt avoids some intermediate objects either hidden in `with_entries` or plain \r\nvisible before the `add` and goes directly to `reduce` which is also used both by `with_entries` and `add`.\r\n",
                "title": "Transfer two array content values of same count into key value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1695481523,
        "creation_date": 1687858678,
        "last_edit_date": 1687915678,
        "question_id": 76563529,
        "body_markdown": "I have a question.\r\nLet&#39;s assume I had a json doc like this:\r\n```\r\n{\r\n  &quot;counts&quot;: [\r\n    17,\r\n    1014,\r\n    22,\r\n    9,\r\n    11\r\n  ],\r\n  &quot;values&quot;: [\r\n    &quot;5&quot;,\r\n    &quot;10&quot;,\r\n    &quot;15&quot;,\r\n    &quot;20&quot;,\r\n    &quot;25&quot;\r\n  ]\r\n}\r\n```\r\nand I wanted to get a result like this:\r\n```\r\n{\r\n    &quot;5&quot;:17,\r\n    &quot;10&quot;:1014,\r\n    &quot;15&quot;:22,\r\n    &quot;20&quot;:9,\r\n    &quot;25&quot;:11\r\n}\r\n```\r\nbasically the array elements assigned as key value pairs one after the other. How can I achieve that?\r\n\r\nI tried jq `with_entries(.values = .counts)` and `with_entries(.values[] = .counts[])` but it didn&#39;t work.",
        "link": "https://stackoverflow.com/questions/76563529/transfer-two-array-content-values-of-same-count-into-key-value-pair",
        "title": "Transfer two array content values of same count into key value pair"
    },
    {
        "tags": [
            "linux",
            "bash",
            "x86-64",
            "jq"
        ],
        "comments": [
            {
                "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": 1687876239,
                "post_id": 76565692,
                "comment_id": 134996344,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1687876245,
                "creation_date": 1687876245,
                "answer_id": 76565930,
                "question_id": 76565692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a space in the value of `$b`. Thus, when expanded you end up with two arguments to jq, one being `.[]|select(.c == &quot;d` and the other one being `c&quot;)`.\r\n\r\nIf you wanted to properly inject the variable with whitespace, quote the shell variable(s):\r\n```\r\necho &quot;$a&quot; | jq &#39;.[]|select(.c == &quot;&#39;&quot;$b&quot;&#39;&quot;)&#39;\r\n```\r\n\r\nBetter yet, don&#39;t inject data into code, use the idiomatic way to import strings into jq with the dedicated `--arg` option:\r\n```sh\r\necho &quot;$a&quot; | jq --arg b &quot;$b&quot;  &#39;.[]|select(.c == $b)&#39;\r\n```",
                "title": "linux 64bit jq did not support the variable with blank space expansion in select function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1687876245,
        "creation_date": 1687874651,
        "question_id": 76565692,
        "body_markdown": "# Example OK in macos:\r\n## jq Version\r\n```\r\njq-1.6\r\n```\r\n## Code\r\n\r\n```\r\na=&#39;[{&quot;a&quot;:&quot;b&quot;},{&quot;c&quot;:&quot;d c&quot;}]&#39;\r\nb=&quot;d c&quot;\r\necho $a|jq &#39;.[]|select(.c == &quot;&#39;$b&#39;&quot;)&#39;\r\n```\r\n## Output\r\n```\r\n{\r\n  &quot;c&quot;: &quot;d c&quot;\r\n}\r\n```\r\n\r\n# Example KO in linux:\r\n## jq Version\r\n```\r\njq-1.5-1-a5b5cbe\r\n```\r\n## Code\r\n```\r\na=&#39;[{&quot;a&quot;:&quot;b&quot;},{&quot;c&quot;:&quot;d c&quot;}]&#39;\r\nb=&quot;d c&quot;\r\necho $a|jq &#39;.[]|select(.c == &quot;&#39;$b&#39;&quot;)&#39;\r\n```\r\n## Output\r\n```\r\njq: error: syntax error, unexpected $end, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.[]|select(.c == &quot;d\r\njq: 1 compile error\r\n```\r\n\r\nAs above, there is a difference about blank space expand in select function of jq between linux env and macos env. I had already tried to download jq-1.6 in linux env, but it also produced the issue like above example KO in linux. Is there a bug still exist in jq of linux version? And can anybody come in another pretty good way to achieve above functionality? I am using jq in shell to parse the database information getting specify content...\r\nThanks in advance!\r\n",
        "link": "https://stackoverflow.com/questions/76565692/linux-64bit-jq-did-not-support-the-variable-with-blank-space-expansion-in-select",
        "title": "linux 64bit jq did not support the variable with blank space expansion in select function"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1687933162,
                "post_id": 76570156,
                "comment_id": 135004419,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1843462,
                    "reputation": 117,
                    "user_id": 1672382,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6f1769c20be39298e980657809ffd24b?s=256&d=identicon&r=PG",
                    "display_name": "kaushal47",
                    "link": "https://stackoverflow.com/users/1672382/kaushal47"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1687935720,
                "post_id": 76570156,
                "comment_id": 135004833,
                "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": 1687935906,
                "post_id": 76570156,
                "comment_id": 135004861,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1688024934,
                "last_edit_date": 1688024934,
                "creation_date": 1687947806,
                "answer_id": 76572254,
                "question_id": 76570156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your regex isn’t quite right. Also, it might be worthwhile using `map` to make things more straightforward:\r\n\r\n    map(if (.node|test(&quot;^10[.]13[.]&quot;)) then .state=&quot;disabled&quot; else . end)\r\n\r\nOr you could simply use `startswith`.\r\n\r\n-------\r\nIn response to the follow-up question:\r\n\r\nIf your array lives at `_` in `{&quot;properties&quot;: { &quot;basic&quot;: {&quot;nodes_table&quot;: _}}}`, you&#39;d write:\r\n\r\n    .properties.basic.nodes_table |= map(....)\r\n\r\n\r\n",
                "title": "How to change multiple values in a json using jq by selecting them by key and getting whole json output"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1687957051,
                "creation_date": 1687957051,
                "answer_id": 76573423,
                "question_id": 76570156,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only want to modify array elements whose IP address starts with &quot;10.13.&quot;, you&#39;d usually use `map` and combine with `startswith` (for prefix-matching the IP address):\r\n\r\n```\r\njq &#39;map(select(.node|startswith(&quot;10.13.&quot;)).state = &quot;disabled&quot;)&#39; input.json\r\n```\r\n\r\nAn equivalent solution assigning multiple values at once:\r\n\r\n```\r\njq &#39;(.[]|select(.node|startswith(&quot;10.13&quot;)).state) = &quot;disabled&quot;&#39; input.json\r\n```\r\n\r\nNote that the second solution is almost identical to your proposed one (with slight modifications: different grouping, `startswith`, and the plain assignment operator)",
                "title": "How to change multiple values in a json using jq by selecting them by key and getting whole json output"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1688024934,
        "creation_date": 1687928195,
        "last_edit_date": 1687935612,
        "question_id": 76570156,
        "body_markdown": "I have following data.json to be modified , I want to change the state to &quot;disabled&quot; based on the filtered IP address range(eg &quot;10.13*&quot;. I tried following command and I need to get whole json content as the out put, but i&#39;m getting a syntax errors for this(I have used same for updating a single value(without using character mapping), it worked fine. (Plan is to use this in shell command and redirect the out put to a new file). Can someone help me on this\r\n\r\n```\r\njq &#39;(.[]| select(.node|test(&quot;^10.13*&quot;))).state |=&quot;disabled&quot; data.json\r\n```\r\n\r\n\r\n```\r\n[\r\n\t{\r\n\t\t&quot;node&quot;:&quot;10.13.248.254:61052&quot;,\r\n\t\t&quot;state&quot;: &quot;active&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;node&quot;:&quot;10.13.248.255:61052&quot;,\r\n\t\t&quot;state&quot;: &quot;active&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;node&quot;:&quot;10.54.247.228:61052&quot;,\r\n\t\t&quot;state&quot;: &quot;active&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;node&quot;:&quot;10.54.247.229:61052&quot;,\r\n\t\t&quot;state&quot;: &quot;active&quot;\r\n\t}\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76570156/how-to-change-multiple-values-in-a-json-using-jq-by-selecting-them-by-key-and-ge",
        "title": "How to change multiple values in a json using jq by selecting them by key and getting whole json output"
    },
    {
        "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": 1,
                "creation_date": 1688033723,
                "post_id": 76580033,
                "comment_id": 135020772,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1688033913,
                "last_edit_date": 1688033913,
                "creation_date": 1688033501,
                "answer_id": 76580080,
                "question_id": 76580033,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since not all objects have the `username` field, you&#39;ll need to use the [Optional Object Identifier-Index](https://jqlang.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?) (`?`) as `.username?` to catch those missing ones:\r\n\r\n```\r\njq -r --arg user &quot;PRODUCTION_1&quot; \\\r\n  &#39;.[] | select(.username? == $user).password_clear&#39; file.json\r\n```\r\n\r\nOutput:\r\n```none\r\n7bla1234\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nRegarding your attempt, you were using `.value`, but that&#39;s not needed since [`.[]`][1] can loop over objects just fine.\r\n\r\nThe `.value` could come from [`to_entries`][2], to convert the object to key/value pair, but again, using `.[]` is a lot easier.\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#Array/ObjectValueIterator:.[]\r\n  [2]: https://jqlang.github.io/jq/manual/#to_entries,from_entries,with_entries(f)",
                "title": "jq : extract value where other value matches pattern"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1688034093,
        "creation_date": 1688033116,
        "question_id": 76580033,
        "body_markdown": "I have the following json : \r\n```\r\n{\r\n  &quot;id&quot;: &quot;jboss_data1&quot;,\r\n  &quot;DS1&quot;: {\r\n    &quot;policy_name&quot;: &quot;CAT_LOCATION&quot;,\r\n    &quot;username&quot;: &quot;PRODUCTION_1&quot;,\r\n    &quot;password_clear&quot;: &quot;7bla1234&quot;,\r\n  },\r\n  &quot;DS3&quot;: {\r\n    &quot;policy_name&quot;: &quot;CAT_SRC&quot;,\r\n    &quot;username&quot;: &quot;PRODUCTION_2&quot;,\r\n    &quot;password_clear&quot;: &quot;foo7864&quot;,\r\n  },\r\n  &quot;DS4&quot;: {\r\n    &quot;policy_name&quot;: &quot;CAT_FOLDER&quot;,\r\n    &quot;username&quot;: &quot;PRODUCTION_3&quot;,\r\n    &quot;password_clear&quot;: &quot;123bar456&quot;,\r\n  }\r\n}\r\n```\r\nIn bash, I&#39;m trying to extract the `password_clear` value when the `username` matches my variable.\r\n\r\nI&#39;ve tried something like \r\n```\r\njq -r --arg user &quot;${user_picked}&quot; &#39;.[]|select(.value.username==&quot;$user&quot;).password_clear&#39; file.json\r\n```\r\n(I&#39;ve also tried a lot of different other combinations, but without success...)\r\n\r\nCould you please guide me to the correct syntax for this request ?\r\n\r\nRegards",
        "link": "https://stackoverflow.com/questions/76580033/jq-extract-value-where-other-value-matches-pattern",
        "title": "jq : extract value where other value matches pattern"
    },
    {
        "tags": [
            "gitlab",
            "gitlab-ci",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1688073839,
                "creation_date": 1688073839,
                "answer_id": 76584683,
                "question_id": 76583083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For using a bash-variable in jq&#39;s filter you need to bind the variable as argument e.g. `--arg name $variable` or `--argjson name JSON-text` ([jq manual][1])\r\n\r\nIn your case you could write following.\r\n\r\n```bash\r\njq -r --arg TEMP_TAG &quot;$TAG&quot; &#39;.version |= &quot;${TEMP_TAG}&quot;&#39; temp.json &gt; package.json\r\n```\r\n\r\nfuther question and possible duplicate question:\r\nhttps://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#Invokingjq",
                "title": "Gilab-ci pipeline not resolving variables not resolved when there is a double quotes inside single quote"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1688416528,
        "creation_date": 1688057310,
        "last_edit_date": 1688416528,
        "question_id": 76583083,
        "body_markdown": "I&#39;m trying to change a version of package.json with git TAG generated using `jq`. For that I need to use double quotes inside a single quote passing a gitlab variable as parameter.\r\nThe command is `jq -r &#39;.version |= &quot;${TAG}&quot;&#39; temp.json &gt; package.json` but the ${TAG} or $TAG is not resolving to its value.\r\n\r\n```\r\nbuild-cloudfront:\r\n  stage: build\r\n  image: node:18\r\n  variables:\r\n    TAG: $CI_COMMIT_TAG\r\n  script:\r\n    - apt-get update\r\n    - apt-get install jq -y\r\n    - mv package.json temp.json\r\n    - jq -r &#39;.version |= &quot;${TAG}&quot;&#39; temp.json &gt; package.json\r\n    - npm install\r\n    - npm run build\r\n    - echo &quot;FRONTEND BUILD SUCCESSFULY&quot;\r\n  artifacts:\r\n    paths:\r\n      - dist/\r\n    expire_in: &quot;10 mins&quot;\r\n  # Run this job for tags\r\n  only:\r\n    - tags\r\n```\r\n\r\nResolve gitlab variable.",
        "link": "https://stackoverflow.com/questions/76583083/gilab-ci-pipeline-not-resolving-variables-not-resolved-when-there-is-a-double-qu",
        "title": "Gilab-ci pipeline not resolving variables not resolved when there is a double quotes inside single quote"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688059677,
                "post_id": 76583318,
                "comment_id": 135026446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 397667,
                    "reputation": 399,
                    "user_id": 5075528,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dbf5ad843cca0e25933a2b10c39280db?s=256&d=identicon&r=PG",
                    "display_name": "Amin SZ",
                    "link": "https://stackoverflow.com/users/5075528/amin-sz"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688059953,
                "post_id": 76583318,
                "comment_id": 135026501,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1688059957,
                "post_id": 76583318,
                "comment_id": 135026503,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688060006,
                "post_id": 76583318,
                "comment_id": 135026511,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20958278,
                    "reputation": 23075,
                    "user_id": 19355181,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c7943ebd397154185165f876fb128bfd?s=256&d=identicon&r=PG",
                    "display_name": "jqurious",
                    "link": "https://stackoverflow.com/users/19355181/jqurious"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1688065544,
                "post_id": 76583318,
                "comment_id": 135027574,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 397667,
                    "reputation": 399,
                    "user_id": 5075528,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dbf5ad843cca0e25933a2b10c39280db?s=256&d=identicon&r=PG",
                    "display_name": "Amin SZ",
                    "link": "https://stackoverflow.com/users/5075528/amin-sz"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688066852,
                "post_id": 76583318,
                "comment_id": 135027787,
                "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": 1688069046,
                "post_id": 76583318,
                "comment_id": 135028165,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1688071852,
                "post_id": 76583318,
                "comment_id": 135028620,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 397667,
                    "reputation": 399,
                    "user_id": 5075528,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/dbf5ad843cca0e25933a2b10c39280db?s=256&d=identicon&r=PG",
                    "display_name": "Amin SZ",
                    "link": "https://stackoverflow.com/users/5075528/amin-sz"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688076759,
                "post_id": 76583318,
                "comment_id": 135029314,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1688077742,
                "last_edit_date": 1688077742,
                "creation_date": 1688066830,
                "answer_id": 76584088,
                "question_id": 76583318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq-1.5-1-a5b5cbe (as packaged with certain releases of Debain and Ubuntu) had issues with inferring types from a pipelined `select` filter. In this case, `index` provides `null` if the value was not found, or a number (the actual index) if it was, but `select` requires a boolean result in its body.\r\n\r\nWorkaround: Wrap the body in parens, and compare its result against `null` to get a boolean:\r\n```sh\r\n(.first | .second[] | select((.third | index(&quot;1002&quot;)) != null) | .fourth) = &quot;changed&quot;\r\n```\r\n\r\nSolution: Upgrade to jq 1.6. It was released in 2018.\r\n\r\nNote: With the given sample, neither version requires the update operator `|=`. Just use `=` to assign a static value.",
                "title": "Why it shows error While updating an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1688077742,
        "creation_date": 1688059414,
        "last_edit_date": 1688059869,
        "question_id": 76583318,
        "body_markdown": "My JSON file (temp.json):\r\n```\r\n{\r\n\t&quot;first&quot;: {\r\n\t\t&quot;second&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;third&quot;: [\r\n\t\t\t\t\t&quot;1000&quot;,\r\n\t\t\t\t\t&quot;1001&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;fourth&quot;: &quot;Don&#39;tWantToChange&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;third&quot;: [\r\n\t\t\t\t\t&quot;1000&quot;,\r\n\t\t\t\t\t&quot;1001&quot;,\r\n\t\t\t\t\t&quot;1002&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;fourth&quot;: &quot;WantToChange&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\nI want to select an item from array and update as below\r\n```\r\n{\r\n\t&quot;first&quot;: {\r\n\t\t&quot;second&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;third&quot;: [\r\n\t\t\t\t\t&quot;1000&quot;,\r\n\t\t\t\t\t&quot;1001&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;fourth&quot;: &quot;Don&#39;tWantToChange&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;third&quot;: [\r\n\t\t\t\t\t&quot;1000&quot;,\r\n\t\t\t\t\t&quot;1001&quot;,\r\n\t\t\t\t\t&quot;1002&quot;\r\n\t\t\t\t],\r\n\t\t\t\t&quot;fourth&quot;: &quot;changed&quot;\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```\r\n\r\nThis is my code:\r\n```\r\njq &#39;(.first | .second[] | select(.third | index(&quot;1002&quot;)) | .fourth) |= &quot;changed&quot;&#39; temp.json\r\n```\r\n\r\n\r\nIt works on Online JQ Playgrounds perfectly\r\n\r\nBut in the terminal, it shows Error:\r\n```\r\njq: error (at temp.json:13): Invalid path expression near attempt to access element &quot;fourth&quot; of {&quot;third&quot;:[&quot;1000&quot;,&quot;1001&quot;,&quot;1...\r\n```\r\n\r\nWhere am I going wrong?",
        "link": "https://stackoverflow.com/questions/76583318/why-it-shows-error-while-updating-an-array-using-jq",
        "title": "Why it shows error While updating an array using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1688316729,
                "creation_date": 1688316729,
                "answer_id": 76599917,
                "question_id": 76599435,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use $ARGS.named :\r\n\r\n```\r\njq -c -n -f /dev/stdin --arg a &#39;&quot;1&quot;&#39; --arg b &#39;&quot;2&quot;&#39; &lt;&lt;&lt; &#39;{u: &quot;u&quot;} + $ARGS.named&#39;\r\n```",
                "title": "adding key-value pairs from command to a json object without duplication"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1688316729,
        "creation_date": 1688309067,
        "question_id": 76599435,
        "body_markdown": "I want to add key-value pairs to a JSON object in the command line.\r\n\r\n```\r\n$ jq -c -n -f /dev/stdin --arg a &#39;&quot;1&quot;&#39; --arg b &#39;&quot;2&quot;&#39; &lt;&lt;&lt; &#39;{u: &quot;u&quot;, a: $a, b: $b}&#39;\r\n{&quot;u&quot;:&quot;u&quot;,&quot;a&quot;:&quot;\\&quot;1\\&quot;&quot;,&quot;b&quot;:&quot;\\&quot;2\\&quot;&quot;}\r\n```\r\n\r\nIn the above example, given the arguments of --arg a &#39;&quot;1&quot;&#39; --arg b &#39;&quot;2&quot;&#39;, I have to manually add &quot;a&quot; and &quot;b&quot; to the template (the string from stdin). This duplication is not desirable.\r\n\r\nHow can I make the template independent of the arguments to be passed?",
        "link": "https://stackoverflow.com/questions/76599435/adding-key-value-pairs-from-command-to-a-json-object-without-duplication",
        "title": "adding key-value pairs from command to a json object without duplication"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "transform"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1688310656,
                "creation_date": 1688310656,
                "answer_id": 76599539,
                "question_id": 76599481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `walk` to recursively apply a function everywhere.\r\n\r\n    jq &#39;walk(if type == &quot;object&quot;\r\n             then\r\n                 with_entries(.key |= (.[0:1] | ascii_upcase) + (.[1:]))\r\n             else .\r\n             end)&#39; file.json\r\n",
                "title": "jq - transform all keys recursively"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1688322508,
        "creation_date": 1688309845,
        "last_edit_date": 1688322508,
        "question_id": 76599481,
        "body_markdown": "Using jq, I&#39;d like to uppercase the first letter over every property name, recursively. Seems like it should be simple to upper.\r\n\r\nExample Input Json:\r\n\r\n    {\r\n      &quot;field1&quot;: &quot;v1&quot;,\r\n      &quot;field2&quot;: {\r\n        &quot;subfield1&quot;: &quot;sv1&quot;\r\n      },\r\n      &quot;field3&quot;: [&quot;av1&quot;, &quot;av2&quot;]\r\n    }\r\n\r\nDesired Output:\r\n\r\n    {\r\n      &quot;Field1&quot;: &quot;v1&quot;,\r\n      &quot;Field2&quot;: {\r\n        &quot;Subfield1&quot;: &quot;sv1&quot;\r\n      },\r\n      &quot;Field3&quot;: [&quot;av1&quot;, &quot;av2&quot;]\r\n    }\r\n\r\n\r\n\r\nJumping through hoops, I managed to get it working, but only for the first level.\r\n\r\n    cat x.json | jq &#39;([ [ . |  (keys[] as $key | ($key[0:1] | ascii_upcase) + $key[1:]) ], [.[]] ]) | transpose |  map( {(.[0]): (.[1])}) | add&#39;\r\n\r\n\r\nIt seems like it should be easy and that I&#39;m missing something basic/fundamental. Pretty much a noob to jq\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/76599481/jq-transform-all-keys-recursively",
        "title": "jq - transform all keys recursively"
    },
    {
        "tags": [
            "json",
            "select",
            "key",
            "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": 1688377217,
                "post_id": 76603465,
                "comment_id": 135061322,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9612625,
                    "reputation": 31,
                    "user_id": 7136507,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/56a5753e277cf1edf3c30cae30d093d9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "surya",
                    "link": "https://stackoverflow.com/users/7136507/surya"
                },
                "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": 1688379169,
                "post_id": 76603465,
                "comment_id": 135061701,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1688452723,
                "last_edit_date": 1688452723,
                "creation_date": 1688377106,
                "answer_id": 76603540,
                "question_id": 76603465,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries,from_entries,with_entries(f)) to get an array of key-value-pairs, then iterate it with [`.[]`](https://jqlang.github.io/jq/manual/#Array/ObjectValueIterator:.[]) it and [`select`](https://jqlang.github.io/jq/manual/#select(boolean_expression)) the pairs with an empty value, and finally extract the [`.key`](https://jqlang.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar) from the pair:\r\n\r\n```\r\nto_entries[] | select(.value==&quot;&quot;) | .key\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;key2&quot;\r\n```\r\n\r\nTo run with Windows PowerShell, you should be able to quote the whole expression with single quotes:\r\n\r\n```\r\njq &#39;to_entries[] | select(.value==&quot;&quot;) | .key&#39;\r\n```\r\n\r\nAt least that&#39;s what [the documentation of PowerShell 7.3](https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_quoting_rules?view=powershell-7.3#including-quote-characters-in-a-string) suggests.\r\n\r\nIf that does not work either, you can store your jq program in a file (e.g. `find-keys.jq` with content `to_entries[] | select(.value==&quot;&quot;) | .key`) and then load it with `jq -f find-keys.jq`",
                "title": "Find object keys with empty string values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1688452723,
        "creation_date": 1688376476,
        "last_edit_date": 1688392737,
        "question_id": 76603465,
        "body_markdown": "I&#39;m trying to get the keys named `key2` which has the value `&quot;&quot;` from a JSON file as below through `jq`.\r\n\r\nI&#39;m using `jq` in `Windows PowerShell`. Can someone please help me ?\r\n\r\n    {\r\n        &quot;Key&quot;: &quot;value&quot;,\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/76603465/find-object-keys-with-empty-string-values",
        "title": "Find object keys with empty string values"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1688468688,
                "post_id": 76611896,
                "comment_id": 135075415,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20353323,
                    "reputation": 355,
                    "user_id": 14929472,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f5691f0639547f67bf69bd341e63c6a8?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "cesq",
                    "link": "https://stackoverflow.com/users/14929472/cesq"
                },
                "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": 1688469213,
                "post_id": 76611896,
                "comment_id": 135075534,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1688468596,
                "last_edit_date": 1688468596,
                "creation_date": 1688468285,
                "answer_id": 76611918,
                "question_id": 76611896,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Loop over the `storagePoolList` array, map each object, assign `storagePoolName` to `.storagePoolEntity.storagePoolName`\r\n\r\n```\r\n.storagePoolList |= map(.storagePoolName = .storagePoolEntity.storagePoolName)\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/Le7g4S1uqdi)\r\n----------\r\n\r\nIf you want to remove the `storagePoolEntitiy.storegePoolName` from the inner object, use `del()`:\r\n```\r\n(.storagePoolList |= map(.storagePoolName = .storagePoolEntity.storagePoolName | del(.storagePolicyEntity.storagePolicyName))) \r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/U5xXtaysijg)\r\n----------\r\n\r\n\r\n",
                "title": "How to move a json item one level higher in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1688468658,
        "creation_date": 1688468087,
        "last_edit_date": 1688468658,
        "question_id": 76611896,
        "body_markdown": "I have a json response object that follows this format:\r\n\r\n    {\r\n     &quot;storagePoolList&quot;: [\r\n       {\r\n         &quot;status&quot;: Online\r\n         &quot;statusCode&quot;: 0,\r\n         &quot;storagePolicyEntity&quot;: {\r\n           &quot;_type_&quot;: 17,\r\n           &quot;storagePolicyName&quot;: &quot;n1&quot;,\r\n           &quot;storagePolicyId&quot;: 38\r\n          },\r\n         &quot;storagePoolEntity&quot;: {\r\n           &quot;storagePoolName&quot;: &quot;n2&quot;,\r\n           &quot;_type_&quot;: 160,\r\n           &quot;storagePoolId&quot;: 38\r\n         },\r\n         &quot;storagePool&quot;: {\r\n           &quot;_type_&quot;: 28,\r\n           &quot;clientGroupId&quot;: 38,\r\n           &quot;clientGroupName&quot;: &quot;ddsa&quot;\r\n         }\r\n       },\r\n       {\r\n         &quot;status&quot;: &quot;Online&quot;,\r\n         &quot;statusCode&quot;: 0,\r\n         &quot;storagePolicyEntity&quot;: {\r\n           &quot;_type_&quot;: 17,\r\n           &quot;storagePolicyName&quot;: &quot;dsa&quot;,\r\n           &quot;storagePolicyId&quot;: 65\r\n         },\r\n         &quot;storagePoolEntity&quot;: {\r\n           &quot;storagePoolName&quot;: &quot;dasdas&quot;,\r\n           &quot;_type_&quot;: 160,\r\n           &quot;storagePoolId&quot;: 65\r\n         },\r\n         &quot;storagePool&quot;: {\r\n           &quot;_type_&quot;: 28,\r\n           &quot;clientGroupId&quot;: 65,\r\n           &quot;clientGroupName&quot;: &quot;fasdf&quot;\r\n         }\r\n       }\r\n     ]\r\n    }\r\n\r\nAssume that there&#39;s more of these, not only two. The thing is, I want the `storagePolicyName` one level higher, at the same level as `status` item. \r\n\r\nThe json object is stored in a `data` variable\r\n\r\nWhat I&#39;ve tried is this:\r\n\r\n```\r\nneed_this=$(echo &quot;$data&quot; | jq &#39;.storagePoolList |= map(.storagePolicyName = .storagePolicyEntity.storagePolicyName | del(.storagePolicyEntity))&#39;)\r\n```\r\n\r\nBut it doesn&#39;t work (output is unchanged), I&#39;ve been racking my mind for a while now, what I wrote I &quot;tried&quot; is just the latest version of the script that has seen way too many changes.\r\n\r\nI come to you asking for help",
        "link": "https://stackoverflow.com/questions/76611896/how-to-move-a-json-item-one-level-higher-in-bash",
        "title": "How to move a json item one level higher in bash?"
    },
    {
        "tags": [
            "arrays",
            "json",
            "mongodb",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3631143,
                    "reputation": 60146,
                    "user_id": 3027266,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/6OFEe.png?s=256",
                    "display_name": "Wernfried Domscheit",
                    "link": "https://stackoverflow.com/users/3027266/wernfried-domscheit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688474760,
                "post_id": 76612734,
                "comment_id": 135076741,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10524481,
                    "reputation": 29,
                    "user_id": 7755909,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27e36285713e462e07600de8c48ee4b7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MDL",
                    "link": "https://stackoverflow.com/users/7755909/mdl"
                },
                "reply_to_user": {
                    "account_id": 3631143,
                    "reputation": 60146,
                    "user_id": 3027266,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/6OFEe.png?s=256",
                    "display_name": "Wernfried Domscheit",
                    "link": "https://stackoverflow.com/users/3027266/wernfried-domscheit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688474929,
                "post_id": 76612734,
                "comment_id": 135076779,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1688475316,
                "post_id": 76612734,
                "comment_id": 135076866,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1688475360,
                "post_id": 76612734,
                "comment_id": 135076874,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10524481,
                    "reputation": 29,
                    "user_id": 7755909,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27e36285713e462e07600de8c48ee4b7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MDL",
                    "link": "https://stackoverflow.com/users/7755909/mdl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688475625,
                "post_id": 76612734,
                "comment_id": 135076948,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10524481,
                    "reputation": 29,
                    "user_id": 7755909,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/27e36285713e462e07600de8c48ee4b7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "MDL",
                    "link": "https://stackoverflow.com/users/7755909/mdl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688475667,
                "post_id": 76612734,
                "comment_id": 135076955,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1688476043,
                "post_id": 76612734,
                "comment_id": 135077045,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3631143,
                    "reputation": 60146,
                    "user_id": 3027266,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://i.sstatic.net/6OFEe.png?s=256",
                    "display_name": "Wernfried Domscheit",
                    "link": "https://stackoverflow.com/users/3027266/wernfried-domscheit"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1688478425,
                "post_id": 76612734,
                "comment_id": 135077591,
                "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": 1688482197,
                "post_id": 76612734,
                "comment_id": 135078473,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689326069,
                "last_edit_date": 1689326069,
                "creation_date": 1688549225,
                "answer_id": 76618949,
                "question_id": 76612734,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the [tag:jq] tag has been included, here&#39;s a script showing the kind of thing you could do using jq.\r\n\r\nThe main problem from the JSON-processing point of view is that your sample is not actually JSON.\r\nIf you could get mongo to give you JSON, then things would be much more straightforward.\r\n\r\nIn any case, in the following, we first convert your pseuso-JSON to valid JSON, using a bespoke jq function, here named `ObjectId`. \r\n\r\nWith your example, the following script produces the output shown below it:\r\n\r\n```\r\n#!/bin/bash\r\n\r\nmongo=&#39;[ { &quot;_id&quot; : ObjectId(&quot;64a3f08660a51f2848729093&quot;), &quot;setId&quot; : &quot;64a3f08560a51f2848729092&quot; }, \r\n         { &quot;_id&quot; : ObjectId(&quot;64a3f08660a51f2848729094&quot;), &quot;setId&quot; : &quot;64a3f08560a51f2848729092&quot; } ]&#39;\r\n\r\nfunction itemize {\r\n  jq -nc &quot;\r\n  def ObjectId(s): {ObjectId: s};\r\n\r\n  $mongo\r\n  | .[]&quot;\r\n}\r\n\r\nwhile read -r object ; do\r\n    echo &quot;$object&quot;\r\ndone &lt; &lt;(itemize)\r\n\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{&quot;_id&quot;:{&quot;ObjectId&quot;:&quot;64a3f08660a51f2848729093&quot;},&quot;setId&quot;:&quot;64a3f08560a51f2848729092&quot;}\r\n{&quot;_id&quot;:{&quot;ObjectId&quot;:&quot;64a3f08660a51f2848729094&quot;},&quot;setId&quot;:&quot;64a3f08560a51f2848729092&quot;}\r\n```",
                "title": "how to loop through output of mongo db find query in shellscript"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689326069,
        "creation_date": 1688474332,
        "last_edit_date": 1688529273,
        "question_id": 76612734,
        "body_markdown": "```\r\nele=$(mongo ${DATABASE_NAME} --quiet --eval &#39;printjson(db.&#39;${COLLECTION_NAME&#39;.find({&quot;status&quot;:1},{&quot;_id&quot;: 1, &quot;setId&quot;: 1}).toArray())&#39;)\r\n\r\n```\r\nThis returns \r\n```[ { &quot;_id&quot; : ObjectId(&quot;64a3f08660a51f2848729093&quot;), &quot;setId&quot; : &quot;64a3f08560a51f2848729092&quot; }, { &quot;_id&quot; : ObjectId(&quot;64a3f08660a51f2848729094&quot;), &quot;setId&quot; : &quot;64a3f08560a51f2848729092&quot; } ]```\r\nNow when i want to do further processing on this data,the loop is not returning it as 2 elements,but instead 1.. How do i make it to 1 document at a time within the loop.\r\n```\r\nfor i in &quot;${ele[@]}&quot;\r\ndo\r\n    echo $i\r\ndone\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76612734/how-to-loop-through-output-of-mongo-db-find-query-in-shellscript",
        "title": "how to loop through output of mongo db find query in shellscript"
    },
    {
        "tags": [
            "c",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9115493,
                    "reputation": 12434,
                    "user_id": 6782754,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/99008d0e4c4c15ab03d77938ad9e345b?s=256&d=identicon&r=PG",
                    "display_name": "Gerhardh",
                    "link": "https://stackoverflow.com/users/6782754/gerhardh"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1688480958,
                "post_id": 76613620,
                "comment_id": 135078200,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1688556301,
                "last_edit_date": 1688556301,
                "creation_date": 1688506759,
                "answer_id": 76615988,
                "question_id": 76613620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As far as I can tell, `jv_parse` can be used to validate strings of JSON.\r\n\r\nIts declared in [*src/jv.h*][1] as:\r\n\r\n```C\r\njv jv_parse(const char* string);\r\n```\r\n\r\nPassing the result of this function to `jv_is_valid` appears to get the job done. `jv_is_valid` is defined in *src/jv.h* as:\r\n\r\n```C\r\nstatic int jv_is_valid(jv x) {\r\n    return jv_get_kind(x) != JV_KIND_INVALID;\r\n}\r\n```\r\n\r\nA cursory example:\r\n\r\n```C\r\n#include &lt;jq.h&gt;\r\n#include &lt;stdio.h&gt;\r\n#include &lt;string.h&gt;\r\n\r\nint json_is_valid(const char *json)\r\n{\r\n    jv ele = jv_parse(json);\r\n    int valid = jv_is_valid(ele);\r\n    jv_free(ele);\r\n\r\n    return valid;\r\n}\r\n\r\nint main(void)\r\n{\r\n    while (1) {\r\n        char buf[512];\r\n\r\n        if (!fgets(buf, sizeof buf, stdin))\r\n            break;\r\n\r\n        buf[strcspn(buf, &quot;\\n&quot;)] = &#39;\\0&#39;;\r\n\r\n        printf(&quot;&lt;&lt;%s&gt;&gt; Valid? %s.\\n&quot;, buf, json_is_valid(buf) ? &quot;Yes&quot; : &quot;No&quot;);\r\n    }\r\n}\r\n```\r\n\r\n```lang-none\r\n{}\r\n&lt;&lt;{}&gt;&gt; Valid? Yes.\r\n[]\r\n&lt;&lt;[]&gt;&gt; Valid? Yes.\r\n[{}]\r\n&lt;&lt;[{}]&gt;&gt; Valid? Yes.\r\n[][]\r\n&lt;&lt;[][]&gt;&gt; Valid? No.\r\n&quot;foo&quot;\r\n&lt;&lt;&quot;foo&quot;&gt;&gt; Valid? Yes.\r\n&quot;foo&quot;:&quot;bar&quot;\r\n&lt;&lt;&quot;foo&quot;:&quot;bar&quot;&gt;&gt; Valid? No.\r\n51\r\n&lt;&lt;51&gt;&gt; Valid? Yes.\r\n{42: []}\r\n&lt;&lt;{42: []}&gt;&gt; Valid? No.\r\n{&quot;42&quot;:[1, 2, 3]}\r\n&lt;&lt;{&quot;42&quot;:[1, 2, 3]}&gt;&gt; Valid? Yes.\r\n&#39;qux&#39;\r\n&lt;&lt;&#39;qux&#39;&gt;&gt; Valid? No.\r\n```\r\n\r\nThe problem with `jq_compile` (`jq_compile_args`) is that it would seem to parse the *jq* filtering language described in [the manual][2].\r\n\r\nThere might be a more correct method, but the [lack of a proper C API documentation][3] makes this an unwieldy problem to research.\r\n\r\n  [1]: https://github.com/jqlang/jq/blob/master/src/jv.h\r\n  [2]: https://jqlang.github.io/jq/manual/#Basicfilters\r\n  [3]: https://github.com/jqlang/jq/wiki/C-API:-libjq",
                "title": "how to check if a string is valid json in c using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1688556301,
        "creation_date": 1688480748,
        "last_edit_date": 1688506766,
        "question_id": 76613620,
        "body_markdown": "basically I want to have a function `bool json_is_valid(char* input)` in c. As I use `jq` for the rest of my json stuff, I want to use it for this as well, however I am unable to find a proper way of doing it. Among other things I&#39;ve tried the following: \r\n```c\r\nbool json_is_valid(char* input){\r\n        jq_state* state = jq_init();\r\n        jv compiled = jq_compile_args(state, &quot;.&quot;, NULL);\r\n\r\n        return !(jv_is_valid(compiled));\r\n}\r\n```\r\n\r\nHowever, this still doesn&#39;t work. How could this be fixed?",
        "link": "https://stackoverflow.com/questions/76613620/how-to-check-if-a-string-is-valid-json-in-c-using-jq",
        "title": "how to check if a string is valid json in c using jq"
    },
    {
        "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": 1,
                "creation_date": 1688486983,
                "post_id": 76614334,
                "comment_id": 135079428,
                "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": 1688489066,
                "post_id": 76614334,
                "comment_id": 135079804,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9612625,
                    "reputation": 31,
                    "user_id": 7136507,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/56a5753e277cf1edf3c30cae30d093d9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "surya",
                    "link": "https://stackoverflow.com/users/7136507/surya"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688551377,
                "post_id": 76614334,
                "comment_id": 135087287,
                "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": 1688571559,
                "post_id": 76614334,
                "comment_id": 135092135,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1688564382,
                "creation_date": 1688564382,
                "answer_id": 76620933,
                "question_id": 76614334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I cannot find the dupe, so here goes.\r\n\r\nTo add each file as element into one big array, you can use [`-s`/`--slurp`](https://jqlang.github.io/jq/manual/#Invokingjq) with the [identity filter `.`](https://jqlang.github.io/jq/manual/#Identity:.):\r\n\r\n```\r\njq -s &#39;.&#39; file1.json file2.json\r\n```\r\n\r\n… or collect [`inputs`](https://jqlang.github.io/jq/manual/#inputs) into [an array](https://jqlang.github.io/jq/manual/#Arrayconstruction:[]) (with `-n`/`--null-input`):\r\n\r\n```\r\njq -n &#39;[inputs]&#39; file1.json file2.json\r\n```\r\n\r\nor without `-n`:\r\n\r\n```\r\njq &#39;[., inputs]&#39; file1.json file2.json\r\n```\r\n\r\nYou can read more about the differences of slurping vs consuming inputs in https://stackoverflow.com/questions/73843868/difference-between-slurp-null-input-and-inputs-filter\r\n\r\nOutput:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n  },\r\n  {\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n  }\r\n]\r\n```",
                "title": "join individual key:value maps into a single map using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1688564382,
        "creation_date": 1688486805,
        "question_id": 76614334,
        "body_markdown": "Hi I have below code which has individual `key:value` maps needs to be merged into a single `key:value` map\r\n\r\nFrom below code\r\n```\r\n{\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n}\r\n{\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n}\r\n```\r\n\r\nTo below code using `jq`\r\n```\r\n{\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n},\r\n{\r\n    &quot;Key1&quot;: &quot;value1&quot;,\r\n    &quot;Key2&quot;: &quot;value2&quot;,\r\n    &quot;Key3&quot;: &quot;value3&quot;,\r\n    &quot;Key4&quot;: &quot;value4&quot;\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/76614334/join-individual-keyvalue-maps-into-a-single-map-using-jq",
        "title": "join individual key:value maps into a single map using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1688633981,
                "last_edit_date": 1688633981,
                "creation_date": 1688625978,
                "answer_id": 76626144,
                "question_id": 76625723,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way using regular expressions with [`capture`](https://jqlang.github.io/jq/manual/v1.6/#capture%28val%29%2Ccapture%28regex%3Bflags%29):\r\n```sh\r\n.events[].message | capture([\r\n  &quot;(?&lt;date&gt;[\\\\d-]+ [\\\\d:]+)&quot;,\r\n  &quot;(?&lt;ip&gt;[\\\\d.]+)&quot;,\r\n  &quot;(?&lt;user&gt;[^:]+)&quot;,\r\n  &quot;&quot;, &quot;LOG&quot;, &quot;duration&quot;,\r\n  &quot;(?&lt;time&gt;[\\\\d.]+)&quot;,\r\n  &quot;(?&lt;query&gt;.*)&quot;\r\n] | join(&quot;[^:]*: *&quot;))\r\n| [.date, .ip, .user, .time, .query | @html &quot;&lt;td&gt;\\(.)&lt;/td&gt;&quot;]\r\n| &quot;&lt;tr&gt;\\(add)&lt;/tr&gt;&quot;\r\n```\r\n```html\r\n&lt;tr&gt;&lt;td&gt;2023-07-06 03:55:24&lt;/td&gt;&lt;td&gt;11.11.11.11&lt;/td&gt;&lt;td&gt;testUser@postgres&lt;/td&gt;&lt;td&gt;2004.016&lt;/td&gt;&lt;td&gt;select pg_sleep(2);&lt;/td&gt;&lt;/tr&gt;\r\n&lt;tr&gt;&lt;td&gt;2023-07-06 03:58:42&lt;/td&gt;&lt;td&gt;111.22.331.41&lt;/td&gt;&lt;td&gt;testService@postgres&lt;/td&gt;&lt;td&gt;2009.526&lt;/td&gt;&lt;td&gt;select pg_sleep(2);&lt;/td&gt;&lt;/tr&gt;\r\n```\r\n[Demo](https://jqplay.org/s/GGb1WrSIVIL)\r\n\r\n---\r\nTo add some simple pretty-printing, you could replace the last line with\r\n```sh\r\n| &quot;&lt;tr&gt;\\n\\(map(&quot;  \\(.)\\n&quot;) | add)&lt;/tr&gt;&quot;\r\n```\r\n```html\r\n&lt;tr&gt;\r\n  &lt;td&gt;2023-07-06 03:55:24&lt;/td&gt;\r\n  &lt;td&gt;11.11.11.11&lt;/td&gt;\r\n  &lt;td&gt;testUser@postgres&lt;/td&gt;\r\n  &lt;td&gt;2004.016&lt;/td&gt;\r\n  &lt;td&gt;select pg_sleep(2);&lt;/td&gt;\r\n&lt;/tr&gt;\r\n&lt;tr&gt;\r\n  &lt;td&gt;2023-07-06 03:58:42&lt;/td&gt;\r\n  &lt;td&gt;111.22.331.41&lt;/td&gt;\r\n  &lt;td&gt;testService@postgres&lt;/td&gt;\r\n  &lt;td&gt;2009.526&lt;/td&gt;\r\n  &lt;td&gt;select pg_sleep(2);&lt;/td&gt;\r\n&lt;/tr&gt;\r\n```\r\n[Demo](https://jqplay.org/s/XRCKeXHDF_E)",
                "title": "Jq trim with regex or position of char"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1688652366,
        "creation_date": 1688620908,
        "last_edit_date": 1688652366,
        "question_id": 76625723,
        "body_markdown": "The CloudWatch log format for Aurora Postgresql delayed queries is as follows.\r\n\r\n```lang-json\r\n{\r\n    &quot;nextForwardToken&quot;: &quot;f/37657393414703861243420284798371757973629840396172525568/s&quot;, \r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;ingestionTime&quot;: 1688615727267, \r\n            &quot;timestamp&quot;: 1688615724000, \r\n            &quot;message&quot;: &quot;2023-07-06 03:55:24 UTC:11.11.11.11(51400):testUser@postgres:[9802]:LOG:  duration: 2004.016 ms  statement: select pg_sleep(2);&quot;\r\n        }, \r\n        {\r\n            &quot;ingestionTime&quot;: 1688615925270, \r\n            &quot;timestamp&quot;: 1688615922000, \r\n            &quot;message&quot;: &quot;2023-07-06 03:58:42 UTC:111.22.331.41(1230):testService@postgres:[8602]:LOG:  duration: 2009.526 ms  statement: select pg_sleep(2);&quot;\r\n        }\r\n    ], \r\n    &quot;nextBackwardToken&quot;: &quot;b/37657388999156311934356902534929058635511305773902397440/s&quot;\r\n}\r\n```\r\n\r\nI want to create html format using jq command.\r\nI want to parse message field and The desired format like this:\r\n\r\n|Time(UTC)|clientIP|user@db|Query_time(ms)|Query|\r\n|---|---|---|---|---|---|---|---|\r\n|2023-07-06 03:55:24|11.11.11.11|testUser@postgres|2004.016|select pg_sleep(2)|\r\n|2023-07-06 03:58:42|111.22.331.41|testService@postgres|2009.526|select pg_sleep(2)|\r\n\r\nTo create the table, I tried various methods.\r\n\r\n&lt;1&gt;&lt;br&gt;\r\nI wanted to apply the pattern to startswith and trim, but I couldn&#39;t find the material and it didn&#39;t apply.\r\n```\r\n/usr/local/bin/jq -r &#39;\r\ndef to_row: &quot;&lt;tr&gt;&quot;,.[],&quot;&lt;/tr&gt;&quot;;\r\ndef to_cell: &quot;&lt;td&gt;&quot;,.,&quot;&lt;/td&gt;&quot;;\r\n(\r\n  .events[] | select(.message | contains(&quot;duration:&quot;)) | .message/&quot;\\n&quot; | map(\r\n    (select(startswith(&quot;\\(.[0:4])-\\(.[4:6])-\\(.[6:8]) \\(.[8:10]):\\(.[10:12]):\\(.[12:14])&quot;)))\r\n  | map(@html | to_cell)\r\n  | to_row\r\n)\r\n&#39;\r\n```\r\n\r\n&lt;2&gt;&lt;br&gt;\r\nThis method seems to be able to split the fields, but not in the desired direction.\r\n```lang-html\r\n.events[] | .message | split(&quot;:&quot;)\r\n\r\n&lt;tr&gt;\r\n&lt;td&gt;\r\n2023-07-06 03\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n55\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n24 UTC\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n11.11.11.11(51400)\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\ntestUser@postgres\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n[9802]\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\nLOG\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n  duration\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n 2004.016 ms  statement\r\n&lt;/td&gt;\r\n&lt;td&gt;\r\n select pg_sleep(2);\r\n&lt;/td&gt;\r\n&lt;/tr&gt;\r\n```\r\n\r\nIs there a way to make it clean in the jq command?",
        "link": "https://stackoverflow.com/questions/76625723/jq-trim-with-regex-or-position-of-char",
        "title": "Jq trim with regex or position of char"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688764923,
                "post_id": 76640222,
                "comment_id": 135122625,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28972823,
                    "reputation": 3,
                    "user_id": 22192712,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a241e3395768cf1d66afda2ac7f31f90?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rubberduck",
                    "link": "https://stackoverflow.com/users/22192712/rubberduck"
                },
                "reply_to_user": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688767199,
                "post_id": 76640222,
                "comment_id": 135122850,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1688764559,
                "creation_date": 1688764559,
                "answer_id": 76640281,
                "question_id": 76640222,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r &#39;.[] | .regisseur as $r | .movies[] | [$r, .] | @csv&#39;\r\n```\r\nWill output proper CSV\r\n```none\r\n&quot;Steven Spielberg&quot;,&quot;War of the Worlds&quot;\r\n&quot;Steven Spielberg&quot;,&quot;Jurassic Park&quot;\r\n&quot;George Lucas&quot;,&quot;Howard The Duck&quot;\r\n&quot;George Lucas&quot;,&quot;Hook&quot;\r\n```\r\n\r\nFor semicolon separated, you could pipe that into another tool like [tag:miller] or [tag:csvkit], or you could hope the input data contains no semicolons and do\r\n```sh\r\njq -r &#39;.[] | .regisseur as $r | .movies[] | [$r, .] | join(&quot;;&quot;)&#39;\r\n```\r\n",
                "title": "Generate CSV from JSON with JQ with nested levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1688764559,
        "creation_date": 1688763681,
        "question_id": 76640222,
        "body_markdown": "I&#39;m struggling somehow to create a nice jq-Query to generate a proper CSV like the below from following JSON example:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;regisseur&quot;: &quot;Steven Spielberg&quot;,\r\n    &quot;movies&quot;: [\r\n      &quot;War of the Worlds&quot;,\r\n      &quot;Jurassic Park&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;regisseur&quot;: &quot;George Lucas&quot;,\r\n    &quot;movies&quot;: [\r\n      &quot;Howard The Duck&quot;,\r\n      &quot;Hook&quot;\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nWhat I&#39;d like to get is a CSV-representation of it looking like this:\r\n```\r\nSteven Spielberg;War of the Worlds;\r\nSteven Spielberg;Jurassic Park;\r\nGeorge Lucas;Howard The Duck;\r\nGeorge Lucas;Hook;\r\n```\r\n\r\nI especially want to achieve this with one single jq - call for performance-reasons and I&#39;d like to avoid to iterate over it for each regisseur (at least within bash; jq may do iterate, as long as it is fast)\r\n\r\n(The example here is just small, in reality I have to look at many more records, hence the emphasis on performance)\r\n\r\n\r\n\r\nI could do it by getting a list of all regisseurs, externally iterate over it and then ask for the list of movies per that regisseur and make the CSV. \r\n\r\nHowever this is not performant enough and I do not know how to script such within jq itself.",
        "link": "https://stackoverflow.com/questions/76640222/generate-csv-from-json-with-jq-with-nested-levels",
        "title": "Generate CSV from JSON with JQ with nested levels"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688832418,
                "post_id": 76643800,
                "comment_id": 135128328,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 146405,
                    "reputation": 65432,
                    "user_id": 356849,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/vTOLbdzo.png?s=256",
                    "display_name": "NullVoxPopuli",
                    "link": "https://stackoverflow.com/users/356849/nullvoxpopuli"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688832764,
                "post_id": 76643800,
                "comment_id": 135128368,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688834001,
                "post_id": 76643800,
                "comment_id": 135128490,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 146405,
                    "reputation": 65432,
                    "user_id": 356849,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/vTOLbdzo.png?s=256",
                    "display_name": "NullVoxPopuli",
                    "link": "https://stackoverflow.com/users/356849/nullvoxpopuli"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688834746,
                "post_id": 76643800,
                "comment_id": 135128569,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 146405,
                    "reputation": 65432,
                    "user_id": 356849,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/vTOLbdzo.png?s=256",
                    "display_name": "NullVoxPopuli",
                    "link": "https://stackoverflow.com/users/356849/nullvoxpopuli"
                },
                "reply_to_user": {
                    "account_id": 3597514,
                    "reputation": 122820,
                    "user_id": 3001761,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/feZwC.jpg?s=256",
                    "display_name": "jonrsharpe",
                    "link": "https://stackoverflow.com/users/3001761/jonrsharpe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1688834972,
                "post_id": 76643800,
                "comment_id": 135128598,
                "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": 1688842340,
                "post_id": 76643800,
                "comment_id": 135129410,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 146405,
                    "reputation": 65432,
                    "user_id": 356849,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/vTOLbdzo.png?s=256",
                    "display_name": "NullVoxPopuli",
                    "link": "https://stackoverflow.com/users/356849/nullvoxpopuli"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1688843052,
                "post_id": 76643800,
                "comment_id": 135129508,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1688843806,
                "last_edit_date": 1688843806,
                "creation_date": 1688843306,
                "answer_id": 76644556,
                "question_id": 76643800,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input appears to be a stream of the objects. You have the right idea but execution is off. `||=` is not valid syntax, you probably meant `|=`.\r\n\r\nYou can use jq&#39;s pattern binding syntax in a similar fashion to javascript to pull out certain properties of an object. Though, there isn&#39;t a &quot;rest&quot; syntax for the unbound properties, but we can work around that. Then construct the result. You can take shortcuts here as jq assumes an object when performing assignments to properties.\r\n\r\n```\r\n$ jq -n &#39;reduce (inputs|[.,del(.package,.task)]) as [{$package,$task},$rest] ({};\r\n  .[$package][$task] |= $rest\r\n)&#39;\r\n{\r\n  &quot;@nullvoxpopuli/dev&quot;: {\r\n    &quot;_syncPnpm&quot;: {\r\n      &quot;local&quot;: false,\r\n      &quot;remote&quot;: false,\r\n      &quot;status&quot;: &quot;MISS&quot;,\r\n      &quot;timeSaved&quot;: 0\r\n    },\r\n    &quot;test&quot;: {\r\n      &quot;local&quot;: false,\r\n      &quot;remote&quot;: false,\r\n      &quot;status&quot;: &quot;MISS&quot;,\r\n      &quot;timeSaved&quot;: 0\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/ir-BQqyZYyv)",
                "title": "Using jq, how do I convert an array of objects where two properties make up a &quot;key&quot; to an indexed object of objects?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1688843806,
        "creation_date": 1688831924,
        "last_edit_date": 1688832255,
        "question_id": 76643800,
        "body_markdown": "I have this input JSON array (already slightly preprocessed from turborepo&#39;s --dry-run=json output)\r\n```\r\n{\r\n  &quot;package&quot;: &quot;@nullvoxpopuli/dev&quot;,\r\n  &quot;task&quot;: &quot;_syncPnpm&quot;,\r\n  &quot;local&quot;: false,\r\n  &quot;remote&quot;: false,\r\n  &quot;status&quot;: &quot;MISS&quot;,\r\n  &quot;timeSaved&quot;: 0\r\n}\r\n{\r\n  &quot;package&quot;: &quot;@nullvoxpopuli/dev&quot;,\r\n  &quot;task&quot;: &quot;test&quot;,\r\n  &quot;local&quot;: false,\r\n  &quot;remote&quot;: false,\r\n  &quot;status&quot;: &quot;MISS&quot;,\r\n  &quot;timeSaved&quot;: 0\r\n}\r\n{ \r\n  &quot;package&quot;: &quot;another-package&quot;,\r\n  ...\r\n  ... etc\r\n```\r\n\r\nI&#39;d like to transform this data in to the following shape:\r\n```\r\n{\r\n  &quot;@nullvoxpopuli/dev&quot;: {\r\n    &quot;_syncPnpm&quot;: {\r\n      &quot;local&quot;: false,\r\n      &quot;remote&quot;: false,\r\n      &quot;status&quot;: &quot;MISS&quot;,\r\n      &quot;timeSaved&quot;: 0\r\n    },\r\n    &quot;test&quot;: {\r\n      &quot;local&quot;: false,\r\n      &quot;remote&quot;: false,\r\n      &quot;status&quot;: &quot;MISS&quot;,\r\n      &quot;timeSaved&quot;: 0  \r\n    }\r\n  }\r\n}\r\n```\r\nThe schem(e|a) for this transform is:\r\n```\r\n{\r\n  [package]: {\r\n    [task]: {\r\n      ...the other fields\r\n    }\r\n  }\r\n}\r\n```\r\nThis would allow me to use GitHub actions to skip jobs based on cache status, which would help save the environment\r\n\r\nI&#39;ve been using https://jqplay.org/ to test out stuff before I bring the solution to the command line, and most of my problem is just that I don&#39;t know the foundations of jq well enough.\r\n\r\nI think I need to use reduce, but building new nested objects is escaping my understanding.\r\n\r\nChatGPT suggested this:\r\n```\r\nreduce .[] as $item ({};\r\n    .[$item.package][$item.task] += [$item]\r\n)\r\n```\r\nbut that gives me this error:\r\n```\r\njq: error (at &lt;stdin&gt;:1072): Cannot index string with string &quot;task&quot;\r\nexit status 5\r\n```\r\nwhich I don&#39;t know what to do about.\r\nIt _sounds_ like it&#39;s trying to iterate over a string, but I don&#39;t know why it would do that? \r\nThe error could def be a lot more clear.\r\n\r\nI also found this site: https://remysharp.com/drafts/jq-recipes\r\nwhich generally suggests the same thing -- at least the reduce syntax looks correct.\r\nMaybe it&#39;s the nested object creation part that ChatGPT got wrong.\r\n(It&#39;s also something that&#39;s very hard to google for, and I haven&#39;t found anyone doing what I want yet)\r\n\r\nI also tried a technique that I use in JavaScript for this sort of thing, but I don&#39;t think this is correct either:\r\n```\r\nreduce .[] as $item ({};\r\n    .[$item.package] ||= {}\r\n    .[$item.package][$item.task] ||= {}\r\n    .[$item.package][$item.task] += [$item]\r\n)\r\n```\r\nas I get the error:\r\n```\r\njq: error: syntax error, unexpected |= (Unix shell quoting issues?) at &lt;top-level&gt;, line 4:\r\n    .[$item.package] ||= {}                      \r\njq: 1 compile error\r\nexit status 3\r\n```\r\nso... I don&#39;t know if jq has the concept of &quot;or, equals&quot;\r\n\r\n\r\nHere is my jq-play link: https://jqplay.org/s/mFZdK_Gz4WE",
        "link": "https://stackoverflow.com/questions/76643800/using-jq-how-do-i-convert-an-array-of-objects-where-two-properties-make-up-a-k",
        "title": "Using jq, how do I convert an array of objects where two properties make up a &quot;key&quot; to an indexed object of objects?"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689010276,
                "post_id": 76656017,
                "comment_id": 135149728,
                "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": 1689011349,
                "post_id": 76656017,
                "comment_id": 135149915,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689014350,
                "creation_date": 1689014350,
                "answer_id": 76656463,
                "question_id": 76656017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you know the actual names of `x` and `y`, you can address them directly (setting `.x` and appending to `.y`) using this `reduce`:\r\n```sh\r\n(reduce data[] as {$x,$y} ({}; .[$x] |= (.x = $x | .y += [$y])))[]\r\n```\r\n```json\r\n{\r\n  &quot;x&quot;: &quot;t&quot;,\r\n  &quot;y&quot;: [\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;\r\n    ],\r\n    [\r\n      &quot;c&quot;,\r\n      &quot;d&quot;\r\n    ]\r\n  ]\r\n}\r\n{\r\n  &quot;x&quot;: &quot;r&quot;,\r\n  &quot;y&quot;: [\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/_JFgmZcUbls)\r\n\r\n---\r\nOr use a more functional approach, and `group_by` the common field:\r\n```sh\r\n[data[]] | group_by(.x)[] | {x: .[0].x, y: map(.y)}\r\n```\r\n```json\r\n{\r\n  &quot;x&quot;: &quot;r&quot;,\r\n  &quot;y&quot;: [\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;c&quot;\r\n    ]\r\n  ]\r\n}\r\n{\r\n  &quot;x&quot;: &quot;t&quot;,\r\n  &quot;y&quot;: [\r\n    [\r\n      &quot;a&quot;,\r\n      &quot;b&quot;\r\n    ],\r\n    [\r\n      &quot;c&quot;,\r\n      &quot;d&quot;\r\n    ]\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/fe5eD7ylMfn)",
                "title": "jq merge data from different objects"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689014350,
        "creation_date": 1689010029,
        "last_edit_date": 1689013405,
        "question_id": 76656017,
        "body_markdown": "I’m trying to merge these objects (preferably appending arrays from common x values) and not having any luck. I realize this is a noop but it’s the closest thing to what I think I want that doesn’t error:\r\n\r\n    jq -n -rSC &#39;def data: {&quot;a&quot;: {&quot;x&quot;: &quot;t&quot;, &quot;y&quot;: [&quot;a&quot;,&quot;b&quot;]}, &quot;b&quot;: {&quot;x&quot;: &quot;t&quot;, &quot;y&quot;: [&quot;c&quot;,&quot;d&quot;]}, &quot;c&quot;: {&quot;x&quot;: &quot;r&quot;, &quot;y&quot;: [&quot;a&quot;,&quot;c&quot;]}}; data | .[] | reduce . as $item ({}; . + $item)&#39;\r\n    {\r\n        &quot;x&quot;: &quot;t&quot;,\r\n        &quot;y&quot;: [\r\n            &quot;a&quot;,\r\n            &quot;b&quot;\r\n        ]\r\n    }\r\n    {\r\n        &quot;x&quot;: &quot;t&quot;,\r\n        &quot;y&quot;: [\r\n            &quot;c&quot;,\r\n            &quot;d&quot;\r\n        ]\r\n    }\r\n    {\r\n        &quot;x&quot;: &quot;r&quot;,\r\n        &quot;y&quot;: [\r\n            &quot;a&quot;,\r\n            &quot;c&quot;\r\n        ]\r\n    }\r\n\r\nExpected output would be:\r\n\r\n    {\r\n        &quot;x&quot;: &quot;t&quot;,\r\n        &quot;y&quot;: [\r\n            [\r\n                &quot;a&quot;,\r\n                &quot;b”\r\n            ],\r\n            [\r\n                &quot;c&quot;,\r\n                &quot;d&quot;\r\n            ]\r\n        ]\r\n    }\r\n    {\r\n        &quot;x&quot;: &quot;r&quot;,\r\n        &quot;y&quot;: [\r\n            [\r\n                &quot;a&quot;,\r\n                &quot;c&quot;\r\n            ]\r\n        ]\r\n    }\r\n\r\nThis is example code. What I’d really like is this merged:\r\n\r\n    gcloud compute snapshots list --project &quot;foo&quot; --format=json | jq -rSC &#39;.[] | select((.sourceDisk | test(&quot;data-disk$&quot;)) and (.autoCreated | true)) | {(.sourceDisk | match(&quot;/([^/]+$)&quot;).captures[0].string): [.diskSizeGb, .name, .creationTimestamp]}&#39;\r\n\r\nI’m kinda good with any outputs from the gcloud command that allows me to have snapshot data for an instance under one object. But I’m hoping it’s pretty similar to my example data. \r\n\r\nI’ve tried simple add, the above reduces, map/map_value",
        "link": "https://stackoverflow.com/questions/76656017/jq-merge-data-from-different-objects",
        "title": "jq merge data from different objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4879,
                    "reputation": 248190,
                    "user_id": 7552,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b60298053f87465641c1b1192338c8cd?s=256&d=identicon&r=PG",
                    "display_name": "glenn jackman",
                    "link": "https://stackoverflow.com/users/7552/glenn-jackman"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1689102606,
                "post_id": 76665077,
                "comment_id": 135164952,
                "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": 1689103029,
                "post_id": 76665077,
                "comment_id": 135165009,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 213235,
                    "reputation": 1077,
                    "user_id": 466521,
                    "user_type": "registered",
                    "accept_rate": 53,
                    "profile_image": "https://www.gravatar.com/avatar/e4df17dcfcd4ddba26238037a33ec950?s=256&d=identicon&r=PG",
                    "display_name": "Yogi",
                    "link": "https://stackoverflow.com/users/466521/yogi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689103239,
                "post_id": 76665077,
                "comment_id": 135165054,
                "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": 4,
                "creation_date": 1689103522,
                "post_id": 76665077,
                "comment_id": 135165115,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1709776373,
                "last_edit_date": 1709776373,
                "creation_date": 1689103611,
                "answer_id": 76665197,
                "question_id": 76665077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming your input looks like this:\r\n```json\r\n{\r\n  &quot;outer1&quot;: {\r\n    &quot;outer2&quot;: {\r\n      &quot;outer3&quot;: {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n      },\r\n      &quot;outer4&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\n```\r\n\r\nYou could use the `--stream` option to read the input as a stream of path-value pairs. For instance:\r\n```sh\r\njq --stream -n &#39;\r\n  reduce (inputs | select(has(1))) as [$path, $val] ({};\r\n    .[$path[:-1] | join(&quot;.&quot;)][$path[-1]] = $val\r\n  )\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;outer1.outer2.outer3&quot;: {\r\n    &quot;key1&quot;: &quot;value1&quot;,\r\n    &quot;key2&quot;: &quot;value2&quot;\r\n  },\r\n  &quot;outer1.outer2.outer4&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\nNext, format this JSON according to your needs. For example using `to_entries` for both levels:\r\n```sh\r\njq --stream -nr &#39;\r\n  reduce (inputs | select(has(1))) as [$path, $val] ({};\r\n    .[$path[:-1] | join(&quot;.&quot;)][$path[-1]] = $val\r\n  )\r\n  | to_entries[] | &quot;[\\(.key)]&quot;, (\r\n      .value | to_entries[] | &quot;\\(.key) = \\(.value)&quot;\r\n    ), &quot;&quot;\r\n&#39;\r\n```\r\n```\r\n[outer1.outer2.outer3]\r\nkey1 = value1\r\nkey2 = value2\r\n\r\n[outer1.outer2.outer4]\r\nkey1 = value1\r\nkey2 = value2\r\n\r\n```\r\n\r\n---\r\n\r\nAlternatively, combine both steps into a single `foreach` iteration with a sliding context window as state:\r\n```sh\r\njq --stream -nr &#39;\r\n  foreach (inputs | select(has(1))) as [$path, $val] ([];\r\n    [last, ($path[:-1] | join(&quot;.&quot;))];\r\n    (select(first != last) | &quot;\\n[\\(last)]&quot;), &quot;\\($path[-1]) = \\($val)&quot;\r\n  )                                                              \r\n&#39;\r\n```\r\n",
                "title": "Get all nested keys and values using jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1689107178,
                "creation_date": 1689107178,
                "answer_id": 76665539,
                "question_id": 76665077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My take is this:\r\n\r\n    . as $data\r\n    | [ path(.. | scalars) ]\r\n    | map( . as $p | { prefix: $p[0:-1]|join(&quot;.&quot;), key: $p[-1], value: $data | getpath($p) })\r\n    | group_by(.prefix)[]\r\n    | &quot;[\\(first.prefix)]&quot;, (.[] | &quot;\\(.key)=\\(.value)&quot;)\r\n\r\nBasically:\r\n\r\n - find all scalars,\r\n - get the paths to these scalars (like `[&quot;outer1&quot;,&quot;outer2&quot;,&quot;outer3&quot;,&quot;key1&quot;]`)\r\n - create intermediate representation of the path splitted into a prefix like `outer1.outer2.outer3`), a key (`key1`) and the actual value (`value1`)\r\n - group these using the prefix\r\n - format",
                "title": "Get all nested keys and values using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689155272,
                "creation_date": 1689155272,
                "answer_id": 76669255,
                "question_id": 76665077,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you are trying to generate a TOML-encoded document, also consider employing [kislyuk/yq](https://github.com/kislyuk/yq), which is a `jq` wrapper for processing (YAML, XML, and) TOML documents. The TOML processor is called `tomlq`, and it transcodes between TOML and JSON, so that `jq` filters can be applied directly. For your use-case, though, the filter only needs to emit the contents of a variable which is populated with the contents of your JSON input file using jq&#39;s `--argfile` option (because reading from `stdin` and direct file arguments are expected to be TOML-encoded, thus the use of `-n`). Eventually, the `-t` option converts the (final) JSON document (back) to TOML. The output slightly differs from your desired output, but if your goal is to produce a TOML document, you could benefit from `tomlq` automatically providing for a valid and well-formed structure.\r\n\r\n```sh\r\ntomlq -n -t &#39;$f&#39; --argfile f file.json\r\n```\r\n```toml\r\n[outer1.outer2]\r\n[outer1.outer2.outer3]\r\nkey1 = &quot;value1&quot;\r\nkey2 = &quot;value2&quot;\r\n\r\n[outer1.outer2.outer4]\r\nkey1 = &quot;value1&quot;\r\nkey2 = &quot;value2&quot;\r\n```",
                "title": "Get all nested keys and values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1709776373,
        "creation_date": 1689102509,
        "last_edit_date": 1689103361,
        "question_id": 76665077,
        "body_markdown": "I have a json like this\r\n```lang-json\r\n{\r\n  &quot;outer1&quot;: {\r\n    &quot;outer2&quot;: {\r\n      &quot;outer3&quot;: {\r\n        &quot;key1&quot;: &quot;value1&quot;,\r\n        &quot;key2&quot;: &quot;value2&quot;\r\n      }\r\n    },\r\n    &quot;outer4&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 want output to be\r\n\r\n    [outer1.outer2.outer3]\r\n    key1 = value1\r\n    key2 = value2\r\n\r\n    [outer1.outer2.outer4]\r\n    key1 = value1\r\n    key2 = value2\r\n\r\n I tried `jq -r &#39;to_entries|map(&quot;\\(.key)=\\(.value|tostring)&quot;)|.[]&#39; test.json` But its not what is what I want exactly",
        "link": "https://stackoverflow.com/questions/76665077/get-all-nested-keys-and-values-using-jq",
        "title": "Get all nested keys and values using jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1689154215,
                "post_id": 76669053,
                "comment_id": 135171856,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689154491,
                "post_id": 76669053,
                "comment_id": 135171930,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 28357147,
                    "reputation": 19,
                    "user_id": 21687706,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/655f60885884bb945b56bff54bf3c2b6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "basant",
                    "link": "https://stackoverflow.com/users/21687706/basant"
                },
                "reply_to_user": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689154904,
                "post_id": 76669053,
                "comment_id": 135172042,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12394743,
                    "reputation": 7421,
                    "user_id": 12607443,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0a01593ffab5a11f0d29d1ee09120801?s=256&d=identicon&r=PG",
                    "display_name": "Ivan",
                    "link": "https://stackoverflow.com/users/12607443/ivan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689155242,
                "post_id": 76669053,
                "comment_id": 135172104,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689170934,
                "creation_date": 1689170934,
                "answer_id": 76671491,
                "question_id": 76669053,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With jq, you could read in the values of the `metrics` array using the `--args` option, then reference them with `$ARGS.positional[]`, and extract the desired values from the input data in `$json_input` using `.[…].score` and the `-r` flag:\r\n```sh\r\njq -r &#39;.[$ARGS.positional[]].score&#39; --args &quot;${metrics[@]}&quot; &lt;&lt;&lt; &quot;$json_input&quot;\r\n```\r\n```\r\n1\r\n0.92\r\n0.95\r\n0.33\r\n0.83\r\n```\r\n\r\nBack in Bash, you could then take that output, and iterate over each line for further processing. For example:\r\n```sh\r\nwhile read -r score\r\ndo printf &quot;Score: %s\\n&quot; &quot;$score&quot;\r\ndone &lt; &lt;(\r\n  jq -r &#39;.[$ARGS.positional[]].score&#39; --args &quot;${metrics[@]}&quot; &lt;&lt;&lt; &quot;$json_input&quot;\r\n)\r\n```\r\n```\r\nScore: 1\r\nScore: 0.92\r\nScore: 0.95\r\nScore: 0.33\r\nScore: 0.83\r\n```",
                "title": "Iterate over json object/ json string and get only those values present in the array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689170934,
        "creation_date": 1689154036,
        "last_edit_date": 1689156491,
        "question_id": 76669053,
        "body_markdown": "I have a simple requirement, where in I want to output the value of each title and score from the sample json,   \r\nI want to iterate over the metrics array and for each entry of the array, I want to look into the json_input and get the value of score from it.\r\n\r\n    json_input=&#39;{\r\n        &quot;performance&quot;: {\r\n          &quot;title&quot;: &quot;Performance&quot;,\r\n          &quot;score&quot;: 0.95\r\n        },\r\n        &quot;accessibility&quot;: {\r\n          &quot;title&quot;: &quot;Accessibility&quot;,\r\n          &quot;score&quot;: 1\r\n        },\r\n        &quot;bestPractices&quot;: {\r\n          &quot;title&quot;: &quot;Best Practices&quot;,\r\n          &quot;score&quot;: 0.92\r\n        },\r\n        &quot;seo&quot;: {\r\n          &quot;title&quot;: &quot;SEO&quot;,\r\n          &quot;score&quot;: 0.83\r\n        },\r\n        &quot;progressiveWebApp&quot;: {\r\n          &quot;title&quot;: &quot;PWA&quot;,\r\n          &quot;score&quot;: 0.33\r\n      }\r\n    }&#39;\r\n    \r\n    metrics=(&quot;accessibility&quot; &quot;bestPractices&quot; &quot;performance&quot; &quot;progressiveWebApp&quot; &quot;seo&quot;)\r\n    \r\n    # iterate over metrics array and get the score from json_input\r\n    \r\n    for metric in &quot;${metrics[@]}&quot;; do\r\n      echo &quot;${metric}&quot; \r\n    \r\n    done",
        "link": "https://stackoverflow.com/questions/76669053/iterate-over-json-object-json-string-and-get-only-those-values-present-in-the-a",
        "title": "Iterate over json object/ json string and get only those values present in the array"
    },
    {
        "tags": [
            "json",
            "object",
            "select",
            "nested",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689185178,
                "last_edit_date": 1689185178,
                "creation_date": 1689183612,
                "answer_id": 76673183,
                "question_id": 76673014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=` instead of `|` to update without losing the overall structure. Also, use `IN` (instead of `&#236;n`) to test if a value is contained in a given set. All put together:\r\n\r\n```sh\r\n{image, os, resources, summary}\r\n| .resources[].resource |= with_entries(select(IN(.key; &quot;name&quot;, &quot;version&quot;)))\r\n| .resources[].checks[] |= with_entries(select(IN(.key; &quot;name&quot;, &quot;description&quot;)))\r\n```\r\n```json\r\n{\r\n  &quot;image&quot;: &quot;test&quot;,\r\n  &quot;os&quot;: &quot;rhel&quot;,\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;binutils&quot;,\r\n        &quot;version&quot;: &quot;2.35.2-37.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;check3&quot;,\r\n          &quot;description&quot;: &quot;third check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dbus&quot;,\r\n        &quot;version&quot;: &quot;1:1.12.20-7.el9_1&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dmidecode&quot;,\r\n        &quot;version&quot;: &quot;1:3.3-7.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;gcc&quot;,\r\n        &quot;version&quot;: &quot;11.3.1-4.3.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: []\r\n    }\r\n  ],\r\n  &quot;summary&quot;: null\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/_gbkc4jlj68)\r\n\r\nNow, you could further factor out `.resources[]` from the loops to prevent double iteration, and, apparently, therein you also want to filter for `{resource, checks}` (to remove `.installed`):\r\n\r\n```sh\r\n{image, os, resources, summary} | .resources[] |= (\r\n  {resource, checks}\r\n  | .resource |= with_entries(select(IN(.key; &quot;name&quot;, &quot;version&quot;)))\r\n  | .checks[] |= with_entries(select(IN(.key; &quot;name&quot;, &quot;description&quot;)))\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;image&quot;: &quot;test&quot;,\r\n  &quot;os&quot;: &quot;rhel&quot;,\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;binutils&quot;,\r\n        &quot;version&quot;: &quot;2.35.2-37.el9&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;check3&quot;,\r\n          &quot;description&quot;: &quot;third check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dbus&quot;,\r\n        &quot;version&quot;: &quot;1:1.12.20-7.el9_1&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dmidecode&quot;,\r\n        &quot;version&quot;: &quot;1:3.3-7.el9&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;gcc&quot;,\r\n        &quot;version&quot;: &quot;11.3.1-4.3.el9&quot;\r\n      },\r\n      &quot;checks&quot;: []\r\n    }\r\n  ],\r\n  &quot;summary&quot;: null\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/o8p_XMtl6Ps)\r\n\r\n---\r\nAlternatively (instead of updating with `|=`), use a constructive approach, and directly set everything you want to be contained (with using `map` on arrays):\r\n\r\n```sh\r\n{\r\n  image, os, &quot;resources&quot;: .resources | map({\r\n    &quot;resource&quot;: .resource | with_entries(select(IN(.key; &quot;name&quot;, &quot;version&quot;))),\r\n    &quot;checks&quot;: .checks | map(with_entries(select(IN(.key; &quot;name&quot;, &quot;description&quot;))))\r\n  }), summary\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/CkqJylvThz4)",
                "title": "JQ: How to select only some elements in multi-level nested JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689227758,
                "creation_date": 1689227758,
                "answer_id": 76676314,
                "question_id": 76673014,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As an alternative, you could construct the objects by picking out the properties you want to keep. Then filter down at each level.\r\n\r\n```\r\n{image, os, resources, check_summary}\r\n  | .resources[] |= ({resource, checks}\r\n    | .resource |= {name, version}\r\n    | .checks[] |= {name, description}\r\n  )\r\n```\r\n\r\nOr more directly, construct your result picking out the properties at the start.\r\n\r\n```\r\n{\r\n    image,\r\n    os,\r\n    resources: .resources | map({\r\n        resource: .resource | {name, version},\r\n        checks: .checks | map({name, description})\r\n    }),\r\n    check_summary\r\n}\r\n```\r\n\r\nThese approaches does have the disadvantage however that it will retain non-existent properties and set them to `null`. You could remove them at the end by deleting those properties that are `null`.\r\n\r\n```\r\n| del(.. | select(. == null))\r\n```",
                "title": "JQ: How to select only some elements in multi-level nested JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1689227758,
        "creation_date": 1689182143,
        "question_id": 76673014,
        "body_markdown": "This is a bit long, but I am at a loss how to glue together multiple jq queries to filter out nested objects in a multi-level structure.\r\n\r\nI am starting with JSON that looks like this.\r\n```\r\n{\r\n  &quot;image&quot;: &quot;test&quot;,\r\n  &quot;duration&quot;: 40,\r\n  &quot;image_size&quot;: 2758644359,\r\n  &quot;os&quot;: &quot;rhel&quot;,\r\n  &quot;version&quot;: &quot;9.2&quot;,\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;binutils&quot;,\r\n        &quot;version&quot;: &quot;2.35.2-37.el9&quot;,\r\n        &quot;src_version&quot;: &quot;2.35.2-37.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 5.5\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 4.7\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;check3&quot;,\r\n          &quot;description&quot;: &quot;third check&quot;,\r\n          &quot;severity&quot;: &quot;low&quot;,\r\n          &quot;depth&quot;: 4.2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;dbus&quot;,\r\n        &quot;version&quot;: &quot;1:1.12.20-7.el9_1&quot;,\r\n        &quot;src_version&quot;: &quot;1:1.12.20-7.el9_1&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 6.2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;dmidecode&quot;,\r\n        &quot;version&quot;: &quot;1:3.3-7.el9&quot;,\r\n        &quot;src_version&quot;: &quot;1:3.3-7.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 5.5\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 7.1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;gcc&quot;,\r\n        &quot;version&quot;: &quot;11.3.1-4.3.el9&quot;,\r\n        &quot;src_version&quot;: &quot;11.3.1-4.3.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n      ]\r\n    }\r\n  ],\r\n  &quot;image_assurance_results&quot;: {},\r\n  &quot;check_summary&quot;: {\r\n    &quot;total&quot;: 6,\r\n    &quot;low&quot;: 1,\r\n    &quot;moderate&quot;: 5\r\n  },\r\n  &quot;initiating_user&quot;: &quot;test_user&quot;\r\n}\r\n\r\n```\r\nI want to preserve the overall structure and pick off selected elements from the top level as well as the two nested levels in the arrays. This is my desired result.\r\n```\r\n{\r\n  &quot;image&quot;: &quot;test&quot;,\r\n  &quot;os&quot;: &quot;rhel&quot;,\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;binutils&quot;,\r\n        &quot;version&quot;: &quot;2.35.2-37.el9&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;check3&quot;,\r\n          &quot;description&quot;: &quot;third check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dbus&quot;,\r\n        &quot;version&quot;: &quot;1:1.12.20-7.el9_1&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;dmidecode&quot;,\r\n        &quot;version&quot;: &quot;1:3.3-7.el9&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;name&quot;: &quot;gcc&quot;,\r\n        &quot;version&quot;: &quot;11.3.1-4.3.el9&quot;\r\n      },\r\n      &quot;checks&quot;: [\r\n      ]\r\n    }\r\n  ],\r\n  &quot;check_summary&quot;: {\r\n    &quot;total&quot;: 6,\r\n    &quot;low&quot;: 1,\r\n    &quot;moderate&quot;: 5\r\n  }\r\n}\r\n```\r\n\r\nWith this query I can eliminate the top level elements that I don&#39;t want, retaining the full element set under resources:\r\n`jq &#39;{image, os, resources, summary}&#39;`\r\nAnd get this result\r\n```\r\n{\r\n  &quot;image&quot;: &quot;test&quot;,\r\n  &quot;os&quot;: &quot;rhel&quot;,\r\n  &quot;resources&quot;: [\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;binutils&quot;,\r\n        &quot;version&quot;: &quot;2.35.2-37.el9&quot;,\r\n        &quot;src_version&quot;: &quot;2.35.2-37.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 5.5\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 4.7\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;check3&quot;,\r\n          &quot;description&quot;: &quot;third check&quot;,\r\n          &quot;severity&quot;: &quot;low&quot;,\r\n          &quot;depth&quot;: 4.2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;dbus&quot;,\r\n        &quot;version&quot;: &quot;1:1.12.20-7.el9_1&quot;,\r\n        &quot;src_version&quot;: &quot;1:1.12.20-7.el9_1&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 6.2\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;dmidecode&quot;,\r\n        &quot;version&quot;: &quot;1:3.3-7.el9&quot;,\r\n        &quot;src_version&quot;: &quot;1:3.3-7.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;check1&quot;,\r\n          &quot;description&quot;: &quot;first check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 5.5\r\n        },\r\n        {\r\n          &quot;description&quot;: &quot;second check&quot;,\r\n          &quot;severity&quot;: &quot;moderate&quot;,\r\n          &quot;depth&quot;: 7.1\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;resource&quot;: {\r\n        &quot;format&quot;: &quot;rpm&quot;,\r\n        &quot;name&quot;: &quot;gcc&quot;,\r\n        &quot;version&quot;: &quot;11.3.1-4.3.el9&quot;,\r\n        &quot;src_version&quot;: &quot;11.3.1-4.3.el9&quot;\r\n      },\r\n      &quot;installed&quot;: true,\r\n      &quot;checks&quot;: []\r\n    }\r\n  ],\r\n  &quot;summary&quot;: null\r\n}\r\n```\r\n\r\nAnd with this query I can filter out the elements I don&#39;t want down in the nested &quot;checks&quot; objects\r\n`jq &#39;.resources[].checks[] | with_entries(select(.key | in({&quot;name&quot;:1, &quot;description&quot;:1})))&#39;`\r\n```\r\n{\r\n  &quot;name&quot;: &quot;check1&quot;,\r\n  &quot;description&quot;: &quot;first check&quot;\r\n}\r\n{\r\n  &quot;description&quot;: &quot;second check&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;check3&quot;,\r\n  &quot;description&quot;: &quot;third check&quot;\r\n}\r\n{\r\n  &quot;description&quot;: &quot;second check&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;check1&quot;,\r\n  &quot;description&quot;: &quot;first check&quot;\r\n}\r\n{\r\n  &quot;description&quot;: &quot;second check&quot;\r\n}\r\n\r\n```\r\nBut I can&#39;t figure out how to pipe these two queries together to get the desired end result and add in one more operation to eliminate some of the top level elements under resource. How do I apply the with_entries filter to the initial down select of the top level?",
        "link": "https://stackoverflow.com/questions/76673014/jq-how-to-select-only-some-elements-in-multi-level-nested-json",
        "title": "JQ: How to select only some elements in multi-level nested JSON"
    },
    {
        "tags": [
            "json",
            "windows",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15204726,
                    "reputation": 18070,
                    "user_id": 10971581,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/XPQr1.png?s=256",
                    "display_name": "jhnc",
                    "link": "https://stackoverflow.com/users/10971581/jhnc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689197199,
                "post_id": 76673859,
                "comment_id": 135181083,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1689932106,
                "creation_date": 1689932106,
                "answer_id": 76736770,
                "question_id": 76673859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The easiest way to deal with the Windows quote issues is to put the jq filter code into a file and call it with -f. When you do this you can use the same code that works on Linux.",
                "title": "Split/Slice large JSON file in Windows using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1689932106,
        "creation_date": 1689189836,
        "question_id": 76673859,
        "body_markdown": "I have some very large (20-100GB) JSON files that I need to split into smaller files. I found the link below for doing so on Linux, but I am working on Windows. I have jq and it works, but I am not fluent enough to be able to write the requisite code. Could someone please translate the Linux answer to Windows for me?\r\n\r\n&lt;https://stackoverflow.com/questions/70627447/split-slice-large-json-using-jq&gt;",
        "link": "https://stackoverflow.com/questions/76673859/split-slice-large-json-file-in-windows-using-jq",
        "title": "Split/Slice large JSON file in Windows using jq"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689260875,
                "post_id": 76680728,
                "comment_id": 135191326,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1689259661,
                "creation_date": 1689259661,
                "answer_id": 76680729,
                "question_id": 76680728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well okay one way to do it is like this:\r\n\r\n    jq -c . INPUT.JSONL  | head -n 1 | jq\r\n\r\nThe -c option says to output the entries one per line, then `head` gets the first line, then we pretty-print it again with jq. Surely there is a way to do this with just a single invokation of jq?",
                "title": "Get the first JSON object from a file containing a sequence of JSON objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689261488,
                "creation_date": 1689261488,
                "answer_id": 76681001,
                "question_id": 76680728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For an input file like\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;c&quot;: &quot;d&quot;\r\n}\r\n```\r\n\r\nyou could\r\n\r\n- slurp the entire input and then print the first array element:\r\n\r\n  ```sh\r\n  $ jq -s &#39;.[0]&#39; in.json \r\n  {\r\n    &quot;a&quot;: &quot;b&quot;\r\n  }\r\n  ```\r\n\r\n- use null-input, and then `inputs`:\r\n\r\n  ```sh\r\n  $ jq -n &#39;[inputs][0]&#39; in.json \r\n  {\r\n    &quot;a&quot;: &quot;b&quot;\r\n  }\r\n",
                "title": "Get the first JSON object from a file containing a sequence of JSON objects"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1689261687,
                "creation_date": 1689261687,
                "answer_id": 76681021,
                "question_id": 76680728,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Null input (`-n`) is useful in such a case:\r\n\r\n```\r\njq -n &#39;input&#39; file.json\r\n```\r\n\r\nThe [`input` filter](https://jqlang.github.io/jq/manual/#input) will read a single JSON element from the provided input stream.\r\n\r\nExample:\r\n\r\n```\r\njq -n &#39;input&#39; &lt;&lt;JSON\r\n{ &quot;first element&quot;: [ 1, 2 ] }\r\n{ &quot;second element&quot;: [ 3, 4, 5 ] }\r\nJSON\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{\r\n  &quot;first element&quot;: [\r\n    1,\r\n    2\r\n  ]\r\n}\r\n```",
                "title": "Get the first JSON object from a file containing a sequence of JSON objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1689313741,
        "creation_date": 1689259661,
        "last_edit_date": 1689313741,
        "question_id": 76680728,
        "body_markdown": "I have a file containing a sequence of json objects. Using the jq tool, how can I get the first json object from that file?\r\n\r\nI have tried `jq limit(1; .) input.jsonl` but that limits the length of each individual object in the file, rather than giving me just the first object. I have also read through the whole of the jq man page! Maybe I missed something.",
        "link": "https://stackoverflow.com/questions/76680728/get-the-first-json-object-from-a-file-containing-a-sequence-of-json-objects",
        "title": "Get the first JSON object from a file containing a sequence of JSON objects"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689320212,
                "post_id": 76683161,
                "comment_id": 135199528,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1689302585,
                "last_edit_date": 1689302585,
                "creation_date": 1689292911,
                "answer_id": 76683944,
                "question_id": 76683161,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With [tag:jq]\r\n\r\n```sh\r\nif val=$(curl ... \\\r\n         | jq &#39;try \r\n                 if .data != null \r\n                   then . \r\n                   else (&quot;is null&quot; | halt_error) \r\n                 end \r\n               catch\r\n                 (&quot;not an object&quot; | halt_error)\r\n            &#39; 2&gt;&amp;1\r\n        )\r\nthen\r\n    do_something_with_valid &quot;$val&quot;\r\nelse\r\n    echo &quot;error: $val&quot; &gt;&amp;2\r\n    exit 1\r\nfi\r\n```\r\n\r\n\r\n\r\n",
                "title": "Adding a check to find if returned value is not an object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1689302585,
        "creation_date": 1689281483,
        "last_edit_date": 1689283270,
        "question_id": 76683161,
        "body_markdown": "I have a variable that retrieves value as below:\r\n\r\n    val = $(curl command ...)\r\n\r\n`val` returns an object which looks as `{&quot;parm1&quot;:&quot;****&quot;,&quot;data&quot;:&quot;adfsdfsdaf&quot;}`\r\n\r\nI want to add a validation for two conditions:\r\n - `val` is either an object  or \r\n - `val.data` is `null`\r\n\r\nI want to print a message &quot;data not parsed correctly&quot;\r\n\r\n - when `val` is an `object` such as `{&quot;parm1&quot;:&quot;****&quot;,&quot;data&quot;:&quot;adfsdfsdaf&quot;}`\r\n\r\nI want to print a message &quot;data is null&quot; \r\n\r\n - when `val` is an `null`.\r\n\r\nI have written below logic for it but it is not looking correct:\r\n\r\n    if [[ ${val} == null ]]; then\r\n      echo &quot;data not parsed correctly&quot;\r\n      exit 1\r\n\r\nThe correct value of `val` is `adfsdfsdaf` when the script should not exit.\r\n",
        "link": "https://stackoverflow.com/questions/76683161/adding-a-check-to-find-if-returned-value-is-not-an-object",
        "title": "Adding a check to find if returned value is not an object"
    },
    {
        "tags": [
            "json",
            "stripe-payments",
            "jq",
            "webhooks",
            "digital-signature"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21427599,
                    "reputation": 2013,
                    "user_id": 15784650,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91e2aa2f9ab2f665f7f0962c481fa626?s=256&d=identicon&r=PG",
                    "display_name": "Jonathan Steele",
                    "link": "https://stackoverflow.com/users/15784650/jonathan-steele"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689332870,
                "post_id": 76686882,
                "comment_id": 135201869,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27496581,
                    "reputation": 69,
                    "user_id": 20981004,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bb70921d961725f1ef4179539da7f89d?s=256&d=identicon&r=PG",
                    "display_name": "sujay777",
                    "link": "https://stackoverflow.com/users/20981004/sujay777"
                },
                "reply_to_user": {
                    "account_id": 21427599,
                    "reputation": 2013,
                    "user_id": 15784650,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91e2aa2f9ab2f665f7f0962c481fa626?s=256&d=identicon&r=PG",
                    "display_name": "Jonathan Steele",
                    "link": "https://stackoverflow.com/users/15784650/jonathan-steele"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689335090,
                "post_id": 76686882,
                "comment_id": 135202319,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21427599,
                    "reputation": 2013,
                    "user_id": 15784650,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/91e2aa2f9ab2f665f7f0962c481fa626?s=256&d=identicon&r=PG",
                    "display_name": "Jonathan Steele",
                    "link": "https://stackoverflow.com/users/15784650/jonathan-steele"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689676225,
                "post_id": 76686882,
                "comment_id": 135244221,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1689330879,
        "creation_date": 1689330879,
        "question_id": 76686882,
        "body_markdown": "I am trying to verify webhook signature for certain webhook events for Stripe Application, but I am getting -  \r\n\r\n    401 - Unauthorized\tNo valid API key provided.\r\n\r\nBelow is my PolicyInbound [security policy for webhook] for Stripe -\r\n\r\n    &quot;policyInbound&quot;: {\r\n          &quot;type&quot;: &quot;managed&quot;,\r\n          &quot;policy&quot;: &quot;DIGITAL_SIGNATURE&quot;,\r\n          &quot;securityProperties&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;signatureFunction&quot;,\r\n              &quot;displayName&quot;: &quot;Signature Statement&quot;,\r\n              &quot;hidden&quot;: true,\r\n              &quot;required&quot;: true,\r\n              &quot;fixed&quot;: &quot;\\&quot;sha256=\\&quot;+connectivity::hex(connectivity::HMAC(\\&quot;SHA256\\&quot;; .securityProperties.secret;  .request.headers.\\&quot;stripe-signature\\&quot; + .request.body))&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;signatureLocation&quot;,\r\n              &quot;displayName&quot;: &quot;Request Signature Location&quot;,\r\n              &quot;hidden&quot;: true,\r\n              &quot;required&quot;: true,\r\n              &quot;fixed&quot;: &quot;.request.headers.\\&quot;stripe-signature\\&quot;&quot;\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;signKey&quot;,\r\n              &quot;displayName&quot;: &quot;secret&quot;,\r\n              &quot;hidden&quot;: false,\r\n              &quot;required&quot;: true\r\n            }\r\n          ]\r\n        }\r\n Below is my Trigger for Event Subscription -\r\n\r\n    &quot;CreateCustomerTrigger&quot;: {\r\n      &quot;displayName&quot;: &quot;Subscribe to a Create Customer event&quot;,\r\n      &quot;description&quot;: &quot;This trigger detects when an event has been raised.&quot;,\r\n      &quot;group&quot;: &quot;simple&quot;,\r\n      &quot;type&quot;: &quot;webhook&quot;,\r\n      &quot;httpMethod&quot;: &quot;POST&quot;,\r\n      &quot;request&quot;: {\r\n        &quot;schemaType&quot;: &quot;application/json&quot;,\r\n        &quot;schema&quot;: {\r\n          &quot;$ref&quot;: &quot;#/schemas/CustomerCreationResponseBodySchema&quot;\r\n        }\r\n      },\r\n      &quot;webhook&quot;: {\r\n        &quot;headers&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;stripe-signature&quot;,\r\n            &quot;type&quot;: &quot;string&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;user-agent&quot;,\r\n            &quot;type&quot;: &quot;string&quot;\r\n          }\r\n        ],\r\n        &quot;body&quot;: {\r\n          &quot;schemaType&quot;: &quot;application/json&quot;,\r\n          &quot;schema&quot;: {\r\n            &quot;$ref&quot;: &quot;#/schemas/CustomerCreationResponseBodySchema&quot;\r\n          }\r\n        }\r\n      },\r\n      &quot;subscription&quot;: {\r\n        &quot;register&quot;: &quot;flow:CreateAWebhookEndpointFlow&quot;,\r\n        &quot;deregister&quot;: &quot;flow:DeleteAWebhookEndpointFlow&quot;\r\n      }\r\n    }\r\n\r\n Below is my Webhook Subscription Flow - \r\n\r\n    &quot;CreateAWebhookEndpointFlow&quot;: {\r\n      &quot;id&quot;: &quot;CreateAWebhookEndpointFlow&quot;,\r\n      &quot;version&quot;: &quot;0.1&quot;,\r\n      &quot;start&quot;: &quot;startState&quot;,\r\n      &quot;specVersion&quot;: &quot;0.8&quot;,\r\n      &quot;functions&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;CreateAWebhookEndpointFunction&quot;,\r\n          &quot;operation&quot;: &quot;connectivity::rest&quot;,\r\n          &quot;type&quot;: &quot;custom&quot;\r\n        }\r\n      ],\r\n      &quot;states&quot;: [\r\n        {\r\n          &quot;actions&quot;: [\r\n            {\r\n              &quot;functionRef&quot;: {\r\n                &quot;refName&quot;: &quot;CreateAWebhookEndpointFunction&quot;,\r\n                &quot;arguments&quot;: {\r\n                  &quot;uri&quot;: &quot;https://api.stripe.com/v1/webhook_endpoints?enabled_events[0]=customer.created&amp;url={url}&quot;,\r\n                  &quot;method&quot;: &quot;POST&quot;,\r\n                  &quot;headers&quot;: &quot;${ .input.headers }&quot;,\r\n                  &quot;parameters&quot;: {\r\n                    &quot;url&quot;: &quot;${xyz_url}&quot;\r\n                  }\r\n                }\r\n              },\r\n              &quot;actionDataFilter&quot;: {\r\n                &quot;results&quot;: &quot;${ { body: .body, headers: .headers } }&quot;,\r\n                &quot;toStateData&quot;: &quot;${ .output }&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;name&quot;: &quot;startState&quot;,\r\n          &quot;type&quot;: &quot;operation&quot;,\r\n          &quot;end&quot;: true\r\n        }\r\n      ]\r\n    }\r\n\r\nPlease suggest me how can I provide JSON JQ to verify Stripe Signature with respect to any Integration URL of Workato, Dellboomi or Celigo.",
        "link": "https://stackoverflow.com/questions/76686882/how-to-verify-stripe-webhook-signature-manually-using-json-jq-expressions",
        "title": "How to verify Stripe Webhook Signature manually using JSON JQ Expressions?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1689469707,
                "post_id": 76696095,
                "comment_id": 135217869,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1689526073,
                "last_edit_date": 1689526073,
                "creation_date": 1689466945,
                "answer_id": 76696254,
                "question_id": 76696095,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Clever. The easiest way to amend your code to work is to change `[0]` to `.0`, and then match integers and cast them to numbers.\r\n\r\n```jq\r\n#!/usr/bin/jq -rn\r\n\r\n[\r\n  &quot;creation_date&quot;,\r\n  &quot;data.transactionType&quot;,\r\n  &quot;data.location.zoneId&quot;,\r\n  &quot;data.media.typeCode&quot;,\r\n  &quot;data.media.postPaymentEvent.0.transactionDate&quot;,\r\n  &quot;id&quot;\r\n] as $h |\r\n\r\n$h,\r\n(inputs | ([getpath($h[] |\r\n                    . / &quot;.&quot; |\r\n                    map(if test(&quot;^[[:digit:]]+$&quot;)\r\n                        then tonumber\r\n                        else . end))\r\n           ])) | @csv\r\n```",
                "title": "jq convert an json array to csv"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1689534738,
        "creation_date": 1689462546,
        "last_edit_date": 1689534738,
        "question_id": 76696095,
        "body_markdown": "i try to format a .json file in .csv file\r\nmy json file is complex, it mixes arrays and bracket.\r\ni don&#39;t success to extract the array values\r\n\r\nhere is an extract of my json file than i want to format in csv file\r\n\r\n\r\n```json\r\n{\r\n  &quot;creation_date&quot;: &quot;2023/06/16 15:55:09&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;transactionType&quot;: &quot;val&quot;,\r\n    &quot;environment&quot;: &quot;1&quot;,\r\n    &quot;location&quot;: {\r\n      &quot;zoneId&quot;: 2\r\n    },\r\n    &quot;media&quot;: {\r\n      &quot;typeCode&quot;: 15,\r\n      &quot;postPaymentEvent&quot;: [\r\n        {\r\n          &quot;transactionDate&quot;: &quot;2022-12-26T16:50:00+01:00&quot;,\r\n          &quot;vehicleType&quot;: 1,\r\n          &quot;vehicleId&quot;: 1533\r\n        },\r\n        {\r\n          &quot;transactionDate&quot;: &quot;2022-12-27T16:31:00+01:00&quot;,\r\n          &quot;vehicleType&quot;: 1,\r\n          &quot;vehicleId&quot;: 1533\r\n        },\r\n        {\r\n          &quot;transactionDate&quot;: &quot;2022-12-28T15:50:00+01:00&quot;,\r\n          &quot;vehicleType&quot;: 1,\r\n          &quot;vehicleId&quot;: 1533\r\n        }\r\n      ]\r\n    },\r\n    &quot;deviceConfiguration&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;PLATFORM_PAR&quot;,\r\n        &quot;version&quot;: &quot;2.6&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;PLATFORM_SOFT&quot;,\r\n        &quot;version&quot;: &quot;2.6&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;id&quot;: &quot;000-0&quot;\r\n}\r\n```\r\n\r\nAnd my jq command, i want to get all the value, with and without array elements. I didn&#39;t get nothing when i get the value data.media.postPaymentEvent[0].transactionDate.\r\n\r\n```\r\njq --raw-output &#39;[ &quot;creation_date&quot;, &quot;data.transactionType&quot;,  &quot;data.location.zoneId&quot;, &quot;data.media.typeCode&quot;,  &quot;data.media.postPaymentEvent[0].transactionDate&quot;,  &quot;id&quot; ] as $h | $h, (. | [getpath($h[] / &quot;.&quot;)]) | @csv&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/76696095/jq-convert-an-json-array-to-csv",
        "title": "jq convert an json array to csv"
    }
]