[
    {
        "tags": [
            "bash",
            "adb",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695170608,
                "creation_date": 1695170608,
                "answer_id": 77138664,
                "question_id": 77138622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The shell&#39;s parameter expansion is not recursive.  When it expands `$command`, you just get its replacement text, as is.\r\n\r\nYou *could* get a second round a parameter expansion -- and all other expansions, redirections, *etc*. -- by running the resulting command text with `eval` instead of directly:\r\n```\r\neval &quot;$command&quot;\r\n```\r\nThat expands `&quot;$command&quot;` normally, then evaluates the result as if it were shell input.\r\n\r\n`eval` is dangerous and tricky.  Especially so when applied to data obtained externally from the script in which the `eval`uation is taking place.  I think what you&#39;re trying to accomplish is too clever by half, yet not half as well engineered as it should be for something of its kind.  I do not recommend proceeding down this path.\r\n\r\nMoreover, it&#39;s unclear what you think you&#39;re gaining from the internal parameterization, as the variable values are tightly associated with the command.  There&#39;s no customization available that way without editing the file, and if you&#39;re going to do that then you might as well just edit the command directly.\r\n",
                "title": "Bash / JQ - cant assign pull string and assign variable"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1695176861,
                "last_edit_date": 1695176861,
                "creation_date": 1695171839,
                "answer_id": 77138706,
                "question_id": 77138622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is not very elegant (see **More Elegant** below), and I&#39;m confident you&#39;ll get a better answer, but it&#39;s possible for `jq` to form the `command` string in one go using a filter like this.  Perhaps you can adapt it for your application.\r\n```jq\r\n.commands.play_music\r\n| .command as $cmd\r\n| .variables\r\n  | .device_directory.variable as $dir\r\n  | .music_file.variable as $file\r\n  | .audio_type.variable as $type\r\n| $cmd\r\n| sub(&quot;\\\\${device_directory}&quot;; $dir)\r\n| sub(&quot;\\\\${music_file}&quot;; $file)\r\n| sub(&quot;\\\\${audio_type}&quot;; $type)\r\n```\r\nOutput using your probable input:\r\n```\r\n&quot;adb shell am start -a android.intent.action.VIEW -d file:////Downloads/test.mp3 -t audio/mp3&quot;\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/pCWP6phsvbN &quot;Click me!&quot;).\r\n\r\n#### More Elegant\r\n\r\nThe same output is produced by this filter and is perhaps more adaptable to your application.\r\n```jq\r\n.commands.play_music\r\n| (.variables|map({k: .name, v: .variable})) as $vars\r\n| reduce $vars[] as $var (.command; .|sub(&quot;\\\\${\\($var.k)}&quot;; $var.v))\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/Bz3xY99I64d &quot;Click me too!&quot;).\r\n\r\n... and more incomprehensibly as:\r\n```jq\r\n.commands.play_music\r\n| reduce .variables[] as $var (.command; .|sub(&quot;\\\\${\\($var.name)}&quot;; $var.variable))\r\n```\r\n... still outputs:\r\n```\r\n&quot;adb shell am start -a android.intent.action.VIEW -d file:////Downloads/test.mp3 -t audio/mp3&quot;\r\n```\r\nTry this on [jqplay.org](https://jqplay.org/s/7OVHbGldgIr &quot;Click to see it work.&quot;).",
                "title": "Bash / JQ - cant assign pull string and assign variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1695176861,
        "creation_date": 1695169267,
        "question_id": 77138622,
        "body_markdown": "I am trying to write a script that will allow me to pull a command from a json file and use it in the script\r\n\r\nHere is the data.json\r\n\r\n```\r\n&quot;play_music&quot;: {\r\n            &quot;name&quot;: &quot;play_music&quot;,\r\n            &quot;command&quot; : &quot;adb shell am start -a android.intent.action.VIEW -d file:///${device_directory}${music_file} -t audio/${audio_type}&quot;,\r\n            &quot;variables&quot; : {\r\n                &quot;device_directory&quot; : {\r\n                    &quot;name&quot; : &quot;device_directory&quot;,\r\n                    &quot;variable&quot; : &quot;/Downloads/&quot;\r\n                },\r\n                &quot;music_file&quot; : {\r\n                    &quot;name&quot; : &quot;music_file&quot;,\r\n                    &quot;variable&quot; : &quot;test.mp3&quot;\r\n                },\r\n                &quot;audio_type&quot; : {\r\n                    &quot;name&quot; : &quot;audio_type&quot;,\r\n                    &quot;variable&quot; : &quot;mp3&quot;\r\n                }\r\n            }\r\n```\r\n\r\nAnd here is a snippet of code that I am trying to get to run the command\r\n```\r\nwhile true; do\r\n    variables=( $(jq -r &quot;.commands.$option.variables | map(.name) | .[]&quot; data.json))\r\n    ##echo ${variables[@]}\r\n    \r\n    for i in ${variables[@]}; do\r\n        ##echo -e &quot;\\n$i&quot;\r\n        var=$(jq -r &quot;.commands.$option.variables.$i.variable&quot; data.json)\r\n        if [[ -z $var ]]; then\r\n            ##echo -e &quot;var is empty&quot;\r\n            echo -e &quot;Enter $i: &quot;\r\n            read $i\r\n        else\r\n            ##echo -e &quot;var is full&quot;\r\n            declare $i=$var\r\n        fi\r\n    done\r\n\r\necho -e &quot;\\nmusic file=&#39;${music_file}&#39;&quot;\r\necho -e &quot;\\naudio type=&#39;${audio_type}&#39;&quot;\r\necho &quot;&quot;\r\n\r\ncommand=&quot;$(jq -r &quot;.commands.$option.command&quot; data.json)&quot;\r\necho $command\r\n```\r\n\r\nThe variables report as\r\n\r\n```\r\nmusic file=&#39;test.mp3&#39;\r\n\r\naudio type=&#39;mp3&#39;\r\n```\r\n\r\n\r\nThe command just comes back as:\r\n`adb shell am start -a android.intent.action.VIEW -d file:///${device_directory}${music_file} -t audio/${audio_type}`\r\nBut what I am looking for is\r\n`adb shell am start -a android.intent.action.VIEW -d file:////Downloads/test.mp3 -t audio/mp3`\r\n\r\n\r\nI tried running outputting the command in different forms $(command), &quot;$command&quot;, etc but have had no luck.",
        "link": "https://stackoverflow.com/questions/77138622/bash-jq-cant-assign-pull-string-and-assign-variable",
        "title": "Bash / JQ - cant assign pull string and assign variable"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "jq",
            "ceph"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695201817,
                "post_id": 77141019,
                "comment_id": 135991327,
                "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": 1695201897,
                "post_id": 77141019,
                "comment_id": 135991342,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4042207,
                    "reputation": 13,
                    "user_id": 3324696,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/95025bd5e1cacab26206181e41904ccc?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user3324696",
                    "link": "https://stackoverflow.com/users/3324696/user3324696"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695202002,
                "post_id": 77141019,
                "comment_id": 135991365,
                "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": 1695204340,
                "post_id": 77141019,
                "comment_id": 135991870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1695202189,
                "creation_date": 1695202189,
                "answer_id": 77141088,
                "question_id": 77141019,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This filter first selects the object where the &quot;num_objects&quot; property is equal to 189398, and then extracts the value of the &quot;bucket&quot; property from that object,so this should give you the expected output of &quot;sample-bucket&quot;!\r\n\r\n    cat testjql.txt | jq -r &#39;select(.num_objects == 189398).bucket&#39;\r\n\r\noutput\r\n\r\n    sample-bucket",
                "title": "I&#39;m trying to extract a string from json using jq but got an error &quot;cannot index string with string &quot;num_objects&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1695262953,
        "creation_date": 1695201682,
        "last_edit_date": 1695262953,
        "question_id": 77141019,
        "body_markdown": "My json snippet is as follows\r\n```\r\n\r\n\r\n            {\r\n                &quot;bucket&quot;: &quot;sample-bucket&quot;,\r\n                &quot;tenant&quot;: &quot;&quot;,\r\n                &quot;num_objects&quot;: 189398,\r\n                &quot;num_shards&quot;: 0,\r\n                &quot;objects_per_shard&quot;: 189398,\r\n                &quot;fill_status&quot;: &quot;OVER 100.000000%&quot;\r\n            }\r\n\r\n```\r\n  My expected output is sample-bucket and i want to select it using the &quot;num_objects&quot; so i come up with an jq filter below.\r\n\r\n\r\n```\r\ncat testjql.txt | jq  -r &#39;.bucket | select(.num_objects == &#39;189398&#39;)&#39;\r\n```\r\n\r\nbut got an error like this.\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:8): Cannot index string with string &quot;num_objects&quot;\r\n```\r\n\r\n\r\n\r\n\r\n\r\n\r\nI tried to play it on different ways but no luck on the expected output. ",
        "link": "https://stackoverflow.com/questions/77141019/im-trying-to-extract-a-string-from-json-using-jq-but-got-an-error-cannot-index",
        "title": "I&#39;m trying to extract a string from json using jq but got an error &quot;cannot index string with string &quot;num_objects&quot;"
    },
    {
        "tags": [
            "bash",
            "jq",
            "herestring"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1695307195,
                "post_id": 77151239,
                "comment_id": 136009492,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695307207,
                "post_id": 77151239,
                "comment_id": 136009495,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 31027,
                    "reputation": 1824,
                    "user_id": 84940,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/ZLTRkURm.jpg?s=256",
                    "display_name": "sudocracy",
                    "link": "https://stackoverflow.com/users/84940/sudocracy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695446042,
                "post_id": 77151239,
                "comment_id": 136028635,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1695307491,
        "creation_date": 1695306733,
        "last_edit_date": 1695307491,
        "question_id": 77151239,
        "body_markdown": "I&#39;m looping through a json file with the following code : \r\n```\r\n#!/bin/bash\r\n\r\nDS_SRC_FILE=&quot;/mnt/c/Users/foo/tmp/jboss_simple.json&quot;\r\n\r\nUSERNAMES=$(jq -r &#39;to_entries[]| select(.value.policy_name)?| [.key, .value.username, .value.policy_name, .value.atg_type ]| join(&quot; &quot;)&#39; ${DS_SRC_FILE})\r\nwhile read  ds current_username policy atg; do\r\n  echo -e &quot;##########\\nProcessing $ds...&quot;\r\n  echo -e &quot;username is ${current_username}&quot;\r\n  echo -e &quot;policy is ${policy}&quot;\r\n  echo -e &quot;atg is ${atg}&quot;\r\n  \r\ndone &lt;&lt;&lt; ${USERNAMES}\r\n```\r\nWith the json file [here][1]\r\n\r\nWhen running on my laptop with WSL : \r\n```\r\n$ jq --version\r\njq-1.6\r\n$ bash --version\r\nGNU bash, version 5.1.4(1)-release (x86_64-pc-linux-gnu)\r\n```\r\nI do have what&#39;s expected : \r\n```\r\n$ ./toto.sh \r\n##########\r\nProcessing DS1...\r\nusername is user_1\r\npolicy is policy_1\r\natg is CORE\r\n##########\r\nProcessing DS3...\r\nusername is user_2\r\npolicy is policy_2\r\natg is SWA\r\n##########\r\nProcessing DS4...\r\nusername is user_3\r\npolicy is policy_3\r\natg is SWB\r\n```\r\n\r\nBut when trying it from a linux box, with other bash and jq versions : \r\n```\r\n$ jq --version\r\njq-1.5\r\n$ bash --version\r\nGNU bash, version 4.2.46(2)-release (x86_64-redhat-linux-gnu)\r\n```\r\nIt fails, because there is no carriage return after the 1st end of line : \r\n```\r\n$ ./toto.sh\r\n##########\r\nProcessing DS1...\r\nusername is user_1\r\npolicy is policy_1\r\natg is CORE DS3 user_2 policy_2 SWA DS4 user_3 policy_3 SWB DS5 user_5 policy_4 AGT DS6 user_6 policy_5 PUB DS8 user_7 policy_6 COREPV DS9 user_8 policy_7 SWAPV DS10 user_9 policy_8 SWBPV DS15 user_10 policy_9 SWA DS15_batch_only user_11 policy_10 SWA DS16 user_12 policy_11 SWB DS16_batch_only user_13 policy_12 SWB DS17 user_14 policy_13 PROCESS DS18 user_15 policy_14 PROCESS DS19 user_16 policy_15 EDIT DS19_batch_only user_17 policy_16 EDIT DS20 user_18 policy_17 EDIT DS22 user_19 policy_1 IMPORT\r\n```\r\n\r\nHow can I adapt to that, to have the same code on both boxes ?\r\n\r\n  [1]: https://jqplay.org/s/2mc1gZUUKa5",
        "link": "https://stackoverflow.com/questions/77151239/here-string-or-jq-seems-to-behave-differently-with-bash-version",
        "title": "here-string or jq seems to behave differently with bash version"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq",
            "appendchild",
            "slurp"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1695330995,
                "last_edit_date": 1695330995,
                "creation_date": 1695328790,
                "answer_id": 77153527,
                "question_id": 77153469,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can merge (`add`) the items based on their index in their respective arrays using `--slurp` (or `-s`) and `transpose`:\r\n```sh\r\njq -s &#39;transpose | map(add)&#39; info.json keywords.json\r\n```\r\n[Demo](https://jqplay.org/s/lYCHxkDj0b9)\r\n\r\nFor a deep merge of two inputs, use `first * last` instead of `add`. For more than two inputs, use `reduce .[1:][] as $i (first; . * $i)` instead of it.\r\n\r\n---\r\n\r\nAn iterative approach could skim through all the items using `to_entries` to access the indices, then add them successively using `+=`:\r\n```sh\r\njq &#39;reduce (inputs | to_entries)[] as {$key, $value} (.; .[$key] += $value)&#39; info.json keywords.json\r\n```\r\n[Demo](https://jqplay.org/s/DfQxSHSTZy_X)\r\n\r\nAgain, use `*=` instead of `+=` for a deep merge.\r\n\r\n---\r\n\r\nYou could also build up the entire result from scratch using `setpath` based on the `--stream` representation of the inputs:\r\n```sh\r\njq --stream -n &#39;reduce (inputs | select(has(1))) as $i (.; setpath($i[0]; $i[1]))&#39; info.json keywords.json\r\n```\r\n\r\nThis approach always performs a deep merge.\r\n\r\n---\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 14,\r\n    &quot;column&quot;: &quot;43-49&quot;,\r\n    &quot;keyword&quot;: &quot; `master1` &quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 10,\r\n    &quot;column&quot;: &quot;38-44&quot;,\r\n    &quot;keyword&quot;: &quot; `Master2` &quot;\r\n  }\r\n]\r\n```",
                "title": "How do I merge these two different jsons using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1695330995,
        "creation_date": 1695328216,
        "question_id": 77153469,
        "body_markdown": "I have two simple jsons like:\r\n\r\ninfo.json\r\n\r\n```\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 14,\r\n    &quot;column&quot;: &quot;43-49&quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 10,\r\n    &quot;column&quot;: &quot;38-44&quot;\r\n  }\r\n]\r\n```\r\n\r\nkeywords.json\r\n\r\n```\r\n[\r\n  {\r\n    &quot;keyword&quot;: &quot; `master1` &quot;\r\n  },\r\n  {\r\n    &quot;keyword&quot;: &quot; `Master2` &quot;\r\n  }\r\n]\r\n```\r\n\r\nWould like to have the result as:\r\n\r\nresults.json\r\n```\r\n[\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 14,\r\n    &quot;column&quot;: &quot;43-49&quot;,\r\n    &quot;keyword&quot;: &quot; `master1` &quot;\r\n  },\r\n  {\r\n    &quot;filename&quot;: &quot;drilldown.json&quot;,\r\n    &quot;line&quot;: 10,\r\n    &quot;column&quot;: &quot;38-44&quot;,\r\n    &quot;keyword&quot;: &quot; `Master2` &quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nIn my case there&#39;s no relation between either of the json but would like them to be merged the way shown above\r\n\r\nAny pointers regarding the same would be much appreciated. Thanks\r\n\r\n\r\n\r\n\r\n\r\nTried these two solutions were closest but they have some inter-relation between two json files\r\n\r\nhttps://stackoverflow.com/questions/65762113/using-jq-to-add-key-value-to-a-json-file-using-another-json-file-as-a-source\r\n\r\nhttps://stackoverflow.com/questions/61092531/how-do-i-use-a-value-as-a-key-reference-in-jq#new-answer\r\n",
        "link": "https://stackoverflow.com/questions/77153469/how-do-i-merge-these-two-different-jsons-using-jq",
        "title": "How do I merge these two different jsons using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695420180,
                "creation_date": 1695420180,
                "answer_id": 77160871,
                "question_id": 77157402,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way to do it.\r\n```\r\n.[1].res[0] as $resources\r\n| .[0].amc.ott[].req as $reqs\r\n| ($reqs | map({(.wc): ({&quot;type&quot;: .wc, &quot;value&quot;:$resources[.os]} + (if .ip == &quot;t&quot; then {&quot;key3&quot;: $resources.sp.hH} else null end))}))\r\n+ [ {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},\r\n    {&quot;Mod&quot;: $reqs[] | select(.wc == &quot;rm&quot;) | {&quot;type&quot;: .wc,&quot;value&quot;: $resources[.os]}}\r\n  ]\r\n| add\r\n```\r\nOutput:\r\n```lang-json\r\n{\r\n  &quot;tc&quot;: {\r\n    &quot;type&quot;: &quot;tc&quot;,\r\n    &quot;value&quot;: &quot;desval&quot;\r\n  },\r\n  &quot;nm&quot;: {\r\n    &quot;type&quot;: &quot;nm&quot;,\r\n    &quot;value&quot;: &quot;1234&quot;,\r\n    &quot;key3&quot;: &quot;hHValue&quot;\r\n  },\r\n  &quot;rm&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  },\r\n  &quot;Column&quot;: {\r\n    &quot;type&quot;: &quot;S&quot;,\r\n    &quot;value&quot;: &quot;rv&quot;\r\n  },\r\n  &quot;Mod&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  }\r\n}\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/wGwZnWXrbgZ &quot;Click me!&quot;).",
                "title": "Getting error while adding JSON object based on condition using JQ command"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1695420180,
        "creation_date": 1695383763,
        "last_edit_date": 1695413749,
        "question_id": 77157402,
        "body_markdown": "I have below json input to JQ filter:\r\n\r\n```lang-json\r\n[\r\n  {\r\n    &quot;sn&quot;: &quot;rv&quot;,\r\n    &quot;amc&quot;: {\r\n      &quot;ott&quot;: [\r\n        {\r\n          &quot;req&quot;: [\r\n            {\r\n              &quot;wc&quot;: &quot;tc&quot;,\r\n              &quot;os&quot;: &quot;des&quot;,\r\n              &quot;dt&quot;: &quot;rt&quot;,\r\n              &quot;ip&quot;: &quot;f&quot;\r\n            },\r\n            {\r\n              &quot;wc&quot;: &quot;nm&quot;,\r\n              &quot;os&quot;: &quot;id&quot;,\r\n              &quot;dt&quot;: &quot;s&quot;,\r\n              &quot;ip&quot;: &quot;t&quot;\r\n            },\r\n            {\r\n              &quot;wc&quot;: &quot;rm&quot;,\r\n              &quot;os&quot;: &quot;mo&quot;,\r\n              &quot;dt&quot;: &quot;ts&quot;,\r\n              &quot;ip&quot;: &quot;f&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;res&quot;: [\r\n      {\r\n        &quot;sp&quot;: {\r\n          &quot;dm&quot;: &quot;dmValue&quot;,\r\n          &quot;hH&quot;: &quot;hHValue&quot;\r\n        },\r\n        &quot;des&quot;: &quot;desval&quot;,\r\n        &quot;id&quot;: &quot;1234&quot;,\r\n        &quot;mo&quot;: &quot;movalur&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n \r\n\r\nUsing below JQ syntax which reads above json data to generate output:\r\n\r\n\r\n```\r\n  [.[1].res as $resources \r\n  | (.[0].amc.ott[].req[]  \r\n     | {(.wc): {&quot;type&quot;: .wc,\r\n                &quot;value&quot;: $resources[0].[(.os)]}})] \r\n+\r\n [.[1].res as $resources \r\n  | {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},\r\n    {&quot;Mod&quot;: {&quot;type&quot;: (.[0].amc.ott[].req[]\r\n                      | select(.wc == &quot;rm&quot;) \r\n                      | .wc),\r\n             &quot;value&quot;: ((.[0].amc.ott[].req[] \r\n                        | select(.wc == &quot;rm&quot;) \r\n                        | $resources[0].[(.os)]))}}] \r\n| reduce .[] as $item ({}; .*$item)\r\n```\r\n \r\n\r\nBelow is the output of above JQ command:\r\n\r\n \r\n\r\n```lang-json\r\n{\r\n  &quot;tc&quot;: {\r\n    &quot;type&quot;: &quot;tc&quot;,\r\n    &quot;value&quot;: &quot;desval&quot;\r\n  },\r\n  &quot;nm&quot;: {\r\n    &quot;type&quot;: &quot;nm&quot;,\r\n    &quot;value&quot;: &quot;1234&quot;\r\n  },\r\n  &quot;rm&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  },\r\n  &quot;Column&quot;: {\r\n    &quot;type&quot;: &quot;S&quot;,\r\n    &quot;value&quot;: &quot;rv&quot;\r\n  },\r\n  &quot;Mod&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  }\r\n}\r\n\r\n```\r\n \r\n\r\nI want to add `key3` to output only when `amc.ott.req.ip` equals to `t`, can please someone help on how to add json key\r\nbased on condition?\r\n\r\n \r\n\r\nBelow is expected output:\r\n\r\n \r\n\r\n```lang-json\r\n{\r\n  &quot;tc&quot;: {\r\n    &quot;type&quot;: &quot;tc&quot;,\r\n    &quot;value&quot;: &quot;desval&quot;\r\n  },\r\n  &quot;nm&quot;: {\r\n    &quot;type&quot;: &quot;nm&quot;,\r\n    &quot;value&quot;: &quot;1234&quot;,\r\n\t&quot;key3&quot;: &quot;hHValue&quot;\r\n  },\r\n  &quot;rm&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  },\r\n  &quot;Column&quot;: {\r\n    &quot;type&quot;: &quot;S&quot;,\r\n    &quot;value&quot;: &quot;rv&quot;\r\n  },\r\n  &quot;Mod&quot;: {\r\n    &quot;type&quot;: &quot;rm&quot;,\r\n    &quot;value&quot;: &quot;movalur&quot;\r\n  }\r\n}\r\n\r\n \r\n```\r\n\r\n \r\n\r\n\r\n\r\nWe tried to use below JQ command:\r\n\r\n \r\n\r\n\r\n```\r\n[.[1].res as $resources | (.[0].amc.ott[].req[]  |\r\n{(.wc): {&quot;type&quot;: .wc,&quot;value&quot;:$resources[0].[(.os)],(if (.ip==&quot;t&quot;) then {&quot;key3&quot;:$resources[0].sp.hH} end)}})] + \r\n[.[1].res as $resources | {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},{&quot;Mod&quot;:{&quot;type&quot;:.[0].amc.ott[].req[] | \r\nselect(.wc == &quot;rm&quot;) | .wc,&quot;value&quot;:((.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | $resources[0].[(.os)]))}}] | \r\nreduce .[] as $item ({}; .*$item)\r\n```\r\n\r\n\r\n \r\n\r\n \r\n\r\nGetting below error:\r\n\r\n \r\n\r\n```\r\njq: error: syntax error, unexpected &#39;}&#39;, expecting &#39;:&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 2:\r\n{(.wc): {&quot;type&quot;: .wc,&quot;value&quot;:$resources[0].[(.os)],(if (.ip==&quot;t&quot;) then {&quot;key3&quot;:$resources[0].sp.hH} end)}})] +                                                                                                         \r\njq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 2:\r\n{(.wc): {&quot;type&quot;: .wc,&quot;value&quot;:$resources[0].[(.os)],(if (.ip==&quot;t&quot;) then {&quot;key3&quot;:$resources[0].sp.hH} end)}})] +                                                    \r\njq: error: syntax error, unexpected &#39;{&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 3:\r\n[.[1].res as $resources | {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},{&quot;Mod&quot;:{&quot;type&quot;:.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | .wc,&quot;value&quot;:((.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | $resources[0].[(.os)]))}}] | reduce .[] as $item ({}; .*$item)                                                                    \r\njq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 3:\r\n[.[1].res as $resources | {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},{&quot;Mod&quot;:{&quot;type&quot;:.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | .wc,&quot;value&quot;:((.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | $resources[0].[(.os)]))}}] | reduce .[] as $item ({}; .*$item)                                                                    \r\njq: error: syntax error, unexpected &#39;]&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 3:\r\n[.[1].res as $resources | {&quot;Column&quot; : {&quot;type&quot;:&quot;S&quot;,&quot;value&quot;:.[0].sn}},{&quot;Mod&quot;:{&quot;type&quot;:.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | .wc,&quot;value&quot;:((.[0].amc.ott[].req[] | select(.wc == &quot;rm&quot;) | $resources[0].[(.os)]))}}] | reduce .[] as $item ({}; .*$item)                                                                                                                                                                                                                    \r\njq: 5 compile errors\r\nexit status 3\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77157402/getting-error-while-adding-json-object-based-on-condition-using-jq-command",
        "title": "Getting error while adding JSON object based on condition using JQ command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1695411086,
                "creation_date": 1695411086,
                "answer_id": 77160253,
                "question_id": 77160241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Take the `.data` array, and `map` each item to an object. Use `.teams[]` to iterate without capturing the items in a separate array, so the output is multiplicated:\r\n```sh\r\njq &#39;.data | map({id, team: .teams[]})&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;000000000014444A&quot;,\r\n    &quot;team&quot;: &quot;000000000011AE74&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;000000000014434B&quot;,\r\n    &quot;team&quot;: &quot;000000000011AE74&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;000000000014434B&quot;,\r\n    &quot;team&quot;: &quot;00000000001583CE&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;000000000014434B&quot;,\r\n    &quot;team&quot;: &quot;000000000010B4D7&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/UruZrvGZljS)",
                "title": "Normalize JSON data"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1695414122,
                "creation_date": 1695414122,
                "answer_id": 77160466,
                "question_id": 77160241,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are a several ways to get the result that you want. One of them is described in [@pmf&#39;s answer](https://stackoverflow.com/a/77160253/4265352).\r\n\r\nThis is another way:\r\n\r\n```shell\r\njq &#39;[ .data[] | { id, team: .teams[] } ]&#39;\r\n```\r\n\r\nHow it works:\r\n\r\n1. `.data` extracts the property `data` from the input (the input is an object); the value of property `data` is an array;\r\n2. `[]` splits the array into items; the output of `.data[]` consists of multiple values, each value is one of the items of `.data`; the output of `.data[]` consists of two objects;\r\n3. `|` - the next filters apply to each input value independent of other values; the input values are the values produced by `.data[]`;\r\n4. `{ id, team: .teams[] }` - the output of this filter is an object (`{ ... }`) whose properties are `id` and `team`;\r\n   * `id` is a shorthand of `id: .id`; the key (`id`) is the name of the property in the output object; the value (`.id`) is a filter that extracts the property `id` of each input object (the input objects have the properties `id` and `teams`);\r\n   * `team: .teams[]` produce the property `team` in the output object; its value is the value of property `teams` from the input object; `teams` is an array in the input object but `[]` after `.team` split the value of `teams` into individual items; the expression `.teams[]` produce multiple output values from one input value; it produces one result for the object with `id` equal to `&quot;000000000014444A&quot;` and three results for the object with `id` equal to `&quot;000000000014434B&quot;`.\r\n\r\n   All in all, the expression `.data[] | { id, team: .teams[] }` produce four results as output.\r\n5. The outer `[` and `]` wrap the results produced by the enclosed pipeline into an array. The array (which is the output of the entire program) contains the four items generated by the inner expression. It is the output that you expect.\r\n\r\nSee it on the [jq playground](https://jqplay.org/s/05w0UiCeUZZ).",
                "title": "Normalize JSON data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1695414122,
        "creation_date": 1695410911,
        "question_id": 77160241,
        "body_markdown": "Given the following JSON structure\r\n\r\n```\r\n{\r\n\t&quot;data&quot;: [\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;000000000014444A&quot;,\r\n\t\t\t&quot;teams&quot;: [\r\n\t\t\t\t&quot;000000000011AE74&quot;\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;000000000014434B&quot;,\r\n\t\t\t&quot;teams&quot;: [\r\n\t\t\t\t&quot;000000000011AE74&quot;,\r\n\t\t\t\t&quot;00000000001583CE&quot;,\r\n\t\t\t\t&quot;000000000010B4D7&quot;\r\n\t\t\t]\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nHow can I use jq to structure the data as\r\n\r\n```\r\n[\r\n\t{\r\n\t\t&quot;id&quot;: &quot;000000000014444A&quot;,\r\n\t\t&quot;team&quot;: &quot;000000000011AE74&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: &quot;000000000014434B&quot;,\r\n\t\t&quot;team&quot;: &quot;000000000011AE74&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: &quot;000000000014434B&quot;,\r\n\t\t&quot;team&quot;: &quot;00000000001583CE&quot;\r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: &quot;000000000014434B&quot;,\r\n\t\t&quot;team&quot;: &quot;000000000010B4D7&quot;\r\n\t}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/77160241/normalize-json-data",
        "title": "Normalize JSON data"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1695461319,
                "post_id": 77162311,
                "comment_id": 136029782,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 92073,
                    "reputation": 12828,
                    "user_id": 252518,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/3FDkH.jpg?s=256",
                    "display_name": "Freeman",
                    "link": "https://stackoverflow.com/users/252518/freeman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695469005,
                "post_id": 77162311,
                "comment_id": 136030476,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13225839,
                    "reputation": 193,
                    "user_id": 9550953,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5563b28fb4c4a3afeea9045275baa8ef?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kevin",
                    "link": "https://stackoverflow.com/users/9550953/kevin"
                },
                "reply_to_user": {
                    "account_id": 92073,
                    "reputation": 12828,
                    "user_id": 252518,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://i.sstatic.net/3FDkH.jpg?s=256",
                    "display_name": "Freeman",
                    "link": "https://stackoverflow.com/users/252518/freeman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695483633,
                "post_id": 77162311,
                "comment_id": 136031817,
                "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": 1695487720,
                "post_id": 77162311,
                "comment_id": 136032329,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1695468500,
                "creation_date": 1695468500,
                "answer_id": 77162820,
                "question_id": 77162311,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to unbuffer python&#39;s stdout, e.g.:\r\n\r\n```python\r\npython3 -u jqtest.py | jq &#39;.&#39;\r\n```",
                "title": "Invoke jq on every new json object printed by Python script, not just on completion"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1695485853,
        "creation_date": 1695459508,
        "last_edit_date": 1695468569,
        "question_id": 77162311,
        "body_markdown": "I have a python script that watches a socket and when data is received it writes JSON to stdout. \r\n\r\nThis sample script below illustrates the behaviour, outputting new JSON every 3 seconds.\r\n\r\n```\r\nimport json, time\r\n\r\ndef new_json(n):\r\n    frame = {\r\n        &quot;Iteration&quot;: n,\r\n        &quot;Field0&quot;: 0,\r\n        &quot;Field1&quot;: 1,\r\n        &quot;Field2&quot;: 2\r\n    }\r\n    print(json.dumps(frame))\r\n\r\nnew_json(1)\r\ntime.sleep(3)\r\nnew_json(2)\r\ntime.sleep(3)\r\nnew_json(3)\r\n```\r\n\r\nThe output of this is:\r\n```\r\n{&quot;Iteration&quot;: 1, &quot;Field0&quot;: 0, &quot;Field1&quot;: 1, &quot;Field2&quot;: 2}\r\n{&quot;Iteration&quot;: 2, &quot;Field0&quot;: 0, &quot;Field1&quot;: 1, &quot;Field2&quot;: 2}\r\n{&quot;Iteration&quot;: 3, &quot;Field0&quot;: 0, &quot;Field1&quot;: 1, &quot;Field2&quot;: 2}\r\n```\r\nIf i pipe this into ```jq``` using ```python3 jqtest.py | jq .``` it only prints the JSON when the script has completely finished. \r\n\r\nHow can i invoke ```jq``` for every new JSON object received during execution, not just at the end?\r\n",
        "link": "https://stackoverflow.com/questions/77162311/invoke-jq-on-every-new-json-object-printed-by-python-script-not-just-on-complet",
        "title": "Invoke jq on every new json object printed by Python script, not just on completion"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1695908938,
                "last_edit_date": 1695908938,
                "creation_date": 1695502984,
                "answer_id": 77164897,
                "question_id": 77164858,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`paths/1` (see its [definition](https://github.com/jqlang/jq/blob/master/src/builtin.jq#L52)) already applies `select/1` using your provided node filter. Your approach didn&#39;t work because your node filter also applies another `select/1` around the result, causing *falsy* values (`null` and `false`) being filtered out. Remove your `select/1` from the node filter, and it&#39;ll work:\r\n\r\n```sh\r\n[ paths(type | IN(&quot;object&quot;, &quot;array&quot;) | not) as $path\r\n  | { &quot;\\($path)&quot;: getpath($path) }\r\n] | add\r\n```\r\n```json\r\n{\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key1\\&quot;]&quot;: 1,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key2\\&quot;]&quot;: null,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key3\\&quot;]&quot;: 3,\r\n  &quot;[\\&quot;array\\&quot;,0]&quot;: &quot;a&quot;,\r\n  &quot;[\\&quot;array\\&quot;,1]&quot;: null,\r\n  &quot;[\\&quot;array\\&quot;,2]&quot;: &quot;c&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/mbUYeIbPwUM)\r\n\r\n---\r\n\r\nAlternatively, especially if you were including `select/1` to simulate the application of [shortcuts](https://jqlang.github.io/jq/manual/v1.6/#arrays-objects-iterables-booleans-numbers-normals-finites-strings-nulls-values-scalars) like `iterables/0` (selecting only arrays and objects), or `scalars/0` (the opposite), which themselves are also all [implemented](https://github.com/jqlang/jq/blob/master/src/builtin.jq#L54-L64) based on `select/1` (thus not usable here with `paths/1`), you could switch to the non-recursive `path/1` [filter](https://jqplay.org/s/Ke6H7XHpfpd) (no &quot;s&quot;), and manually include the recursion, e.g. using the [recursive descent](https://jqlang.github.io/jq/manual/v1.6/#recursive-descent) `..`:\r\n```sh\r\n[ path(.. | select(type | IN(&quot;object&quot;, &quot;array&quot;) | not)) as $path\r\n  | { &quot;\\($path)&quot;: getpath($path) }\r\n] | add\r\n\r\n# or\r\n\r\n[ path(.. | scalars) as $path\r\n  | { &quot;\\($path)&quot;: getpath($path) }\r\n] | add\r\n```\r\n[Demo](https://jqplay.org/s/Ke6H7XHpfpd)\r\n\r\n---\r\n\r\nDepending on your specific use-case, you might also be interested in jq&#39;s feature to convert its input into a &quot;stream representation&quot; which already provides you with a `[path, value]` structure, using the `tostream/0` filter or the `--stream` option. Just filter out the backtracking items (without value) by selecting by index 1.\r\n```sh\r\njq &#39;[tostream | select(has(1)) | {(&quot;\\(first)&quot;): last}] | add&#39;\r\n# or\r\njq --stream -s &#39;map(select(has(1)) | {(&quot;\\(first)&quot;): last}) | add&#39;\r\n# or\r\njq --stream -n &#39;reduce (inputs | select(has(1))) as [$p,$v] ({}; .[&quot;\\($p)&quot;] = $v)&#39;\r\n```",
                "title": "How can I exclude arrays and objects without excluding null values in a jq filter?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1695908938,
        "creation_date": 1695502335,
        "last_edit_date": 1695523610,
        "question_id": 77164858,
        "body_markdown": "I don&#39;t understand why, when filtering out all items that are objects and arrays, null values are affected as well.\r\n\r\nAnd I didn&#39;t find any workaround so far.\r\n\r\nThe input:\r\n\r\n```\r\n$ cat test.json\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;key1&quot;: 1,\r\n    &quot;key2&quot;: null,\r\n    &quot;key3&quot;: 3\r\n  },\r\n  &quot;array&quot;: [ &quot;a&quot;, null, &quot;c&quot; ]\r\n}\r\n```\r\n\r\nActual behavior, unexpectedly missing output for null values:\r\n\r\n```\r\n$ jq &#39;[ paths(select(type | IN(&quot;object&quot;, &quot;array&quot;) | not)) as $path | { &quot;\\($path)&quot;: getpath($path) } ] | add&#39; test.json\r\n{\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key1\\&quot;]&quot;: 1,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key3\\&quot;]&quot;: 3,\r\n  &quot;[\\&quot;array\\&quot;,0]&quot;: &quot;a&quot;,\r\n  &quot;[\\&quot;array\\&quot;,2]&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nDesired (and expected) output:\r\n\r\n```\r\n{\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key1\\&quot;]&quot;: 1,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key2\\&quot;]&quot;: null,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key3\\&quot;]&quot;: 3,\r\n  &quot;[\\&quot;array\\&quot;,0]&quot;: &quot;a&quot;,\r\n  &quot;[\\&quot;array\\&quot;,1]&quot;: null,\r\n  &quot;[\\&quot;array\\&quot;,2]&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nEDIT:\r\n\r\nAs we can see here, paths with null values are output if no filter is applied:\r\n\r\n```\r\n$  jq &#39;[ paths as $path | { &quot;\\($path)&quot;: getpath($path) } ] | add&#39; test.json\r\n{\r\n  &quot;[\\&quot;object\\&quot;]&quot;: {\r\n    &quot;key1&quot;: 1,\r\n    &quot;key2&quot;: null,\r\n    &quot;key3&quot;: 3\r\n  },\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key1\\&quot;]&quot;: 1,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key2\\&quot;]&quot;: null,\r\n  &quot;[\\&quot;object\\&quot;,\\&quot;key3\\&quot;]&quot;: 3,\r\n  &quot;[\\&quot;array\\&quot;]&quot;: [\r\n    &quot;a&quot;,\r\n    null,\r\n    &quot;c&quot;\r\n  ],\r\n  &quot;[\\&quot;array\\&quot;,0]&quot;: &quot;a&quot;,\r\n  &quot;[\\&quot;array\\&quot;,1]&quot;: null,\r\n  &quot;[\\&quot;array\\&quot;,2]&quot;: &quot;c&quot;\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77164858/how-can-i-exclude-arrays-and-objects-without-excluding-null-values-in-a-jq-filte",
        "title": "How can I exclude arrays and objects without excluding null values in a jq filter?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1695586005,
                "creation_date": 1695586005,
                "answer_id": 77168757,
                "question_id": 77168700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `keys_unsorted` to get a list of keys in representation order, then take the second one (at index 1):\r\n```sh\r\njq -r &#39;.versions | keys_unsorted[1]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/IyOq-fNU7R8)\r\n\r\nGetting &quot;the lastest version&quot; highly depends on how the version numbers are constructed. Your sample suggests that considering numbers only will suffice. So, strip consecutive digits from the keys, turn them into numbers, and get the maximum by that:\r\n```sh\r\njq -r &#39;.versions | keys_unsorted | max_by([scan(&quot;\\\\d+&quot;) | tonumber])&#39;\r\n```\r\n[Demo](https://jqplay.org/s/fZ4oRDahbpD)\r\n\r\nOutput:\r\n```\r\n4.2.5\r\n```",
                "title": "bash get 2nd JSON record with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1695593071,
                "last_edit_date": 1695593071,
                "creation_date": 1695592219,
                "answer_id": 77169068,
                "question_id": 77168700,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will produce both version and path :\r\n\r\n```\r\nwget -q -O- https://www.spip.net/spip_loader.api |\r\n  jq -r &#39;.versions | to_entries\r\n        | max_by(.key | [scan(&quot;\\\\d+&quot;) | tonumber])\r\n        | &quot;\\(.key) \\(.value)&quot;&#39;\r\n# Output: 4.2.5 spip/archives/spip-v4.2.5.zip\r\n```",
                "title": "bash get 2nd JSON record with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1695593071,
        "creation_date": 1695585062,
        "question_id": 77168700,
        "body_markdown": "I&#39;m trying to get the lastest version of &quot;spip&quot;\r\nFor that, I can use a JSON output from https://www.spip.net/spip_loader.api but I don&#39;t know how to get the 2nd record key (4.2.5) in bash with jq.\r\n\r\n    $ wget -q -O- https://www.spip.net/spip_loader.api | jq &#39;.versions&#39;\r\n    {\r\n      &quot;dev&quot;: &quot;spip/dev/spip-master.zip&quot;,\r\n      &quot;4.2.5&quot;: &quot;spip/archives/spip-v4.2.5.zip&quot;,\r\n      &quot;4.1.12&quot;: &quot;spip/archives/spip-v4.1.12.zip&quot;,\r\n      &quot;4.0.11&quot;: &quot;spip/archives/spip-v4.0.11.zip&quot;,\r\n      &quot;3.2.19&quot;: &quot;spip/archives/spip-v3.2.19.zip&quot;\r\n    }\r\n\r\nI could just get 3rd line with `| sed -n &#39;3p&#39;` but I don&#39;t find it very clean and I think that using jq completely would be more suitable.\r\n\r\nI admit that it&#39;s more out of curiosity than out of need since I can do otherwise.",
        "link": "https://stackoverflow.com/questions/77168700/bash-get-2nd-json-record-with-jq",
        "title": "bash get 2nd JSON record with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695624729,
                "creation_date": 1695624729,
                "answer_id": 77170416,
                "question_id": 77170372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use:\r\n\r\n```bash\r\n$ jq &#39;[.[] | {iid: .iid, project_id: .project_id, ref: .ref, status: .status, source: .source, created_at: .created_at, updated_at: .updated_at, web_url: .web_url}]&#39; file\r\n[\r\n  {\r\n    &quot;iid&quot;: 6316,\r\n    &quot;project_id&quot;: 1234,\r\n    &quot;ref&quot;: &quot;test_branch&quot;,\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;source&quot;: &quot;web&quot;,\r\n    &quot;created_at&quot;: &quot;2023-09-25T05:55:20.788Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2023-09-25T05:55:23.481Z&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.gitlab.com&quot;\r\n  }\r\n]\r\n```",
                "title": "select multiple key and values from a JSON output using JQ"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1695639622,
                "last_edit_date": 1695639622,
                "creation_date": 1695624735,
                "answer_id": 77170418,
                "question_id": 77170372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to provide what to keep, you can use the `pick` filter if you have jq 1.7:\r\n```sh\r\nmap(pick(\r\n  .iid, .project_id, .ref, .status, .source,\r\n  .created_at, .updated_at, .web_url\r\n))\r\n```\r\n[Demo](https://jqplay.org/s/rfUCPj0K-uc)\r\n\r\nIf you don&#39;t have jq 1.7, you can define it by copying it over from the [source](https://github.com/jqlang/jq/blob/master/src/builtin.jq#L259-L263):\r\n```sh\r\ndef pick(pathexps):\r\n  . as $in | reduce path(pathexps) as $a (null;\r\n      setpath($a; $in|getpath($a))\r\n  );\r\n\r\nmap(pick(…))\r\n```\r\n[Demo](https://jqplay.org/s/KH2CYZ-Si_8)\r\n\r\nIf you rather want to provide what to delete, use `del` instead:\r\n```sh\r\nmap(del(.id, .sha))\r\n```\r\n[Demo](https://jqplay.org/s/k0374yav7kI)\r\n\r\n---\r\n\r\nAs you&#39;ve tried using `with_entries` and `select`, here&#39;s how you could achieve the desired result using these filters:\r\n\r\nSelecting what to keep:\r\n```sh\r\nmap(with_entries(select(.key | IN(\r\n  &quot;iid&quot;, &quot;project_id&quot;, &quot;ref&quot;, &quot;status&quot;, &quot;source&quot;,\r\n  &quot;created_at&quot;, &quot;updated_at&quot;, &quot;web_url&quot;\r\n))))\r\n```\r\n[Demo](https://jqplay.org/s/fA7fED-m0Fh)\r\n\r\nSelecting what not to keep:\r\n```sh\r\nmap(with_entries(select(.key | IN(&quot;id&quot;, &quot;sha&quot;) | not)))\r\n```\r\n[Demo](https://jqplay.org/s/w75-AZOcmGY)\r\n\r\n---\r\n\r\nAll of the above output:\r\n```json\r\n[\r\n  {\r\n    &quot;iid&quot;: 6316,\r\n    &quot;project_id&quot;: 1234,\r\n    &quot;ref&quot;: &quot;test_branch&quot;,\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;source&quot;: &quot;web&quot;,\r\n    &quot;created_at&quot;: &quot;2023-09-25T05:55:20.788Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2023-09-25T05:55:23.481Z&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.gitlab.com&quot;\r\n  }\r\n]\r\n```\r\n",
                "title": "select multiple key and values from a JSON output using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695710080,
                "creation_date": 1695710080,
                "answer_id": 77177507,
                "question_id": 77170372,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The simplest way, working in all jq versions:\r\n\r\n    map({\r\n      iid, project_id, ref, status, source,\r\n      created_at, updated_at, web_url\r\n    })\r\n\r\n[Demo][1]\r\n\r\n  [1]: https://jqplay.org/s/zoJ9zjrNr7f",
                "title": "select multiple key and values from a JSON output using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1695710080,
        "creation_date": 1695624269,
        "last_edit_date": 1695629588,
        "question_id": 77170372,
        "body_markdown": "I have a JSON data like below\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 4449282,\r\n    &quot;iid&quot;: 6316,\r\n    &quot;project_id&quot;: 1234,\r\n    &quot;sha&quot;: &quot;abcdefg&quot;,\r\n    &quot;ref&quot;: &quot;test_branch&quot;,\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;source&quot;: &quot;web&quot;,\r\n    &quot;created_at&quot;: &quot;2023-09-25T05:55:20.788Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2023-09-25T05:55:23.481Z&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.gitlab.com&quot;\r\n  }\r\n]\r\n```\r\nI want the output to be filtered only with select key and values. The filtered output I need is \r\n\r\n```\r\n[\r\n  {\r\n    &quot;iid&quot;: 6316,\r\n    &quot;project_id&quot;: 1234,\r\n    &quot;ref&quot;: &quot;test_branch&quot;,\r\n    &quot;status&quot;: &quot;running&quot;,\r\n    &quot;source&quot;: &quot;web&quot;,\r\n    &quot;created_at&quot;: &quot;2023-09-25T05:55:20.788Z&quot;,\r\n    &quot;updated_at&quot;: &quot;2023-09-25T05:55:23.481Z&quot;,\r\n    &quot;web_url&quot;: &quot;https://example.gitlab.com&quot;\r\n  }\r\n]\r\n```\r\nI tried with `jq &#39;with_entries` and `jq select` , but couldn&#39;t get it working.",
        "link": "https://stackoverflow.com/questions/77170372/select-multiple-key-and-values-from-a-json-output-using-jq",
        "title": "select multiple key and values from a JSON output using JQ"
    },
    {
        "tags": [
            "json",
            "shell",
            "github-actions",
            "jq",
            "jsonschema"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11598503,
                    "reputation": 23954,
                    "user_id": 8496462,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/iX1W0.jpg?s=256",
                    "display_name": "GuiFalourd",
                    "link": "https://stackoverflow.com/users/8496462/guifalourd"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1695640708,
                "post_id": 77171901,
                "comment_id": 136046965,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1695640753,
                "post_id": 77171901,
                "comment_id": 136046978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11698906,
                    "reputation": 3549,
                    "user_id": 8564731,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-YS7UCJcQ0-Q/AAAAAAAAAAI/AAAAAAAAACg/55XwHWieOlI/s256-rj/photo.jpg",
                    "display_name": "Jeremy Fiel",
                    "link": "https://stackoverflow.com/users/8564731/jeremy-fiel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695651919,
                "post_id": 77171901,
                "comment_id": 136049418,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11009157,
                    "reputation": 140,
                    "user_id": 8087167,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-EWhl3QDGIas/AAAAAAAAAAI/AAAAAAAAADU/lLF5vDouLGY/s256-rj/photo.jpg",
                    "display_name": "jkroepke",
                    "link": "https://stackoverflow.com/users/8087167/jkroepke"
                },
                "reply_to_user": {
                    "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": 1695732052,
                "post_id": 77171901,
                "comment_id": 136061292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11009157,
                    "reputation": 140,
                    "user_id": 8087167,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-EWhl3QDGIas/AAAAAAAAAAI/AAAAAAAAADU/lLF5vDouLGY/s256-rj/photo.jpg",
                    "display_name": "jkroepke",
                    "link": "https://stackoverflow.com/users/8087167/jkroepke"
                },
                "reply_to_user": {
                    "account_id": 11698906,
                    "reputation": 3549,
                    "user_id": 8564731,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-YS7UCJcQ0-Q/AAAAAAAAAAI/AAAAAAAAACg/55XwHWieOlI/s256-rj/photo.jpg",
                    "display_name": "Jeremy Fiel",
                    "link": "https://stackoverflow.com/users/8564731/jeremy-fiel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695732700,
                "post_id": 77171901,
                "comment_id": 136061456,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1695747679,
                "creation_date": 1695747679,
                "answer_id": 77182077,
                "question_id": 77171901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to delete all `&quot;required&quot;` properties at any level, the following expression should work:\r\n\r\n```\r\ndel(..|.required?)\r\n```\r\n\r\n`?` is the [Optional Object Identifier-Index](https://jqlang.github.io/jq/manual/v1.7/#optional-object-identifier-index) which will suppress errors.\r\n\r\nSample output with your given input:\r\n\r\n```json\r\n{\r\n  &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema#&quot;,\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;blackbox&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;enabled&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "recursively delete all required keys in a JSON schema"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1695748701,
                "creation_date": 1695748701,
                "answer_id": 77182170,
                "question_id": 77171901,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Recursively remove one key**\r\n```bash\r\njq &#39;walk(if type == &quot;object&quot; then del(.required) else . end)&#39;\r\n# same as\r\njq &#39;del(..|.required?)&#39;\r\n```\r\n\r\n```\r\n{\r\n  &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema#&quot;,\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;blackbox&quot;: {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;enabled&quot;: {\r\n          &quot;type&quot;: &quot;boolean&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n**Recursively remove multiple keys**\r\n```bash\r\njq &#39;walk(if type == &quot;object&quot; then del(.type,.required) else . end)&#39;\r\n# same as\r\njq &#39;del(..|.type?,.required?)&#39;\r\n```\r\n\r\n```\r\n{\r\n  &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema#&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;blackbox&quot;: {\r\n      &quot;properties&quot;: {\r\n        &quot;enabled&quot;: {}\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
                "title": "recursively delete all required keys in a JSON schema"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1695748701,
        "creation_date": 1695638004,
        "last_edit_date": 1695731335,
        "question_id": 77171901,
        "body_markdown": "I have written a [JSON schema](https://json-schema.org) file for my Kubernetes Helm values files.\r\n\r\nThe schema defined some [required properties](https://json-schema.org/draft/2020-12/json-schema-validation.html#section-6.5.3). I would like to publish modified schema without all required properties.\r\n\r\nBackground: With helm, it&#39;s possible to define a subset of the values files. IntelliJ highlights some error on such subset YAML files, since it misses some &quot;required keys&quot;. Thats fine in this context, since the YAML files which holds a subset of the configuration will be merged with the base configuration.\r\n\r\nExample JSON\r\n\r\n```json\r\n{\r\n    &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema#&quot;,\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;blackbox&quot;: {\r\n            &quot;type&quot;: &quot;object&quot;,\r\n            &quot;properties&quot;: {\r\n                &quot;enabled&quot;: {\r\n                    &quot;type&quot;: &quot;boolean&quot;\r\n                }\r\n            },\r\n            &quot;required&quot;: [&quot;enabled&quot;]\r\n        }\r\n    },\r\n    &quot;required&quot;: [&quot;blackbox&quot;]\r\n}\r\n```\r\n\r\nThe schema itself is repeatable, the &quot;required&quot; key can also be found in a 9th or 10th nested level. That&#39;s why I need a solution which enables to do it recursively.\r\n\r\nThe step should be executed in GitHub Action, however any shell based solution is fine, too. \r\n\r\nI was trying to play with jq, but I don&#39;t find the way here.\r\n\r\nExample Output:\r\n\r\n```\r\n{\r\n    &quot;$schema&quot;: &quot;http://json-schema.org/draft-07/schema#&quot;,\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;properties&quot;: {\r\n        &quot;blackbox&quot;: {\r\n            &quot;type&quot;: &quot;object&quot;,\r\n            &quot;properties&quot;: {\r\n                &quot;enabled&quot;: {\r\n                    &quot;type&quot;: &quot;boolean&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77171901/recursively-delete-all-required-keys-in-a-json-schema",
        "title": "recursively delete all required keys in a JSON schema"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1695719310,
                "creation_date": 1695719310,
                "answer_id": 77178572,
                "question_id": 77178511,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you can write such a query:\r\n\r\n```\r\n.vms[] | to_entries[] | select(any(.value[]; .relevant == &quot;true&quot;)).key\r\n```\r\n\r\nWe want to select the vms where any of its values have a `relevant` key set to `&quot;true&quot;`.\r\n\r\nIn your example: `.vms[] | select(.[].relevant == &quot;true&quot; )| keys`\r\nYou&#39;re attempting to go through all the values of the `vm` objects (which all happened to be arrays). You would have needed to do `select(.[][].relevant ...)` but at that point, you should be using the `any/2` filter.",
                "title": "JQ get names of lists containing specific property value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1695719310,
        "creation_date": 1695718843,
        "last_edit_date": 1695718984,
        "question_id": 77178511,
        "body_markdown": "I have json file with infrastructure description. Simplified it for pasting here\r\n\r\n```\r\n{\r\n  &quot;vms&quot;: [\r\n    {\r\n      &quot;vm01&quot;: [\r\n        {\r\n          &quot;relevant&quot;: &quot;true&quot;\r\n        }\r\n      ],\r\n      &quot;vm02&quot;: [\r\n        {\r\n          &quot;relevant&quot;: &quot;false&quot;\r\n        }\r\n      ],\r\n      &quot;vm03&quot;: [\r\n        {\r\n          &quot;relevant&quot;: &quot;true&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI need JQ statement for getting VM names (such as vm01, vm03) which have &quot;relevant&quot; key set to &quot;true&quot;\r\n\r\n```jq &#39;.vms[] | select(.[].relevant == &quot;true&quot; )| keys&#39; ```\r\nreturns error (Cannot index array with string &quot;relevant&quot;)\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77178511/jq-get-names-of-lists-containing-specific-property-value",
        "title": "JQ get names of lists containing specific property value"
    },
    {
        "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": 3,
                "creation_date": 1695736961,
                "post_id": 77180739,
                "comment_id": 136062455,
                "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": 1695739168,
                "post_id": 77180739,
                "comment_id": 136062952,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3150808,
                    "reputation": 45,
                    "user_id": 2664304,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3c9c29624c0880a3c2535c1a75041eba?s=256&d=identicon&r=PG",
                    "display_name": "user2664304",
                    "link": "https://stackoverflow.com/users/2664304/user2664304"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695828633,
                "post_id": 77180739,
                "comment_id": 136076973,
                "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": 1695840391,
                "post_id": 77180739,
                "comment_id": 136079158,
                "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": 1695883047,
                "post_id": 77180739,
                "comment_id": 136083717,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1695736820,
        "creation_date": 1695736820,
        "question_id": 77180739,
        "body_markdown": "I have data I&#39;m getting back from an iLO interface using the Redfish API about the disks on the server.  I get a JSON similar to:\r\n\r\n```\r\n{\r\n  &quot;Server&quot;: &quot;my-pc.org&quot;,\r\n  &quot;ArrayController&quot;: &quot;DE0080000&quot;,\r\n  &quot;Health&quot;: &quot;OK&quot;,\r\n  &quot;NumDrives&quot;: &quot;2&quot;,\r\n  &quot;Drives&quot;: [\r\n    {\r\n      &quot;@odata.id&quot;: &quot;/redfish/v1/Systems/1/Storage/DE0080000/Drives/0&quot;,\r\n      &quot;@odata.type&quot;: &quot;#Drive.v1_14_0.Drive&quot;,\r\n      &quot;Id&quot;: &quot;0&quot;,\r\n      &quot;Name&quot;: &quot;15TB 22.5G SAS SSD&quot;,\r\n      &quot;Status&quot;: {\r\n        &quot;State&quot;: &quot;UnavailableOffline&quot;,\r\n        &quot;Health&quot;: &quot;Critical&quot;\r\n      },\r\n      &quot;LocationIndicatorActive&quot;: false,\r\n      &quot;Model&quot;: &quot;VO001920RZWUV&quot;,\r\n      &quot;Revision&quot;: &quot;HPD0&quot;,\r\n      &quot;Protocol&quot;: &quot;SAS&quot;,\r\n      &quot;MediaType&quot;: &quot;SSD&quot;,\r\n      &quot;CapacityBytes&quot;: 1920383410176,\r\n      &quot;BlockSizeBytes&quot;: 512,\r\n      &quot;SerialNumber&quot;: &quot;12BA08LTL08&quot;,\r\n      &quot;FailurePredicted&quot;: false,\r\n      &quot;PredictedMediaLifeLeftPercent&quot;: 100,\r\n      &quot;StatusIndicator&quot;: &quot;Fail&quot;,\r\n      &quot;Identifiers&quot;: [\r\n        {\r\n          &quot;DurableName&quot;: &quot;58CE38EE21D51FE&quot;,\r\n          &quot;DurableNameFormat&quot;: &quot;NAA&quot;\r\n        }\r\n      ],\r\n      &quot;PhysicalLocation&quot;: {\r\n        &quot;PartLocation&quot;: {\r\n          &quot;LocationType&quot;: &quot;Bay&quot;,\r\n          &quot;ServiceLabel&quot;: &quot;Slot=1:Port=2E:Box=1:Bay=1&quot;,\r\n          &quot;LocationOrdinalValue&quot;: 1\r\n        }\r\n      },\r\n      &quot;HotspareType&quot;: &quot;None&quot;,\r\n      &quot;EncryptionAbility&quot;: &quot;None&quot;,\r\n      &quot;WriteCacheEnabled&quot;: false,\r\n      &quot;CapableSpeedGbs&quot;: 22.5,\r\n      &quot;NegotiatedSpeedGbs&quot;: 12,\r\n      &quot;Operations&quot;: [],\r\n      &quot;Multipath&quot;: true,\r\n      &quot;Links&quot;: {\r\n        &quot;Volumes@odata.count&quot;: 1,\r\n        &quot;Volumes&quot;: [\r\n          {\r\n            &quot;@odata.id&quot;: &quot;/redfish/v1/Systems/1/Storage/DE0080000/Volumes/1&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;@odata.etag&quot;: &quot;\\&quot;63838C5C\\&quot;&quot;\r\n    },\r\n    {\r\n      &quot;@odata.id&quot;: &quot;/redfish/v1/Systems/1/Storage/DE0080000/Drives/1&quot;,\r\n      &quot;@odata.type&quot;: &quot;#Drive.v1_14_0.Drive&quot;,\r\n      &quot;Id&quot;: &quot;1&quot;,\r\n      &quot;Name&quot;: &quot;15TB 22.5G SAS SSD&quot;,\r\n      &quot;Status&quot;: {\r\n        &quot;State&quot;: &quot;Enabled&quot;,\r\n        &quot;Health&quot;: &quot;OK&quot;\r\n      },\r\n      &quot;LocationIndicatorActive&quot;: false,\r\n      &quot;Model&quot;: &quot;VO001920RZWUV&quot;,\r\n      &quot;Revision&quot;: &quot;HPD0&quot;,\r\n      &quot;Protocol&quot;: &quot;SAS&quot;,\r\n      &quot;MediaType&quot;: &quot;SSD&quot;,\r\n      &quot;CapacityBytes&quot;: 1920383410176,\r\n      &quot;BlockSizeBytes&quot;: 512,\r\n      &quot;SerialNumber&quot;: &quot;12BA08LTL08&quot;,\r\n      &quot;FailurePredicted&quot;: false,\r\n      &quot;PredictedMediaLifeLeftPercent&quot;: 100,\r\n      &quot;StatusIndicator&quot;: &quot;OK&quot;,\r\n      &quot;Identifiers&quot;: [\r\n        {\r\n          &quot;DurableName&quot;: &quot;58CE38EE21D51FE&quot;,\r\n          &quot;DurableNameFormat&quot;: &quot;NAA&quot;\r\n        }\r\n      ],\r\n      &quot;PhysicalLocation&quot;: {\r\n        &quot;PartLocation&quot;: {\r\n          &quot;LocationType&quot;: &quot;Bay&quot;,\r\n          &quot;ServiceLabel&quot;: &quot;Slot=1:Port=2E:Box=1:Bay=2&quot;,\r\n          &quot;LocationOrdinalValue&quot;: 2\r\n        }\r\n      },\r\n      &quot;HotspareType&quot;: &quot;None&quot;,\r\n      &quot;EncryptionAbility&quot;: &quot;None&quot;,\r\n      &quot;WriteCacheEnabled&quot;: false,\r\n      &quot;CapableSpeedGbs&quot;: 22.5,\r\n      &quot;NegotiatedSpeedGbs&quot;: 12,\r\n      &quot;Operations&quot;: [],\r\n      &quot;Multipath&quot;: true,\r\n      &quot;Links&quot;: {\r\n        &quot;Volumes@odata.count&quot;: 1,\r\n        &quot;Volumes&quot;: [\r\n          {\r\n            &quot;@odata.id&quot;: &quot;/redfish/v1/Systems/1/Storage/DE0080000/Volumes/1&quot;\r\n          }\r\n        ]\r\n      },\r\n      &quot;@odata.etag&quot;: &quot;\\&quot;6383FE34\\&quot;&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nI&#39;m trying to just pick out the ones that have &quot;StatusIndicator&quot; set to &quot;Fail&quot; and print out the .PhysicalLocation.PartLocation.ServiceLabel.  I tried:\r\n\r\n```\r\njq -r &#39;.Drives[] | select(.StatusIndicator==&quot;Fail&quot;) | .PhysicalLocation.PartLocation.ServiceLabel&#39; json-file\r\n```\r\nbut I get nothing.  Anyone have an idea what I am doing wrong?",
        "link": "https://stackoverflow.com/questions/77180739/select-in-jq-from-redfish-output",
        "title": "Select in JQ from Redfish Output"
    },
    {
        "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": 2,
                "creation_date": 1695754488,
                "post_id": 77182646,
                "comment_id": 136065976,
                "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": 1695754537,
                "post_id": 77182646,
                "comment_id": 136065983,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29371809,
                    "reputation": 1,
                    "user_id": 22504254,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NFUIu.jpg?s=256",
                    "display_name": "forevernewbie",
                    "link": "https://stackoverflow.com/users/22504254/forevernewbie"
                },
                "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": 1695755504,
                "post_id": 77182646,
                "comment_id": 136066148,
                "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": 1695757405,
                "post_id": 77182646,
                "comment_id": 136066474,
                "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": 1695757647,
                "post_id": 77182646,
                "comment_id": 136066513,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 130446,
                    "reputation": 8369,
                    "user_id": 4154375,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QVkYF.png?s=256",
                    "display_name": "pjh",
                    "link": "https://stackoverflow.com/users/4154375/pjh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695758689,
                "post_id": 77182646,
                "comment_id": 136066673,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29371809,
                    "reputation": 1,
                    "user_id": 22504254,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NFUIu.jpg?s=256",
                    "display_name": "forevernewbie",
                    "link": "https://stackoverflow.com/users/22504254/forevernewbie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695787337,
                "post_id": 77182646,
                "comment_id": 136069469,
                "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": 1695817431,
                "post_id": 77182646,
                "comment_id": 136074376,
                "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": 1695817472,
                "post_id": 77182646,
                "comment_id": 136074384,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1695754358,
        "creation_date": 1695753432,
        "last_edit_date": 1695754358,
        "question_id": 77182646,
        "body_markdown": "I&#39;m running a bash script that would format an HTML entry, which, in turn, would be used as input for a JSON file. Below is the formatted HTML input which returns the expected output.\r\n\r\nRAW\r\n\r\n```\r\ntemplate=&#39;&quot;&#39;&#39;&lt;h3&gt;&lt;span style=\\&#39;&#39;&quot;text-decoration: underline;\\&#39;&#39;&quot;&gt;&lt;strong&gt;&lt;em&gt;Build Execute Summary&lt;/em&gt;&lt;/strong&gt;&lt;/span&gt;&lt;/h3&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;&lt;table style=\\&#39;&#39;&quot;border-collapse: collapse; width: 100%; height: 162px;\\&#39;&#39;&quot; border=\\&#39;&#39;&quot;1\\&#39;&#39;&quot;&gt;&lt;tbody&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Result&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&#39;$notif_result&#39;&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Infra Type&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;internal&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; text-align: center; height: 18px;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Environment&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; text-align: center; height: 18px;\\&#39;&#39;&quot;&gt;&#39;$environment&#39;&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; text-align: center; height: 18px;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Application Name&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; text-align: center; height: 18px;\\&#39;&#39;&quot;&gt;&#39;$application&#39;&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Build Name&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&#39;$region-$application-$environment-$notif_runnum&#39;&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Build Link&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&#39;$notif_url/$notif_repo/actions/runs/$notif_runid&#39;&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&#39;&#39;&quot;height: 18px;\\&#39;&#39;&quot;&gt;&lt;td style=\\&#39;&#39;&quot;width: 33.7887%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&lt;strong&gt;Executed By&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&#39;&#39;&quot;width: 66.2113%; height: 18px; text-align: center;\\&#39;&#39;&quot;&gt;&#39;$notif_actor&#39;&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;&#39;&#39;&quot;&#39;\r\n```\r\n\r\nVARIABLE OUTPUT\r\n\r\n```\r\n&quot;&lt;h3&gt;&lt;span style=\\&quot;text-decoration: underline;\\&quot;&gt;&lt;strong&gt;&lt;em&gt;Build Execute Summary&lt;/em&gt;&lt;/strong&gt;&lt;/span&gt;&lt;/h3&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;&lt;table style=\\&quot;border-collapse: collapse; width: 100%; height: 162px;\\&quot; border=\\&quot;1\\&quot;&gt;&lt;tbody&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; height: 18px; text-align: center;\\&quot;&gt;&lt;strong&gt;Result&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; height: 18px; text-align: center;\\&quot;&gt;$notif_result&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; height: 18px; text-align: center;\\&quot;&gt;&lt;strong&gt;Infra Type&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; height: 18px; text-align: center;\\&quot;&gt;internal&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; text-align: center; height: 18px;\\&quot;&gt;&lt;strong&gt;Environment&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; text-align: center; height: 18px;\\&quot;&gt;$environment&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; text-align: center; height: 18px;\\&quot;&gt;&lt;strong&gt;Application Name&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; text-align: center; height: 18px;\\&quot;&gt;$application&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; height: 18px; text-align: center;\\&quot;&gt;&lt;strong&gt;Build Name&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; height: 18px; text-align: center;\\&quot;&gt;$region-$application-$environment-$notif_runnum&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; height: 18px; text-align: center;\\&quot;&gt;&lt;strong&gt;Build Link&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; height: 18px; text-align: center;\\&quot;&gt;$notif_url/$notif_repo/actions/runs/$notif_runid&lt;/td&gt;&lt;/tr&gt;&lt;tr style=\\&quot;height: 18px;\\&quot;&gt;&lt;td style=\\&quot;width: 33.7887%; height: 18px; text-align: center;\\&quot;&gt;&lt;strong&gt;Executed By&lt;/strong&gt;&lt;/td&gt;&lt;td style=\\&quot;width: 66.2113%; height: 18px; text-align: center;\\&quot;&gt;$notif_actor&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;&quot;\r\n```\r\n\r\nNow, I&#39;m trying to use jq to read my JSON file and to insert the formatted variable above. I&#39;m using the --raw-input option so the backslashes in the template variable will be accepted. However, I&#39;m still getting the error below.\r\n\r\n```\r\njq --raw-input --slurp --ascii-output --arg html $template &#39;.Body.Html.Data = test&#39; ses_message.json &gt; ses_message.json\r\n```\r\n\r\n```\r\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\nstyle=\\&quot;text-decoration:      \r\njq: 1 compile error\r\n```\r\n\r\nIs it a quoting problem? If yes, how to correct it?\r\n\r\nBash JQuery.",
        "link": "https://stackoverflow.com/questions/77182646/jq-not-accepting-raw-input",
        "title": "jq not accepting raw input"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1695815446,
                "last_edit_date": 1695815446,
                "creation_date": 1695814885,
                "answer_id": 77187182,
                "question_id": 77187096,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use a regex with a word boundary:\r\n\r\n```bash\r\n$ echo &#39;[&quot;aa&quot;, &quot;bb&quot;, &quot;cc&quot;]&#39; | jq -r &#39;.[] | test([&quot;\\\\baa\\\\b&quot;]) | tostring | select(. == &quot;true&quot;)&#39;\r\ntrue\r\n\r\n$ echo &#39;[&quot;aa&quot;, &quot;bb&quot;, &quot;cc&quot;]&#39; | jq -r &#39;.[] | test([&quot;\\\\ba\\\\b&quot;]) | tostring | select(. == &quot;true&quot;)&#39;\r\n\r\n```",
                "title": "How can I check whether a string array includes a specified string in `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1695815446,
        "creation_date": 1695814153,
        "question_id": 77187096,
        "body_markdown": "I have an array of string in json format. I&#39;d like to check whether it includes a specific string value.\r\n\r\nI have tried to use `contains`:\r\n\r\n```\r\necho &#39;[&quot;aa&quot;, &quot;bb&quot;, &quot;cc&quot;]&#39; |jq &#39;. | contains([&quot;aa&quot;])&#39;\r\n&gt; true\r\n```\r\n\r\nit works but it also return true for a partial match: \r\n\r\n```\r\necho &#39;[&quot;aa&quot;, &quot;bb&quot;, &quot;cc&quot;]&#39; |jq &#39;. | contains([&quot;a&quot;])&#39;\r\n&gt; true\r\n```\r\n\r\nhow can I find the exact match?\r\n",
        "link": "https://stackoverflow.com/questions/77187096/how-can-i-check-whether-a-string-array-includes-a-specified-string-in-jq",
        "title": "How can I check whether a string array includes a specified string in `jq`?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1695818738,
                "post_id": 77187628,
                "comment_id": 136074663,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7084284,
                    "reputation": 43004,
                    "user_id": 5421539,
                    "user_type": "registered",
                    "accept_rate": 66,
                    "profile_image": "https://www.gravatar.com/avatar/e7d7d3f1b775287a7a9eaed48446380c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Joey Yi Zhao",
                    "link": "https://stackoverflow.com/users/5421539/joey-yi-zhao"
                },
                "reply_to_user": {
                    "account_id": 682692,
                    "reputation": 49935,
                    "user_id": 535275,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://i.sstatic.net/Ft2Mw.jpg?s=256",
                    "display_name": "Scott Hunter",
                    "link": "https://stackoverflow.com/users/535275/scott-hunter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1695818838,
                "post_id": 77187628,
                "comment_id": 136074684,
                "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": 1695818896,
                "post_id": 77187628,
                "comment_id": 136074697,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1695818888,
                "creation_date": 1695818888,
                "answer_id": 77187666,
                "question_id": 77187628,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to do\r\n```\r\nMATCH - (MATCH - COMPARE)\r\n```\r\n\r\nSo in your case:\r\n```\r\n[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;] - ([&quot;a&quot;, &quot;b&quot;, &quot;c&quot;] - [&quot;b&quot;, &quot;d&quot;, &quot;1&quot;])\r\n```\r\n\r\nWill output \r\n```json\r\n[\r\n  &quot;b&quot;\r\n]\r\n```\r\n",
                "title": "How can I use `jq` to find common values from two string arrays"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695819227,
                "creation_date": 1695819227,
                "answer_id": 77187705,
                "question_id": 77187628,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A more verbose method: count all the entries and keep the ones with count == 2\r\n```sh\r\njq -n --argjson arr1 &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; --argjson arr2 &#39;[&quot;b&quot;,&quot;d&quot;,&quot;1&quot;]&#39; &#39;\r\n    $arr1 + $arr2 \r\n    | reduce .[] as $x ({}; .[$x] += 1) \r\n    | to_entries \r\n    | map(select(.value == 2) | .key)\r\n&#39;\r\n```\r\n",
                "title": "How can I use `jq` to find common values from two string arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1695819227,
        "creation_date": 1695818604,
        "question_id": 77187628,
        "body_markdown": "I have two string arrays and I&#39;d like to find all strings from the second array that exist in the first array. For example:\r\n\r\n```\r\narr1=[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]\r\narr2=[&quot;b&quot;, &quot;d&quot;, &quot;1&quot;]\r\n```\r\n\r\nI&#39;d like to return `[&quot;b&quot;]`.\r\n\r\nI found some subtraction like:\r\n\r\n```\r\n&gt; jq --null-input &#39;[&quot;a&quot;, &quot;b&quot;, &quot;c&quot;] - [&quot;b&quot;, &quot;d&quot;, &quot;1&quot;]&#39;\r\n[\r\n  &quot;a&quot;,\r\n  &quot;c&quot;\r\n]\r\n```\r\n\r\nbut it removes the matched value. How can I get the opposite result?",
        "link": "https://stackoverflow.com/questions/77187628/how-can-i-use-jq-to-find-common-values-from-two-string-arrays",
        "title": "How can I use `jq` to find common values from two string arrays"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1695896300,
                "last_edit_date": 1695896300,
                "creation_date": 1695847727,
                "answer_id": 77190794,
                "question_id": 77190745,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Couldn&#39;t you just update (`|=`) every `.&quot;$ref&quot;` key that points to a string by prepending either the first `#` or the end of the string with `.json`?\r\n```sh\r\n(.. | objects.&quot;$ref&quot; | strings) |= sub(&quot;(?&lt;a&gt;#|$)&quot;; &quot;.json\\(.a)&quot;)\r\n```\r\n```json\r\n{\r\n  &quot;schema&quot;: &quot;http://json-schema.org/draft-04/schema#&quot;,\r\n  &quot;id&quot;: &quot;FubarAgent&quot;,\r\n  &quot;metaFormat&quot;: &quot;http://example.org/fubar/&quot;,\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;properties&quot;: {\r\n    &quot;extensions&quot;: {\r\n      &quot;$ref&quot;: &quot;TypeDefinitions.json#/extensions&quot;\r\n    },\r\n    &quot;name&quot;: {\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;maxLength&quot;: 2048,\r\n      &quot;title&quot;: &quot;name&quot;\r\n    },\r\n    &quot;membership&quot;: {\r\n      &quot;oneOf&quot;: [\r\n        {\r\n          &quot;$ref&quot;: &quot;Membership.json&quot;\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;maxLength&quot;: 2048\r\n        }\r\n      ]\r\n    }\r\n  },\r\n  &quot;title&quot;: &quot;FubarAgent&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/SwKq88YF_3f)\r\n\r\n---\r\n\r\n##### Note explaining the version conflict:\r\njq version 1.7 fixed a bug with empty regex matches (see the [release info](https://github.com/jqlang/jq/releases/tag/jq-1.7): &quot;Fix empty regular expression matches. @itchyny [#2677](https://github.com/jqlang/jq/pull/2677)&quot;). Prior to this version, the group matching on `$` would provide no corresponding field in the result object at all (while v1.7 produces `{&quot;a&quot;: &quot;&quot;}`), so the string interpolation of `.a` would evaluate to `null`, producing the literal string `&quot;null&quot;`, which for this example eventually leads to the undesired result of `&quot;$ref&quot;: &quot;Membership.jsonnull&quot;`.\r\n\r\nFor versions 1.5+ (since regexp support was added), this can be mitigated by explicitly treating that case: Add `// &quot;&quot;` to manually provide the empty string as an alternative if `.a` evaluates to a *falsy* value (like `null`).\r\n```sh\r\n(.. | objects.&quot;$ref&quot; | strings) |= sub(&quot;(?&lt;a&gt;#|$)&quot;; &quot;.json\\(.a // &quot;&quot;)&quot;)\r\n```",
                "title": "How to modify JSON property values at any depth with regex?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1695896300,
        "creation_date": 1695847180,
        "question_id": 77190745,
        "body_markdown": "I&#39;ve received a collection of JSON schema files I must use to validate some data in JSON. \r\n The values of the `$ref` properties in the schema are incomplete.  The validator tool is unable to resolve the references.  When I manually edit the `$ref` values in some schema files, I can get the validation to partially work.  However, the collection of JSON schema files is huge and I can&#39;t edit all of them manually, so I thought I could use jq to fix them.\r\n\r\nAn example of a schema with incomplete `$ref` values…\r\n\r\n    {\r\n      &quot;schema&quot;: &quot;http://json-schema.org/draft-04/schema#&quot;,\r\n      &quot;id&quot;: &quot;FubarAgent&quot;,\r\n      &quot;metaFormat&quot;: &quot;http://example.org/fubar/&quot;,\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;properties&quot;: {\r\n        &quot;extensions&quot;: {\r\n          &quot;$ref&quot;: &quot;TypeDefinitions#/extensions&quot;\r\n        },\r\n        &quot;name&quot;: {\r\n          &quot;type&quot;: &quot;string&quot;,\r\n          &quot;maxLength&quot;: 2048,\r\n          &quot;title&quot;: &quot;name&quot;\r\n        },\r\n        &quot;membership&quot;: {\r\n          &quot;oneOf&quot;: [\r\n            {\r\n              &quot;$ref&quot;: &quot;Membership&quot;\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;string&quot;,\r\n              &quot;maxLength&quot;: 2048\r\n            }\r\n          ]\r\n        }\r\n      },\r\n      &quot;title&quot;: &quot;FubarAgent&quot;\r\n    }\r\n\r\nThe problem is that each schema file is named `*object_name*.json`.  When the validator tries to resolve references in files named `TypeDefinitions` and `Membership` it fails, because the files are actually named `TypeDefinitions.json` and `Membership.json`.  The references above should be `TypeDefinitions.json#/extensions` and `Membership.json`, respectively.  (So, not simply appending `.json`.)   I tried to come up with jq code to use a regex to edit these references at any depth, but I haven&#39;t quite figured it out.\r\n\r\nI came close in an earlier attempt, but it didn&#39;t work at all depths or use a regex.  The current version I have uses regex and works on some files, but not all.  It is…\r\n\r\n    jq &#39;walk(if type == &quot;object&quot; and has(&quot;$ref&quot;) then .[&quot;$ref&quot;] = (. | sub(&quot;(?&lt;a&gt;[^#]*)(?&lt;b&gt;#.*)*$&quot;; &quot;\\(.a).json\\(.b + &quot;&quot;)&quot;)) else . end)&#39; FubarAgent.json\r\n\r\nWith the example schema from above, the output is…\r\n\r\n    jq: error (at FubarAgent.json:28): object ({&quot;$ref&quot;:&quot;Ty...) cannot be matched, as it is not a string\r\n\r\nWhat should I do to fix it?  Also, it seems that what I have is very long.  Maybe there&#39;s a shorter way to do this that someone could recommend?",
        "link": "https://stackoverflow.com/questions/77190745/how-to-modify-json-property-values-at-any-depth-with-regex",
        "title": "How to modify JSON property values at any depth with regex?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1695972947,
                "post_id": 77199004,
                "comment_id": 136097119,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695955598,
                "last_edit_date": 1695955598,
                "creation_date": 1695954308,
                "answer_id": 77199167,
                "question_id": 77199004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I don&#39;t know if I&#39;d call this _&quot;slick&quot;_, but here&#39;s one `jq` filter that can do it (using `--null-input` and `--raw-input` options).\r\n\r\nN.B.:  If you have any non-word characters (like `-`), you may want to use something like `scan(&quot;[^\\\\s]+&quot;)`, or equivalently `scan(&quot;\\\\S+&quot;)` instead.  I.e., anything that is not in the space character class.\r\n```\r\n[inputs| [scan(&quot;\\\\w+&quot;), (input_line_number/3|ceil)]]\r\n| group_by(.[2])\r\n| map(map({(.[0]): .[1]})|add)\r\n```\r\nor as a one-liner for your `~/.netrc` file:\r\n```\r\njq --null-input --raw-input &#39;[inputs| [scan(&quot;\\\\w+&quot;), (input_line_number/3|ceil)]] | group_by(.[2]) | map(map({(.[0]): .[1]})|add)&#39; ~/.netrc\r\n```\r\nOutput, given the example input:\r\n```lang-json\r\n[\r\n  {\r\n    &quot;machine&quot;: &quot;foo&quot;,\r\n    &quot;login&quot;: &quot;usera&quot;,\r\n    &quot;password&quot;: &quot;somepass&quot;\r\n  },\r\n  {\r\n    &quot;machine&quot;: &quot;somehost&quot;,\r\n    &quot;login&quot;: &quot;userb&quot;,\r\n    &quot;password&quot;: &quot;otherpass&quot;\r\n  }\r\n]\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/l-4KTfQH2SF &quot;Click me!&quot;).",
                "title": "Creating groupings in JQ from a raw file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1695975290,
                "creation_date": 1695975290,
                "answer_id": 77200371,
                "question_id": 77199004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq --null-input --raw-input\\\r\n  &#39;reduce (inputs | scan(&quot;(\\\\w+) (.*)&quot;)) as [$k,$v] (\r\n   [] ; .[(input_line_number / 3 | ceil - 1)][$k] = $v\r\n   )&#39; ~/.netrc\r\n```",
                "title": "Creating groupings in JQ from a raw file"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1695978726,
                "last_edit_date": 1695978726,
                "creation_date": 1695975641,
                "answer_id": 77200413,
                "question_id": 77199004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one approach simply splitting at whitespaces, then interpreting the first two words from each line as key and value, respectively.\r\n```sh\r\njq -Rn &#39;[[inputs | [splits(&quot;\\\\s+&quot;)] | {(.[0]):.[1]}] | _nwise(3) | add]&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;machine&quot;: &quot;foo&quot;,\r\n    &quot;login&quot;: &quot;usera&quot;,\r\n    &quot;password&quot;: &quot;somepass&quot;\r\n  },\r\n  {\r\n    &quot;machine&quot;: &quot;somehost&quot;,\r\n    &quot;login&quot;: &quot;userb&quot;,\r\n    &quot;password&quot;: &quot;otherpass&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/vb8WRt9auUO)\r\n\r\nNotes:\r\n- If you want to disregard empty lines, replace `inputs` with `inputs | select(length &gt; 0)`. If you want to also disregard any whitespace-only lines, replace with `inputs | select(test(&quot;\\\\S&quot;))` instead.\r\n- If you want to allow for key-only lines, provide a default which is then used as value instead (e.g. the empty string `&quot;&quot;`) by changing `.[1]` to `(.[1] // &quot;&quot;)`.\r\n- If you want the entire rest of the line be the value, not just the second word (i.e. including all subsequent whitespaces as is), replace `[splits(&quot;\\\\s+&quot;)]` with `scan(&quot;(\\\\S+)(?:\\\\s+(.*))?&quot;)`.\r\n- If you&#39;re uncomfortable using undocumented `_nwise` for the grouping, replace it with `while(has(0);.[3:])[:3]`.",
                "title": "Creating groupings in JQ from a raw file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1696016624,
        "creation_date": 1695949858,
        "last_edit_date": 1696016624,
        "question_id": 77199004,
        "body_markdown": "So, I have a .netrc file that looks like this:\r\n\r\n```\r\nmachine foo\r\nlogin usera\r\npassword somepass\r\nmachine somehost\r\nlogin userb\r\npassword otherpass\r\n```\r\n\r\nAnd I am trying to get it into an array of object, grouped in sets of 3, which I can then sort and select out uniq ones (yes, there are probably other, non jq ways...)\r\n\r\nAnd I keep getting lost. Here&#39;s what I have:\r\n\r\n```shell\r\njq -Rs &#39;\r\nsplit(&quot;\\n&quot;) |\r\nmap(select(length &gt; 0)) |\r\n\tmap(split(&quot; &quot;) |\r\n\t\t\tto_entries | group_by(.key % 2 == 0)\r\n\t) |\r\n\tmap(\r\n\t\tmap(.[0].value )\r\n\t) |\r\n\tmap({\r\n\t\t(.[1]) : .[0]\r\n\t}) | add&#39;\r\n&#39; ~/.netrc\r\n```\r\n\r\nexpected\r\n```json\r\n[\r\n  {\r\n    &quot;machine&quot;: &quot;foo&quot;,\r\n    &quot;login&quot;: &quot;usera&quot;,\r\n    &quot;password&quot;: &quot;somepass&quot;\r\n  },\r\n  {\r\n    &quot;machine&quot;: &quot;somehost&quot;,\r\n    &quot;login&quot;: &quot;userb&quot;,\r\n    &quot;password&quot;: &quot;otherpass&quot;\r\n  }\r\n]\r\n```\r\n\r\nI&#39;d love to see something slick to solve this",
        "link": "https://stackoverflow.com/questions/77199004/creating-groupings-in-jq-from-a-raw-file",
        "title": "Creating groupings in JQ from a raw file"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 1696159124,
                "post_id": 77210078,
                "comment_id": 136115312,
                "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": 1696325061,
                "post_id": 77210078,
                "comment_id": 136135247,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1696174134,
        "creation_date": 1696156044,
        "last_edit_date": 1696174134,
        "question_id": 77210078,
        "body_markdown": "I&#39;m working on a project which manages multiple machines and their Username and IP are stored in a JSON array.\r\n\r\n```json\r\n{\r\n  &quot;a.b.c.d&quot; : {\r\n    &quot;visible&quot; : true,\r\n    &quot;color&quot; : &quot;rgb(0, 255, 192)&quot;,\r\n    &quot;user&quot; : &quot;ubuntu&quot;, #Optional\r\n    &quot;address&quot; : &quot;a.b.c.d&quot;,\r\n    &quot;label&quot; : &quot;VPS-Box&quot; #Optional\r\n  },\r\n  &quot;a.b.c.d&quot; : {\r\n    &quot;visible&quot; : true,\r\n    &quot;color&quot; : &quot;rgb(125, 255, 0)&quot;,\r\n    &quot;address&quot; : &quot;a.b.c.d&quot;\r\n  }\r\n}\r\n```\r\n\r\nI have a very basic API which only needs one thing and that&#39;s to listen for the client application to send its pub IP over telnet in my case the listener is netcat\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nwhile true; do\r\n\r\n    nc -l -p 1337 &gt;&gt; #here it needs to insert the data in to the json array\r\n\r\ndone\r\n```\r\n\r\nI have gone through many ways to do it using awk, sek, echo nothing works the way I want it to \r\n\r\n```json\r\n&quot;nc value&quot; : {\r\n    &quot;visible&quot; : true,\r\n    &quot;color&quot; : &quot;rgb(0, 253, 255)&quot;,\r\n    &quot;user&quot; : &quot;REDACTED&quot;,\r\n    &quot;address&quot; : &quot;nc value&quot;,\r\n```\r\n\r\nHow should I do this in a way that doesn&#39;t corrupt the entire JSON and make the application unusable? My last try below\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\nwhile true; do\r\n    received_data=$(nc -l -p 1337 | tr -d &#39; &#39;)  # Remove spaces from received data\r\n    echo &quot;$received_data&quot; &gt;&gt; /nc-log.txt # just to see if its correctly received\r\n\r\n    # Check if the received data is a valid IP address\r\n    if [[ $received_data =~ ^[0-9]+\\.[0-9]+\\.[0-9]+\\.[0-9]+$ ]]; then\r\n        # Construct the JSON entry\r\n        new_entry=&quot;{\\&quot;visible\\&quot;: true, \\&quot;color\\&quot;: \\&quot;rgb(0, 253, 255)\\&quot;, \\&quot;user\\&quot;: \\&quot;REDACTED\\&quot;, \\&quot;address\\&quot;: \\&quot;$received_data\\&quot;}&quot;\r\n\r\n        # Add the new entry to Machines.json\r\n        jq &quot;. += {\\&quot;$received_data\\&quot;: $new_entry}&quot; /Machines.json &gt; tmp.json &amp;&amp; mv tmp.json /Machines.json\r\n    fi\r\ndone\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77210078/add-object-to-array-with-jq",
        "title": "Add object to array with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1696339748,
                "post_id": 77222636,
                "comment_id": 136137978,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17722379,
                    "reputation": 2272,
                    "user_id": 12867091,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Qa0nK.jpg?s=256",
                    "display_name": "Tashkhisi",
                    "link": "https://stackoverflow.com/users/12867091/tashkhisi"
                },
                "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": 1696340068,
                "post_id": 77222636,
                "comment_id": 136138054,
                "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": 1696347508,
                "post_id": 77222636,
                "comment_id": 136139704,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1696341013,
                "last_edit_date": 1696341013,
                "creation_date": 1696340712,
                "answer_id": 77222843,
                "question_id": 77222636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll get better/more succinct answers, but this seems to work.  _Slurp_ both files into an array, use `file1.json` contents as a filter to `reduce` `file2.json`.\r\n```\r\njq --slurp &#39;.[0] as $filt | reduce .[1][] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)&#39; file1.json file2.json\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/k6QU3QheCar &quot;Click me!&quot;).\r\n\r\nIf the file sizes are large, this might be better since it doesn&#39;t _slurp_.\r\n```\r\njq --null-input &#39;input as $filt | reduce inputs[] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)&#39; file1.json file2.json\r\n```\r\nTry this on [jqplay.org](https://jqplay.org/s/jKZa2epkuql &quot;Clicik me too!&quot;).\r\n\r\nBoth output:\r\n```lang-json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;name&quot;: &quot;name6&quot;\r\n  }\r\n]\r\n```",
                "title": "Process multiple files in jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1696362075,
                "creation_date": 1696362075,
                "answer_id": 77225083,
                "question_id": 77222636,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With both inputs already being arrays, there&#39;s no need to `--slurp`. Also, as there are exactly two inputs, there&#39;s also no need to call on `--null-input`, just use `input` for the second one. For example, using the inputs in reversed order:\r\n```sh\r\njq &#39;input as $ids | map(select(IN(.id; $ids[])))&#39; file2.json file1.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;name&quot;: &quot;name6&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/_Ce4054_22V)",
                "title": "Process multiple files in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1696362075,
        "creation_date": 1696339172,
        "question_id": 77222636,
        "body_markdown": "Imagine I have two files as below:\r\n\r\nfile1:\r\n```\r\n[   \r\n  &quot;id1&quot;,\r\n  &quot;id2&quot;\r\n]\r\n```\r\n\r\nfile2:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id3&quot;,\r\n    &quot;name&quot;: &quot;name3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id5&quot;,\r\n    &quot;name&quot;: &quot;name5&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;name&quot;: &quot;name6&quot;\r\n  }\r\n]\r\n```\r\n\r\nI want to find those entries in file2 that their id exist in file1, in the example above the expected output should be like:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id1&quot;,\r\n    &quot;name&quot;: &quot;name2&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;id2&quot;,\r\n    &quot;name&quot;: &quot;name6&quot;\r\n  }\r\n]\r\n```\r\nHow can I achieve it with jq.\r\n",
        "link": "https://stackoverflow.com/questions/77222636/process-multiple-files-in-jq",
        "title": "Process multiple files in jq"
    },
    {
        "tags": [
            "jq",
            "newrelic",
            "nrql"
        ],
        "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": 1696363846,
                "post_id": 77224785,
                "comment_id": 136142795,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1696360245,
                "creation_date": 1696360245,
                "answer_id": 77224932,
                "question_id": 77224785,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given `{&quot;timestamp&quot;: &quot;1696358217197&quot;}`, extract the string using `.timestamp`, convert to number using `tonumber`, divide by 1000 to convert milliseconds to seconds, and finally convert to your preferred date format using `strftime` (`%F` is equivalent to `%Y-%m-%d`):\r\n```sh\r\njq -r &#39;.timestamp | tonumber / 1000 | strftime(&quot;%F&quot;)&#39;\r\n```\r\n```\r\n2023-10-03\r\n```\r\n[Demo](https://jqplay.org/s/mOjSp6HKDOj)",
                "title": "Convert timestamp with month name to readable time stamp with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1696360245,
        "creation_date": 1696358583,
        "question_id": 77224785,
        "body_markdown": "I have the following output when I query data through API to New Relic:\r\n\r\n&quot;timestamp&quot;: &quot;1696358217197&quot;\r\n\r\nThis is a timestamp prefixed with a month (This number is supposed to be October).\r\nI&#39;m processing the information through JQ but I can&#39;t find a way to convert from this format to Year-Month-Day (ie: 2023-10-02).\r\n\r\nTried all the options I could find and I can&#39;t find neither a way to display the date correctly from New Relic API, nor to interpret it with JQ.\r\nI&#39;m borderline using sed to replace the information since my script already accepts date as an argument.\r\n\r\nIs there a better way?",
        "link": "https://stackoverflow.com/questions/77224785/convert-timestamp-with-month-name-to-readable-time-stamp-with-jq",
        "title": "Convert timestamp with month name to readable time stamp with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1696494303,
                "creation_date": 1696494303,
                "answer_id": 77235423,
                "question_id": 77235385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `to_entries` to get an array of key-value pairs. Search the values using `IN`, and output the key. Use `--arg` to import a string from the command-line.\r\n\r\n```sh\r\njq -r --arg q &quot;service-a&quot; &#39;to_entries[] | select(IN($q; .value[]?)).key&#39;\r\n```\r\n```\r\nblue_services\r\n```\r\n[Demo](https://jqplay.org/s/uEZorg5A35S)",
                "title": "return name of the array that contains certain key with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1696522491,
                "last_edit_date": 1696522491,
                "creation_date": 1696505506,
                "answer_id": 77236721,
                "question_id": 77235385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another way to do it by _streaming_ the input.  `select` passes only arrays having `$q` (your variable input) as an element, and then `.[0][-2]` extracts the key name for the array.\r\n```\r\njq --stream -r --arg q &quot;service-a&quot; &#39;select((.[0][-1] | numbers) and (.[1] == $q)) | .[0][-2]&#39;\r\n```\r\nAdapted demo on [jqplay.org](https://jqplay.org/s/3SLSMMoVIcd &quot;Click me!&quot;).",
                "title": "return name of the array that contains certain key with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1696593001,
                "creation_date": 1696593001,
                "answer_id": 77244211,
                "question_id": 77235385,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have two good answers to your specific question already. I have a more generalized answer for how to search JSON without having to rewrite your query every time the JSON structure changes: a script called [jqg](https://github.com/NorthboundTrain/jqg/) that can, among other things, execute PCRE-compatible searches within the JSON printing out the results. Using your example JSON:\r\n\r\n    $ jqg service-h /tmp/example.json\r\n    {\r\n      &quot;black_services.1&quot;: &quot;service-h&quot;\r\n    }\r\n\r\nBy default, the script will flatten the JSON, search both keys and values for the given string, and output the results. There are many options to control both the searching and the results; this invocation will search only values for the string (`-v`), and output the original, unflattened JSON (`-t unflatten`):\r\n\r\n    $ jqg -t unflatten -v service-h /tmp/example.json\r\n    {\r\n      &quot;black_services&quot;: [\r\n        null,\r\n        &quot;service-h&quot;\r\n      ]\r\n    }\r\n\r\nSparse arrays are a little wonky, as you can see. With the unflattened JSON, though, you can dump that back into `jq` to manipulate it as you like, e.g. pull out just the top level key:\r\n\r\n    $ jqg -t unflatten -v service-h /tmp/example.json | jq -r &#39;. | keys[]&#39;\r\n    black_services\r\n\r\nThat simple manipulation can be done in `jqg` itself, though (`jqu` automatically unflattens the results, `-K` says to output just the keys in the results, and `-r` works just like it does in `jq`):\r\n\r\n    $ jqu -rKv service-h /tmp/example.json\r\n    black_services\r\n\r\nWhere it shines is when the json structure changes, especially when the structure is arbitrarily complex. Using this (randomly generated) JSON:\r\n\r\n    {\r\n      &quot;dicta&quot;: 299,\r\n      &quot;erat&quot;: &quot;mentitum proin putent&quot;,\r\n      &quot;tale&quot;: {\r\n        &quot;appareat&quot;: &quot;dignissim&quot;,\r\n        &quot;dictas&quot;: &quot;signiferumque netus mundi offendit&quot;,\r\n        &quot;quando&quot;: [\r\n          &quot;mazim torquent similique&quot;,\r\n          &quot;autem&quot;,\r\n          237\r\n        ],\r\n        &quot;proin&quot;: {\r\n          &quot;iudicabit&quot;: true,\r\n          &quot;copiosae&quot;: &quot;fabulas non nec brute&quot;,\r\n          &quot;antiopam&quot;: -111,\r\n          &quot;montes&quot;: &quot;consequuntur torquatos dictas nusquam&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nI can easily execute PCRE-compatible searches:\r\n\r\n    $ jqg &#39;dictas|proin&#39; /tmp/complex.json\r\n    {\r\n      &quot;erat&quot;: &quot;mentitum proin putent&quot;,\r\n      &quot;tale.dictas&quot;: &quot;signiferumque netus mundi offendit&quot;,\r\n      &quot;tale.proin.iudicabit&quot;: true,\r\n      &quot;tale.proin.copiosae&quot;: &quot;fabulas non nec brute&quot;,\r\n      &quot;tale.proin.antiopam&quot;: -111,\r\n      &quot;tale.proin.montes&quot;: &quot;consequuntur torquatos dictas nusquam&quot;\r\n    }\r\n\r\nwith unflattened results:\r\n\r\n    $ jqu &#39;dictas|proin&#39; /tmp/complex.json\r\n    {\r\n      &quot;erat&quot;: &quot;mentitum proin putent&quot;,\r\n      &quot;tale&quot;: {\r\n        &quot;dictas&quot;: &quot;signiferumque netus mundi offendit&quot;,\r\n        &quot;proin&quot;: {\r\n          &quot;iudicabit&quot;: true,\r\n          &quot;copiosae&quot;: &quot;fabulas non nec brute&quot;,\r\n          &quot;antiopam&quot;: -111,\r\n          &quot;montes&quot;: &quot;consequuntur torquatos dictas nusquam&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nsearching just the values:\r\n\r\n    $ jqu -v &#39;dictas|proin&#39; /tmp/complex.json\r\n    {\r\n      &quot;erat&quot;: &quot;mentitum proin putent&quot;,\r\n      &quot;tale&quot;: {\r\n        &quot;proin&quot;: {\r\n          &quot;montes&quot;: &quot;consequuntur torquatos dictas nusquam&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nprinting out just the raw top level keys:\r\n\r\n    $ jqu -rKv &#39;dictas|proin&#39; /tmp/complex.json\r\n    erat\r\n    tale\r\n\r\nSo, the same basic `jqg` invocation run on both radically different JSON structures produces the same, desired output:\r\n\r\n    $ jqu -rKv service-h /tmp/example.json\r\n    black_services\r\n    \r\n    $ jqu -rKv &#39;dictas|proin&#39; /tmp/complex.json\r\n    erat\r\n    tale\r\n\r\nNote: I am the author of `jqg`\r\n",
                "title": "return name of the array that contains certain key with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1696593001,
        "creation_date": 1696493996,
        "question_id": 77235385,
        "body_markdown": "I have the following JSON: \r\n\r\n```\r\n{\r\n  &quot;somekey&quot;: &quot;somevalue&quot;,\r\n  &quot;blue_services&quot;: [\r\n    &quot;service-a&quot;,\r\n    &quot;service-b&quot;,\r\n    &quot;service-c&quot;\r\n  ],\r\n  &quot;otherkey&quot;: &quot;othervalue&quot;,\r\n  &quot;red_services&quot;: [\r\n    &quot;service-d&quot;,\r\n    &quot;service-e&quot;,\r\n    &quot;service-f&quot;\r\n  ],\r\n  &quot;black_services&quot;: [\r\n    &quot;service-g&quot;,\r\n    &quot;service-h&quot;,\r\n    &quot;service-i&quot;\r\n  ]\r\n}\r\n```\r\n\r\nI want `jq` to return the name of the array that contains certain value: \r\n\r\nfor example:\r\n\r\nif I look for `service-a` jq should return `blue_services`  \r\nif I look for `service-h` jq should return `black_services`  \r\n\r\nI manage to extract the arrays that match certain regexp with: \r\n\r\n```\r\nkeys[] | select(test (&quot;[aA-zZ]_services&quot;))\r\n```\r\n\r\nBut i dont know how to then search inside for a match and return the relevant name, I have also tried piping to contains/has/any\r\n\r\nideally I would like to use a variable to be able to do several searches for service-x",
        "link": "https://stackoverflow.com/questions/77235385/return-name-of-the-array-that-contains-certain-key-with-jq",
        "title": "return name of the array that contains certain key with jq"
    },
    {
        "tags": [
            "arrays",
            "shell",
            "select",
            "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": 1696496900,
                "post_id": 77235620,
                "comment_id": 136161408,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1696499947,
                "last_edit_date": 1696499947,
                "creation_date": 1696497870,
                "answer_id": 77235822,
                "question_id": 77235620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given a JSON input like\r\n```json\r\n{\r\n  &quot;member&quot;: [\r\n    {\r\n      &quot;firstName&quot;: &quot;Paul&quot;,\r\n      &quot;lastName&quot;: &quot;Simons&quot;,\r\n      &quot;certificates&quot;: [\r\n        {\r\n          &quot;status&quot;: &quot;Pass&quot;,\r\n          &quot;grade&quot;: {\r\n            &quot;type&quot;: &quot;music&quot;,\r\n            &quot;level&quot;: 3\r\n          },\r\n          &quot;awardDate&quot;: &quot;2023-01-28&quot;\r\n        },\r\n        {\r\n          &quot;status&quot;: &quot;Pass&quot;,\r\n          &quot;grade&quot;: {\r\n            &quot;type&quot;: &quot;sports&quot;,\r\n            &quot;level&quot;: 2\r\n          },\r\n          &quot;awardDate&quot;: &quot;2021-02-02&quot;\r\n        },\r\n        {\r\n          &quot;status&quot;: &quot;Pass&quot;,\r\n          &quot;grade&quot;: {\r\n            &quot;type&quot;: &quot;music&quot;,\r\n            &quot;level&quot;: 2\r\n          },\r\n          &quot;awardDate&quot;: &quot;2021-02-02&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nYou could use `group_by` to combine same grade types, and `max_by` to get the one with the highest grade level:\r\n```sh\r\n.member[] | [&quot;\\(.firstName) \\(.lastName)&quot;, (.certificates\r\n  | group_by(.grade.type)[] | max_by(.grade.level)\r\n  | &quot;[\\(.grade.type), \\(.grade.level), \\(.awardDate)]&quot;\r\n)] | join(&quot;, &quot;) + &quot;.&quot;\r\n```\r\n```\r\nPaul Simons, [music, 3, 2023-01-28], [sports, 2, 2021-02-02].\r\n```\r\n[Demo](https://jqplay.org/s/jD6hJzgkoHD)",
                "title": "jq - unable to correctly perform multiple selects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1696499947,
        "creation_date": 1696496157,
        "last_edit_date": 1696496226,
        "question_id": 77235620,
        "body_markdown": "I&#39;ve been reading through other posts and jq reference pages but I cannot seem to get this working.\r\n\r\nExample data\r\n\r\n```\r\n{\r\n\t&quot;member&quot;: [\r\n\t{\r\n\t\t&quot;firstName&quot;: &quot;Paul&quot;\r\n\t\t&quot;lastName&quot;: &quot;Simons&quot;\r\n\t\t&quot;certificates&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;status&quot; : &quot;Pass&quot;,\r\n\t\t\t\t&quot;grade&quot; : {\r\n\t\t\t\t  &quot;type&quot; : &quot;music&quot;,\r\n\t\t\t\t  &quot;level&quot; : 3\r\n\t\t\t\t},\r\n\t\t\t&quot;awardDate&quot; : &quot;2023-01-28&quot;\r\n\t\t\t}\r\n\t\t\t{\r\n\t\t\t\t&quot;status&quot; : &quot;Pass&quot;,\r\n\t\t\t\t&quot;grade&quot; : {\r\n\t\t\t\t  &quot;type&quot; : &quot;sports&quot;,\r\n\t\t\t\t  &quot;level&quot; : 2\r\n\t\t\t\t},\r\n\t\t\t&quot;awardDate&quot; : &quot;2021-02-02&quot;\r\n\t\t\t}\r\n                        {\r\n\t\t\t\t&quot;status&quot; : &quot;Pass&quot;,\r\n\t\t\t\t&quot;grade&quot; : {\r\n\t\t\t\t  &quot;type&quot; : &quot;music&quot;,\r\n\t\t\t\t  &quot;level&quot; : 2\r\n\t\t\t\t},\r\n\t\t\t&quot;awardDate&quot; : &quot;2021-02-02&quot;\r\n\t\t\t}\r\n\t}\r\n]\r\n}\r\n```\r\n\r\n\r\nThe aim is to list: each members name, date of most senior grade (per type), type of grade, level of grade.\r\n\r\n```\r\nPaul Simmons, [music, 3, 2023-01-28], [sports, 2, 2021-02-02].\r\n```\r\n\r\n\r\n\r\nWhere I&#39;ve gotten to before my head exploded:\r\n```\r\njq -r &#39;.member[] |\r\n[.firstName + &quot; &quot; + .lastName, (.certificates\r\n| sort_by(.awardDate)\r\n| (.[-1].awardDate) as $max\r\n| .[]\r\n| select(.grade.type)\r\n| select(.awardDate == $max)\r\n| [(.awardDate | fromdateiso8601 | strflocaltime(&quot;%Y-%m-%d&quot;)), .grade.type, .grade.level])&#39;] members.json\r\n```\r\n\r\nDetermining the most recent level (per type of certificate), could also be finding the highest level, rather than using date - however I was having trouble.",
        "link": "https://stackoverflow.com/questions/77235620/jq-unable-to-correctly-perform-multiple-selects",
        "title": "jq - unable to correctly perform multiple selects"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1696579150,
                "post_id": 77242778,
                "comment_id": 136173885,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1696581436,
                "last_edit_date": 1696581436,
                "creation_date": 1696579861,
                "answer_id": 77242850,
                "question_id": 77242778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Traverse to each path of interest, and use `|=` to update them based on their current value. For this, you can use your `if` expression to distiguish the cases (note that since jq 1.7 the default `else .` branch can be omitted):\r\n```sh\r\n.[].Action.Charge |= if . &gt; 0 then 34 end\r\n```\r\n[Demo](https://jqplay.org/s/zGtHQnYubhh)\r\n\r\nAlternatively, you could also pre-filter the paths of interest using `select` on the LHS (note the added parentheses), and just assign the new value to them (using `=` as there is no dependecy on the previous value anymore):\r\n```sh\r\n(.[].Action.Charge | select(. &gt; 0)) = 34\r\n```\r\n[Demo](https://jqplay.org/s/-okKbyMVUil)\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 34,\r\n      &quot;Discharge&quot;: 100\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T01:00:00Z&quot;\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 0,\r\n      &quot;Discharge&quot;: 22\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T04:00:00Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nIf you want to provide the new value from the command line, use the `--argjson` flag for JSON values (like a number), or the `--arg` flag for raw strings:\r\n```sh\r\njq --argjson val 34 &#39;.[].Action.Charge |= if . &gt; 0 then $val end&#39;\r\n# or\r\njq --argjson val 34 &#39;(.[].Action.Charge | select(. &gt; 0)) = $val&#39;\r\n```",
                "title": "Update property value sub objects that match a filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1696581558,
        "creation_date": 1696579105,
        "last_edit_date": 1696581558,
        "question_id": 77242778,
        "body_markdown": "For example in JavaScript:\r\n```javascript\r\nlist.map(z =&gt; {if (z.Action.Charge &gt; 0) { z.Action.Charge = 1;} return z;)\r\n```\r\n\r\nThe closest I&#39;ve got in `jq` is\r\n```bash\r\ncat list | jq &#39;.values  = .values  | if ( .value.Action.Charge == 0 ) then ( .value.Action.Charge = 1 ) else . end&#39;\r\n```\r\nbut it doesn&#39;t do anything.\r\n\r\n\r\nInput\r\n```json\r\n[\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 21,\r\n      &quot;Discharge&quot;: 100\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T01:00:00Z&quot;\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 0,\r\n      &quot;Discharge&quot;: 22\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T04:00:00Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nRequired output\r\n```json\r\n[\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 34,\r\n      &quot;Discharge&quot;: 100\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T01:00:00Z&quot;\r\n  },\r\n  {\r\n    &quot;Action&quot;: {\r\n      &quot;Charge&quot;: 0,\r\n      &quot;Discharge&quot;: 22\r\n    },\r\n    &quot;T&quot;: &quot;2023-10-05T04:00:00Z&quot;\r\n  }\r\n]\r\n```\r\n\r\nThe first object in the list where `Action.Charge` is nonzero has been updated with the new value.\r\n",
        "link": "https://stackoverflow.com/questions/77242778/update-property-value-sub-objects-that-match-a-filter",
        "title": "Update property value sub objects that match a filter"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 4,
                "creation_date": 1696590857,
                "post_id": 77243900,
                "comment_id": 136175987,
                "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"
                },
                "reply_to_user": {
                    "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": 1696591440,
                "post_id": 77243900,
                "comment_id": 136176104,
                "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": 1696609312,
                "post_id": 77243900,
                "comment_id": 136179763,
                "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": 1696609469,
                "post_id": 77243900,
                "comment_id": 136179795,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1696608832,
                "last_edit_date": 1696608832,
                "creation_date": 1696594580,
                "answer_id": 77244361,
                "question_id": 77243900,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need bash/a shell here at all, nor multiple invocations of `jq`. A single call can solve your problem:\r\n\r\n```\r\njq -r &#39;\r\n[.tasks[].directory] as $paths\r\n| .packages[]\r\n| . as $app\r\n| $paths[]\r\n| (\r\n  &quot;path \\(.)&quot;,\r\n  &quot;built app \\($app)&quot;,\r\n  (select(contains($app)) | &quot;it is a match&quot;)\r\n)\r\n&#39; affected.json\r\n```\r\n\r\nOutput:\r\n\r\n```\r\npath packages/subfolder/package-1\r\nbuilt app package-1\r\nit is a match\r\npath packages/subfolder/package-2\r\nbuilt app package-1\r\n```",
                "title": "I am having an issue performing string matching within a for loop in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1696609628,
        "creation_date": 1696589902,
        "question_id": 77243900,
        "body_markdown": "I have a simple script where I am attempting to extract the directory path of a package from a json file using a bash script.\r\n\r\nI&#39;m really struggling to correctly perform the check to see whether a string performs a substring within a for loop, using variables.\r\n\r\nexample below:\r\n\r\naffected.json\r\n```json\r\n{\r\n  &quot;packages&quot;: [\r\n    &quot;package-1&quot;\r\n  ],\r\n  &quot;tasks&quot;: [\r\n    {\r\n      &quot;directory&quot;: &quot;packages/subfolder/package-1&quot;\r\n    },\r\n    {\r\n      &quot;directory&quot;: &quot;packages/subfolder/package-2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nmain.sh\r\n\r\n```bash\r\n#!/bin/sh\r\n\r\nBUILT_APPS=($(jq -r &#39;.packages[] | @sh&#39; affected.json))\r\nPATHS=($(jq -r &#39;.tasks[] | .directory | @sh&#39; affected.json))\r\n\r\nfor PATH in ${PATHS[@]}; do\r\n  for BUILT_APP in ${BUILT_APPS[@]}; do\r\n    echo &#39;path&#39; $PATH\r\n    echo &#39;built app&#39; $BUILT_APP\r\n    # Approach 1 \r\n    # if echo &quot;${PATH}&quot; | grep -iq ${BUILT_APP}\r\n    \r\n    # Approach 2\r\n    if [[ &quot;${PATH}&quot; == *&quot;${BUILT_APP}&quot;* ]]\r\n    then\r\n      echo &#39;it is a match&#39;\r\n    echo &#39;\\n&#39;\r\n    fi\r\n  done\r\ndone\r\n```\r\n\r\nIn &#39;approach 1&#39; I seem unable to use the `grep` command, it results in `grep: command not found`\r\n\r\nIn &#39;approach 2&#39; I just can&#39;t seem to make get the check to successfully recognise that the string contains the correct substring. i.e. with `package-1`\r\n\r\nAny help is well received. Hopefully it&#39;s something simple.",
        "link": "https://stackoverflow.com/questions/77243900/i-am-having-an-issue-performing-string-matching-within-a-for-loop-in-bash",
        "title": "I am having an issue performing string matching within a for loop in bash"
    },
    {
        "tags": [
            "json",
            "jq",
            "dump",
            "yt-dlp"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1696592933,
                "post_id": 77244169,
                "comment_id": 136176377,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1696593232,
                "post_id": 77244169,
                "comment_id": 136176437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1696594254,
                "last_edit_date": 1696594254,
                "creation_date": 1696593604,
                "answer_id": 77244273,
                "question_id": 77244169,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If `.chapters` is not present, it evaluates to `null`, and `.chapters[]` will fail with the error `Cannot iterate over null (null)`.\r\n\r\nDepending on what you want as result value in this case, you could wrap the critical part in parentheses, use the error suppression operator `?` to silence the error, and provide an alternative with the alternative operator `//`, e.g. `(…)? // null`.\r\n\r\nNote: `.chapters[] | {title} | has(&quot;title&quot;) | join(&quot;, &quot;)` doesn&#39;t make sense even if there are chapters, as `has` returns a boolean. Do you want to concatenate the chapter titles, separated by commas, into a long string? Use `.chapters | map(.title?) | join(&quot;, &quot;)` instead.\r\n\r\n```sh\r\njq -c &#39;{\r\n  Date: .upload_date | (.[0:4] + &quot;-&quot; + .[4:6] + &quot;-&quot; + .[6:8]),\r\n  ID: .id,\r\n  Title: .fulltitle,\r\n  Chaps: ((.chapters | map(.title) | join(&quot;, &quot;))? // null)\r\n}&#39;\r\n```\r\n",
                "title": "jq how to extract field only if exists for yt-dlp json dump"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1696601195,
        "creation_date": 1696592701,
        "last_edit_date": 1696601195,
        "question_id": 77244169,
        "body_markdown": "When i run the following:\r\n\r\n&gt; yt-dlp --dump-json https://www.youtube.com/watch?v=nochapters | jq -cr &#39;{ Date: .upload_date |\r\n&gt; (.[0:4] + &quot;-&quot; + .[4:6] + &quot;-&quot; + .[6:8]), ID: .id, Title: .fulltitle, \r\n&gt; Chaps: .chapters[] | {title} |  join(&quot;, &quot;) }&#39;\r\n\r\nit gives me an error:\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): Cannot iterate over null (null)\r\n\r\nHow can extract the chapters from those videos that really have chapters? (because I think it gets stuck when no chapters are found).\r\n\r\nEdit:\r\n\r\nInput is like (in this example chapters exists):\r\n&gt; {   &quot;id&quot;: &quot;pvkTC2xIbeY&quot;,   &quot;title&quot;: &quot;How to Add Chapters\r\n&gt; to YouTube Videos | Chapters Explained&quot;,   &quot;formats&quot;: [\r\n&gt;     {\r\n&gt;       &quot;format_id&quot;: &quot;sb2&quot;,\r\n&gt;       &quot;format_note&quot;: &quot;storyboard&quot;,\r\n&gt;       ...\r\n&gt;        &quot;comment_count&quot;: 2600,   &quot;chapters&quot;: [\r\n&gt;     {\r\n&gt;       &quot;start_time&quot;: 0,\r\n&gt;       &quot;title&quot;: &quot;Intro&quot;,\r\n&gt;       &quot;end_time&quot;: 10\r\n&gt;     },\r\n&gt;     {\r\n&gt;       &quot;start_time&quot;: 10,\r\n&gt;       &quot;title&quot;: &quot;YouTube Chapters&quot;,\r\n&gt;       &quot;end_time&quot;: 45\r\n&gt;     },... } }\r\n\r\nOutput like:\r\n\r\n&gt; {&quot;Date&quot;:&quot;2020-06-17&quot;,&quot;ID&quot;:&quot;pvkTC2xIbeY&quot;,&quot;Title&quot;:&quot;How to Add Chapters\r\n&gt; to YouTube Videos | Chapters Explained&quot;,&quot;Chaps&quot;:&quot;Intro, YouTube\r\n&gt; Chapters, What are YouTube chapters?, How to add chapter markers?,\r\n&gt; When are changes updated?, How to disable chapters?, Are chapters\r\n&gt; available in my country?&quot;}\r\n\r\n ",
        "link": "https://stackoverflow.com/questions/77244169/jq-how-to-extract-field-only-if-exists-for-yt-dlp-json-dump",
        "title": "jq how to extract field only if exists for yt-dlp json dump"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "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": 1696639830,
                "post_id": 77247944,
                "comment_id": 136183542,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3066861,
                    "reputation": 423,
                    "user_id": 2598351,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SxgR5.jpg?s=256",
                    "display_name": "unbox-us",
                    "link": "https://stackoverflow.com/users/2598351/unbox-us"
                },
                "reply_to_user": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1696640096,
                "post_id": 77247944,
                "comment_id": 136183558,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1696640730,
                "creation_date": 1696640730,
                "answer_id": 77247984,
                "question_id": 77247944,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.7 introduced the `--raw-output0` flag which &quot;will print NUL instead of newline after each output&quot;. You can use this in combination with `read` and its `-d` flag with an empty string as argument which &quot;will terminate a line when it reads a NUL character&quot;.\r\n```sh\r\n$ { read -r -d &#39;&#39; key; read -r -d &#39;&#39; value; } &lt; &lt;(jq --raw-output0 &#39;.key, .value&#39; file.json)\r\n$ echo &quot;$key&quot;\r\nhello\r\n$ echo &quot;$value&quot;\r\nworld\r\n```\r\n\r\nWith older versions of jq (1.5+), use the `-j` flag to omit the newlines, and print the NUL character manually using `&quot;\\u0000&quot;`:\r\n```sh\r\n{ read -r -d &#39;&#39; key; read -r -d &#39;&#39; value; } &lt; &lt;(jq -j &#39;.key, .value | ., &quot;\\u0000&quot;&#39; file.json)\r\n$ echo &quot;$key&quot;\r\nhello\r\n$ echo &quot;$value&quot;\r\nworld\r\n```",
                "title": "How to get the json elements(key , value) in an object to be separated distinctly"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1696744907,
        "creation_date": 1696639607,
        "last_edit_date": 1696744907,
        "question_id": 77247944,
        "body_markdown": "I am facing an issue with the simple Json mentioned below where I am trying to separately extract &quot;hello&quot; and &quot;world&quot; from this and store them separately. This JSON is coming out after extraction of original data and finally in this format.\r\n\r\n    {\r\n      &quot;key&quot;: &quot;hello&quot;,\r\n      &quot;value&quot;: &quot;world&quot;\r\n    }\r\n\r\nI am using jq already so `jq -r .key` i am aware of already (same for value). But I don&#39;t want this to be separate step. What I want is something like this.\r\nMake a single call to the system that gives above json and store these &quot;key&quot; and &quot;value&quot; values in variables. \r\n\r\nI very much appreciate help.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77247944/how-to-get-the-json-elementskey-value-in-an-object-to-be-separated-distinctl",
        "title": "How to get the json elements(key , value) in an object to be separated distinctly"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3377022,
                    "reputation": 13682,
                    "user_id": 2834978,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ff9af10001f37bc0de566ca2caf2f558?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LMC",
                    "link": "https://stackoverflow.com/users/2834978/lmc"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1696803922,
                "post_id": 77255519,
                "comment_id": 136196405,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1696803945,
                "creation_date": 1696803945,
                "answer_id": 77255541,
                "question_id": 77255519,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the same technique as described [here](https://stackoverflow.com/questions/77247944): jq 1.7 provides the `--raw-output0` flag which you can combine with `read -d &#39;&#39;`:\r\n```sh\r\nwhile read -r -d &#39;&#39; json\r\ndo printf &quot;Using %s to do something.\\n\\n&quot; &quot;$json&quot;\r\ndone &lt; &lt;(jq --raw-output0 . file.json)\r\n```\r\n```json\r\nUsing {\r\n  &quot;key&quot;: &quot;hello&quot;,\r\n  &quot;value&quot;: &quot;world&quot;\r\n} to do something.\r\n\r\nUsing {\r\n  &quot;key&quot;: &quot;foo&quot;,\r\n  &quot;value&quot;: &quot;bar&quot;\r\n} to do something.\r\n\r\nUsing {\r\n  &quot;key&quot;: &quot;Disney&quot;,\r\n  &quot;value&quot;: &quot;World&quot;\r\n} to do something.\r\n\r\nUsing {\r\n  &quot;key&quot;: &quot;South&quot;,\r\n  &quot;value&quot;: &quot;Africa&quot;\r\n} to do something.\r\n```\r\n\r\nWith older versions of jq (1.5+), you can instead use the `-j` flag, and manually produce the NUL characters by changing the filter to `., &quot;\\u0000&quot;`.",
                "title": "How to traverse through each JSON block and print out info"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1696926026,
        "creation_date": 1696803419,
        "last_edit_date": 1696926026,
        "question_id": 77255519,
        "body_markdown": "I have a bash command that gives me the output in the form below, These are 1 block JSON objects , I get these after json &gt; jq &gt; output of this form from a file.\r\n\r\n```\r\n{\r\n\t&quot;key&quot;: &quot;hello&quot;,\r\n\t&quot;value&quot;: &quot;world&quot;\r\n}\r\n{\r\n\t&quot;key&quot;: &quot;foo&quot;,\r\n\t&quot;value&quot;: &quot;bar&quot;\r\n}\r\n{\r\n\t&quot;key&quot;: &quot;Disney&quot;,\r\n\t&quot;value&quot;: &quot;World&quot;\r\n}\r\n{\r\n\t&quot;key&quot;: &quot;South&quot;,\r\n\t&quot;value&quot; &quot;Africa&quot;\r\n}\r\n```\r\n\r\nNow my question is how can my bash script produce each JSON block separately. Like I want to iterate and lets say print each JSON block in this whole output I want to traverse each `{}` block and do something with it. \r\n\r\nPlease Note that command substitution is not helping in this case so storing the output in a file works but feeding this to command substitution fails as these curly braces also gets injected as a single line and not as a block ? Is there a way in bash to read and pass this as a block `{}` ?\r\n\r\nAppreciate help!",
        "link": "https://stackoverflow.com/questions/77255519/how-to-traverse-through-each-json-block-and-print-out-info",
        "title": "How to traverse through each JSON block and print out info"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11421810,
                    "reputation": 910,
                    "user_id": 8551858,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/Um8evNmE.png?s=256",
                    "display_name": "Raky",
                    "link": "https://stackoverflow.com/users/8551858/raky"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1696913714,
                "post_id": 77262936,
                "comment_id": 136209972,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 11421810,
                    "reputation": 910,
                    "user_id": 8551858,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/Um8evNmE.png?s=256",
                    "display_name": "Raky",
                    "link": "https://stackoverflow.com/users/8551858/raky"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1696914150,
                "post_id": 77262936,
                "comment_id": 136210015,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1696913766,
                "creation_date": 1696913766,
                "answer_id": 77263035,
                "question_id": 77262936,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `transpose`. It &quot;rotates&quot; a table by taking a an array of arrays. Iterate over the rotated rows, and use `@csv` to generate the CSV:\r\n```sh\r\njq -r &#39;[.a, .b] | transpose[] | @csv&#39;\r\n```\r\n```csv\r\n1,2\r\n3,4\r\n5,6\r\n7,8\r\n9,10\r\n```\r\n[Demo](https://jqplay.org/s/3TiiEb4Be57)\r\n\r\nNote: If the arrays had unequal lengths, `transpose` would fill in `null`s, resulting in empty items for the the CSV.",
                "title": "how to concat two arrays in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1696913766,
        "creation_date": 1696912101,
        "question_id": 77262936,
        "body_markdown": "I have the following json:\r\n\r\n```\r\necho &#39;{&quot;a&quot;: [1, 3, 5, 7, 9 ], &quot;b&quot;: [2, 4, 6, 8, 10 ]}&#39; | jq                                                                                                                                                    \r\n{\r\n  &quot;a&quot;: [\r\n    1,\r\n    3,\r\n    5,\r\n    7,\r\n    9\r\n  ],\r\n  &quot;b&quot;: [\r\n    2,\r\n    4,\r\n    6,\r\n    8,\r\n    10\r\n  ]\r\n}\r\n```\r\n\r\nI would like to get the following csv:\r\n\r\n```\r\n1,2\r\n3,4\r\n5,6\r\n7,8\r\n9,10\r\n```\r\n\r\nHow is this possible with jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77262936/how-to-concat-two-arrays-in-jq",
        "title": "how to concat two arrays in jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "split",
            "mapping",
            "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": 1697090567,
                "post_id": 77269823,
                "comment_id": 136236085,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1696990251,
                "last_edit_date": 1696990251,
                "creation_date": 1696989800,
                "answer_id": 77269845,
                "question_id": 77269823,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can apply the functions directly while contructing the array:\r\n```\r\n[\r\n  (.latitude, .longitude | .*100000 | round/100000),\r\n  (.altitude, .accuracy | round),\r\n  .provider\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/U6Tv6UdGLeG)\r\n\r\nOr apply functions using ranges:\r\n```\r\n[.latitude, .longitude, .altitude, .accuracy, .provider]\r\n| .[0:2] |= map(.*100000 | round/100000)\r\n| .[2:4] |= map(round)\r\n```\r\n[Demo](https://jqplay.org/s/YWo_6a_3ZoM)\r\n\r\nYou could also wrap this in a custom filter, taking indices and the mapping function as parameters:\r\n```\r\ndef myfun(i;j;f): .[i:j] |= map(f);\r\n\r\n[.latitude, .longitude, .altitude, .accuracy, .provider]\r\n| myfun(0; 2; .*100000 | round/100000)\r\n| myfun(2; 4; round)\r\n```\r\n[Demo](https://jqplay.org/s/yh2wmsMIyLG)\r\n\r\nOutput for the given sample input:\r\n```json\r\n[\r\n  66.32419,\r\n  -121.7703,\r\n  465,\r\n  18,\r\n  &quot;gps&quot;\r\n]\r\n```\r\n\r\n",
                "title": "jq : applying different functions/mappings over parts of an array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1696990251,
        "creation_date": 1696989151,
        "last_edit_date": 1696989615,
        "question_id": 77269823,
        "body_markdown": "The JSON input is a simple set\r\n\r\nI wish to pick some of its elements based on their names\r\na1,..,an -&gt; {&quot;a1&quot;:v1,...&quot;an&#39;:vn}\r\njq -j &#39;[.a1,.a2,...,.an]&#39;\r\n\r\nAnd then use different functions f,g...\r\nso as to finally obtain [f(v1),...,f(vk),g(vk+1),...,g(vn)]\r\n\r\nUsing a single function, the filter would be :\r\njq -j &#39;[.a1,.a2,...,.an]|map(.|f)&#39;\r\n\r\nBut i cannot see the syntax, if any, to apply different functions f,g,... over different ranges\r\n\r\nLet me expose my concrete case :\r\n\r\nAt start, i have as JSON resulting from GPS location on the phone (using termux-location)\r\n```\r\n{\r\n  &quot;latitude&quot;: 66.32418638,\r\n  &quot;longitude&quot;: -121.77029769,\r\n  &quot;altitude&quot;: 465.46502685546875,\r\n  &quot;accuracy&quot;: 17.6742248535156,\r\n  &quot;vertical_accuracy&quot;: 36.48805236816406,\r\n  &quot;bearing&quot;: 0.0,\r\n  &quot;speed&quot;: 0.0,\r\n  &quot;elapsedMs&quot;: 55,\r\n  &quot;provider&quot;: &quot;gps&quot;\r\n}\r\n```\r\n\r\nI would like extract latitude,longitude,elevation,accuracy\r\nand process them differently : round the first 2 with 5 decimals,\r\nand the last 2 to nearest integer, and leave one intact\r\n\r\nWhen splitting :\r\n```\r\njq -j &#39;[.latitude,.longitude]|map(.*100000|round/100000)&#39; in.json\r\njq -j &#39;[.altitude,.accuracy]|map(.|round)&#39; in.json\r\njq -j &#39;.provider&#39; in.json\r\n```\r\n\r\n**q1. But can one easily combine such filters into a single one ?\r\n\r\nq2. When dealing with much larger arrays, it is possible to use different functions over index ranges (without having to name attributes) ?\r\n\r\nq3. Or would one need to build a global map() function with different cases, returning f(.),g(.),... according to ranges ?\r\n**\r\nTo solve q3, i tried to play with index() but my level in JQ is still too poor ...\r\n\r\n* WRONG CODE *\r\n```\r\njq -j &#39;[.latitude,.longitude,.altitude,.accuracy]|map(if .|index&lt;2 then .*100000|round/100000 else .|round end)&#39;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77269823/jq-applying-different-functions-mappings-over-parts-of-an-array",
        "title": "jq : applying different functions/mappings over parts of an array"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1697014916,
                "creation_date": 1697014916,
                "answer_id": 77271627,
                "question_id": 77271148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the array has only flat objects, you could use `to_entries` to iterate over their key-value pairs, and add them up in a `reduce` folding:\r\n```sh\r\nreduce (.[] | to_entries[]) as {$key, $value} ({};\r\n  .[$key] += $value\r\n)\r\n```\r\n```json\r\n{\r\n  &quot;a&quot;: 21,\r\n  &quot;b&quot;: 41,\r\n  &quot;c&quot;: 61\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/3LUr3MjCBeI)",
                "title": "Use jq to sum values of unknown keys"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1697021396,
                "creation_date": 1697021396,
                "answer_id": 77272332,
                "question_id": 77271148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To round out your options, if you have an arbitrarily nested set of objects. Stream it selecting leaf values and you can take the last part of the path as the key.\r\n\r\n```\r\nreduce (tostream|select(length==2)|.[0]|=last) as [$key, $value] ({};\r\n  .[$key] += $value\r\n)\r\n```",
                "title": "Use jq to sum values of unknown keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698463645,
                "last_edit_date": 1698463645,
                "creation_date": 1697591030,
                "answer_id": 77312960,
                "question_id": 77271148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach using `group_by` ([demo][1]):\r\n\r\n```\r\n  map(to_entries[]) \r\n| group_by(.key)\r\n| map({ key : first.key, value : ([ .[].value ] | add) } )\r\n| from_entries\r\n```\r\n\r\n[1]: https://jqplay.org/s/--788A_ocT-",
                "title": "Use jq to sum values of unknown keys"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1698463645,
        "creation_date": 1697010879,
        "question_id": 77271148,
        "body_markdown": "I have the following json:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 10,\r\n        &quot;b&quot;: 20\r\n      },\r\n      {\r\n        &quot;a&quot;: 11,\r\n        &quot;c&quot;: 30,\r\n      },\r\n      {\r\n        &quot;b&quot;: 21,\r\n        &quot;c&quot;: 31\r\n      }\r\n    ]\r\n\r\nAnd I need to create a new json object with all the keys in the different array entries, but with the accumulated values. Something like this:\r\n\r\n    {\r\n      &quot;a&quot;: 21,\r\n      &quot;b&quot;: 41,\r\n      &quot;c&quot;: 61\r\n    }\r\n\r\nThe array elements could be a lot more, and the keys could be anything.\r\n\r\nHow do I do that? Is that possible with jq, or maybe another tool?",
        "link": "https://stackoverflow.com/questions/77271148/use-jq-to-sum-values-of-unknown-keys",
        "title": "Use jq to sum values of unknown keys"
    },
    {
        "tags": [
            "amazon-ec2",
            "tags",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 29646454,
                    "reputation": 11,
                    "user_id": 22721344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/43b7ef432231e33ead09b362aad411ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dbbloke",
                    "link": "https://stackoverflow.com/users/22721344/dbbloke"
                },
                "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": 1697034533,
                "post_id": 77271347,
                "comment_id": 136229067,
                "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": 1697034611,
                "post_id": 77271347,
                "comment_id": 136229087,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29646454,
                    "reputation": 11,
                    "user_id": 22721344,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/43b7ef432231e33ead09b362aad411ee?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dbbloke",
                    "link": "https://stackoverflow.com/users/22721344/dbbloke"
                },
                "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": 1697035058,
                "post_id": 77271347,
                "comment_id": 136229197,
                "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": 1697035620,
                "post_id": 77271347,
                "comment_id": 136229307,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1697012569,
        "creation_date": 1697012569,
        "question_id": 77271347,
        "body_markdown": "I have a tag on my EC2 instances - backup_policy\r\n\r\nIt should be set to\r\n&quot;EC2_Prod_Daily_Weekly_Monthly&quot; for prod accounts\r\n&quot;EC2_NonProd_Daily_Weekly_Monthly&quot; for non-prod accounts\r\nbut sometimes prod may have the nonprod backup tag!\r\n\r\nI need CLI or JQ where tag NOT EQUAL to value.\r\n\r\n**Missing tag**\r\n\r\n```\r\naws ec2 describe-instances --query &#39;Reservations[].Instances[?!contains(Tags[].Key, backup_policy)][].InstanceId&#39;\r\n```\r\n\r\n**With correct tag**\r\n\r\n```\r\naws ec2 describe-instances --filters Name=tag:backup_policy,Values=EC2_Prod_Daily_Weekly_Monthly --query &#39;Reservations[].Instances[?contains(Tags[].Key, backup_policy)].[InstanceId,Tags[?Key==Name].Value | [0],Tags[?Key==backup_policy].Value | [0]]&#39; --output text\r\n```\r\n\r\n**Where NOT correct tag**\r\n\r\nI&#39;ve tried a LOT in jq.\r\ne.g.\r\n\r\n```\r\naws ec2 describe-instances \\\r\n  --query &#39;Reservations[*].Instances[*].{InstanceId: InstanceId, Tags: Tags}&#39; \\\r\n  --output json | \r\n  jq &#39;map(select(all(.Tags[]; .Key != &quot;backup_policy&quot; or .Value | contains(&quot;EC2_Prod_Daily_Weekly_Monthly&quot;) | not)))&#39;\r\n```\r\n\r\nI need the instanceId and incorrect tag value (plus accountid which is also in my tags)\r\n\r\nHere is example of json trying to parse:\r\n\r\n```\r\n[\r\n    {\r\n        &quot;InstanceId&quot;: &quot;i-03226b321aaff1122&quot;,\r\n        &quot;Tags&quot;: [\r\n            {\r\n            {\r\n                &quot;Key&quot;: &quot;account_id&quot;,\r\n                &quot;Value&quot;: &quot;1231231231&quot;\r\n            },\r\n            {\r\n                &quot;Key&quot;: &quot;backup_policy&quot;,\r\n                &quot;Value&quot;: &quot;EC2_Prod_Daily_Weekly_Monthly-oldvalue&quot;\r\n            },\r\n        ],\r\n        }\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/77271347/find-ec2-instances-where-tag-value-not-equal-value",
        "title": "Find EC2 instances where tag value NOT equal value"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1129881,
                    "reputation": 12145,
                    "user_id": 1116230,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/55a894894150db28d6641f0c57e48bac?s=256&d=identicon&r=PG",
                    "display_name": "Nico Haase",
                    "link": "https://stackoverflow.com/users/1116230/nico-haase"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697117300,
                "post_id": 77281024,
                "comment_id": 136241364,
                "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": 1697118051,
                "post_id": 77281024,
                "comment_id": 136241536,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1697124914,
                "creation_date": 1697124914,
                "answer_id": 77282001,
                "question_id": 77281024,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Well, let&#39;s look at what the shell does with that echo statement:\r\n```sh\r\n$ echo {&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;}\r\nok:true elapsed:317ns\r\n```\r\nSeveral things happened: \r\n* the braces disappeared,\r\n* the comma disappeared,\r\n* the quotes disappeared.\r\n\r\nAssuming your shell is bash, this is explained in [3.5.1 Brace Expansion](https://www.gnu.org/software/bash/manual/bash.html#Brace-Expansion) and [3.5.9 Quote Removal](https://www.gnu.org/software/bash/manual/bash.html#Quote-Removal)\r\n\r\nShells are tricky languages. This is why it&#39;s important to use quotes everywhere.\r\n```sh\r\necho &#39;{&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;}&#39; | jq -r &#39;.ok&#39;\r\n# ...^.............................^\r\n```\r\nOr, if your JSON data is stored in a variable:\r\n```sh\r\njson=&#39;{&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;}&#39;\r\necho &quot;$json&quot; | jq -r &#39;.ok&#39;\r\n# ...^.....^\r\n```\r\n",
                "title": "parse error: Invalid numeric literal at line 1, column 4"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1697124914,
        "creation_date": 1697117167,
        "question_id": 77281024,
        "body_markdown": "I am trying to parse a json using `jq` but it is giving parse error, I believe my Json is valid.\r\n\r\n\r\n```\r\n echo {&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;} | jq -r &#39;.ok&#39;\r\njq: parse error: Invalid numeric literal at line 1, column 3\r\n```\r\n\r\n\r\n\r\nCan you please help?\r\n\r\n\r\nI tried putting &#39; around the query, then it works fine, but I am not able to understand what&#39;s issue with first one. \r\n\r\n```\r\n\r\necho &#39;{&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;}&#39; | jq -r &#39;.ok&#39;\r\ntrue\r\n```",
        "link": "https://stackoverflow.com/questions/77281024/parse-error-invalid-numeric-literal-at-line-1-column-4",
        "title": "parse error: Invalid numeric literal at line 1, column 4"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1697120959,
                "post_id": 77281480,
                "comment_id": 136242244,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29654700,
                    "reputation": 13,
                    "user_id": 22727708,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLMfxdDTUHr4NUwImTx0WbgC3dnF7xOuWVLwtS9Z83u=k-s256",
                    "display_name": "ElRamos",
                    "link": "https://stackoverflow.com/users/22727708/elramos"
                },
                "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": 1697121554,
                "post_id": 77281480,
                "comment_id": 136242395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29654700,
                    "reputation": 13,
                    "user_id": 22727708,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLMfxdDTUHr4NUwImTx0WbgC3dnF7xOuWVLwtS9Z83u=k-s256",
                    "display_name": "ElRamos",
                    "link": "https://stackoverflow.com/users/22727708/elramos"
                },
                "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": 1697121592,
                "post_id": 77281480,
                "comment_id": 136242407,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1510734,
                    "reputation": 2206,
                    "user_id": 1412939,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/08988334cb9c66d980453bf2c94e9a42?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Philip Adler",
                    "link": "https://stackoverflow.com/users/1412939/philip-adler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697121758,
                "post_id": 77281480,
                "comment_id": 136242469,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29654700,
                    "reputation": 13,
                    "user_id": 22727708,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocLMfxdDTUHr4NUwImTx0WbgC3dnF7xOuWVLwtS9Z83u=k-s256",
                    "display_name": "ElRamos",
                    "link": "https://stackoverflow.com/users/22727708/elramos"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697121878,
                "post_id": 77281480,
                "comment_id": 136242500,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1697123237,
                "creation_date": 1697123237,
                "answer_id": 77281802,
                "question_id": 77281480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `curl … https://some_uri | jq &#39;.data.keys&#39;` outputs a JSON array of strings like `[&quot;test1&quot;, &quot;test2&quot;, &quot;testN&quot;]`, and `curl … https://some_uri/test1 | jq &#39;.data.data&#39;` outputs a JSON object like `{&quot;expiration_date&quot;: &quot;…&quot;, &quot;serial_number&quot;: &quot;…&quot;}`, then the following might solve your task.\r\n\r\nIt fetches the results from the first URI, and outputs a NUL-delimited list of strings that were contained in the array under `.data.keys`. Shell&#39;s `while` then iterates over that list using `read -d &#39;&#39;` to segment along the NUL characters, and in each step it fetches the results from the other URI (with the current list item appended), and extracts the object under `.data.data`, but leaves it JSON-encoded. A final call to jq then collects all of them in an array using the `-s` flag, and wraps it into an object with field name `data`.\r\n\r\n```\r\n#!/bin/bash\r\n\r\ncurl … &quot;https://some_uri&quot; | jq --raw-output0 &#39;.data.keys[]&#39; |\r\nwhile read -r -d &#39;&#39; key; do\r\n  curl … &quot;https://some_uri/${key}&quot; | jq &#39;.data.data&#39;\r\ndone | jq -s &#39;{data: .}&#39;\r\n```",
                "title": "How can I write the data received after the loop to a json file?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697123654,
                "last_edit_date": 1697123654,
                "creation_date": 1697123287,
                "answer_id": 77281810,
                "question_id": 77281480,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An ugly way would be to directly concatenate the second request responses in a string, and then manipulate this string to separate objects with comma and add opening and closing square brackets:\r\n```bash\r\n#!/bin/bash\r\n\r\ndate=$(date -d &quot;+1 month&quot;)\r\n\r\ncert_list=$(curl -s --header &quot;...&quot; --request LIST https://some_uri | jq -r &#39;.data.keys&#39; | grep &#39;\\w&#39; | tr -d &#39;&quot;&quot;&#39;,&#39;,&#39;)\r\n\r\nlist=&quot;&quot;\r\nfor i in $cert_list\r\ndo\r\n  cert_data=$(curl -s --header &quot;...&quot; --request GET https://some_uri/$i | jq -r &#39;.data.data | &quot;\\(.expiration_date) \\(.serial_number)&quot;&#39;)\r\n  list+=&quot;$cert_data&quot;$&#39;\\n&#39;\r\ndone\r\n\r\njson=&quot;$(echo &quot;[&quot; $(echo &quot;$list&quot; | sed &#39;s/}{/},{/g&#39;) &quot;]&quot;)&quot;\r\n\r\n```",
                "title": "How can I write the data received after the loop to a json file?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1697123654,
        "creation_date": 1697120777,
        "last_edit_date": 1697120965,
        "question_id": 77281480,
        "body_markdown": "I want to make a script that will generate a list of certificates that will expire in a month and write it in json format to a file.\r\n\r\nMaking a loop and getting the list as regular strings is not a problem. I can’t yet understand how to format the resulting list in json form. So that it would be like this:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;{expiration_date}&quot;: &quot;test1_expiration_date_value&quot;,\r\n      &quot;{serial_number}&quot;: &quot;test1_expiration_date_value&quot;\r\n    },\r\n    {\r\n      &quot;{expiration_date}&quot;: &quot;test2_expiration_date_value&quot;,\r\n      &quot;{serial_number}&quot;: &quot;test2_expiration_date_value&quot;\r\n    },\r\n    {\r\n      &quot;{expiration_date}&quot;: &quot;testN_expiration_date_value&quot;,\r\n      &quot;{serial_number}&quot;: &quot;testN_expiration_date_value&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI make a curl request to get a list of certificates\r\n`curl --header &quot;...&quot; --request LIST https://some_uri | jq -r &#39;.data.keys&#39; | grep &#39;\\w&#39; | tr -d &#39;&quot;&quot;&#39;,&#39;,&#39;`\r\nIn response I receive:\r\n```\r\n[\r\n  &quot;test1&quot;,\r\n  &quot;test2&quot;,\r\n  &quot;testN&quot;\r\n]\r\n```\r\nThen you can request additional fields for each of the lists\r\n`curl -s --header &quot;...&quot; --request GET https://some_uri/test1 | jq -r &#39;.data.data&#39;`\r\nIn response I receive:\r\n```\r\n{\r\n  &quot;expiration_date&quot;: &quot;2023-10-11 11:27:10&quot;,\r\n  &quot;serial_number&quot;: &quot;18:df:b4:a8:34:25:b1:43:c9:a3:6d:83:59:34:53:ab:2c:5e:c2:7a&quot;\r\n}\r\n```\r\n\r\nI tried different designs, but have not won yet. The last option, without any conditions for now:\r\n```\r\n#!/bin/bash\r\n\r\ndate=$(date -d &quot;+1 month&quot;)\r\n\r\ncert_list=$(curl -s --header &quot;...&quot; --request LIST https://some_uri | jq -r &#39;.data.keys&#39; | grep &#39;\\w&#39; | tr -d &#39;&quot;&quot;&#39;,&#39;,&#39;)\r\n\r\nlist=()\r\nfor i in $cert_list\r\ndo\r\n  cert_data=$(curl -s --header &quot;...&quot; --request GET https://some_uri/$i | jq -r &#39;.data.data | &quot;\\(.expiration_date) \\(.serial_number)&quot;&#39;)\r\n  list+=&quot;$cert_data&quot;$&#39;\\n&#39;\r\ndone\r\n\r\nlist_json=&quot;$(printf &#39;%s\\n&#39; &quot;${list}&quot;)&quot;\r\njson=&quot;$(jq -Rn &#39;{data: [inputs]}&#39; &lt;&lt;&lt; &quot;$list&quot;)&quot;\r\n\r\nprintf &#39;%s\\n&#39; &quot;$json&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/77281480/how-can-i-write-the-data-received-after-the-loop-to-a-json-file",
        "title": "How can I write the data received after the loop to a json file?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697208432,
                "post_id": 77288554,
                "comment_id": 136255023,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1053909,
                    "reputation": 11329,
                    "user_id": 1057052,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/qGN8h.jpg?s=256",
                    "display_name": "Jose A",
                    "link": "https://stackoverflow.com/users/1057052/jose-a"
                },
                "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": 1699512313,
                "post_id": 77288554,
                "comment_id": 136541820,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697208687,
                "creation_date": 1697208687,
                "answer_id": 77288718,
                "question_id": 77288554,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq can already handle multiple input files by itself:\r\n\r\n```\r\njq &#39;\r\nmap(select(.attributes.closeReason == &quot;Fraud&quot;) | .relationships.customer.data.id) as $ids\r\n| input\r\n| .data[]\r\n| select(.id | IN($ids[]))\r\n&#39; accounts.json data.json\r\n```\r\n\r\nAlternatively, if you really want to invoke two instances of jq:\r\n\r\n```\r\njq \\\r\n--argjson ids &quot;$(jq &#39;map(select(.attributes.closeReason == &quot;Fraud&quot;) | .relationships.customer.data.id)&#39; accounts.json)&quot; \\\r\n&#39;.data[] | select(.id | IN($ids[]))&#39; \\\r\ndata.json\r\n```\r\n\r\nor with an intermediate variable:\r\n\r\n```\r\nids=&quot;$(jq &#39;map(select(.attributes.closeReason == &quot;Fraud&quot;) | .relationships.customer.data.id)&#39; accounts.json)&quot;\r\njq \\\r\n--argjson ids &quot;$ids&quot; \\\r\n&#39;.data[] | select(.id | IN($ids[]))&#39; \\\r\ndata.json\r\n```",
                "title": "Use the output of a jq command as args of another jq command to compare 2 json files"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1699512264,
        "creation_date": 1697207306,
        "last_edit_date": 1699512264,
        "question_id": 77288554,
        "body_markdown": "I want to filter one JSON file based on the contents of another JSON file. \r\n\r\nI want to extract the IDs on the first JSON file, `data.json` with this jq:\r\n```\r\njq &#39;[.data[] | select(.attributes.closeReason == &quot;Fraud&quot;)][:10] | [.[].relationships.customer.id]&#39; data.json\r\n```\r\n\r\nWhich yields something like: \r\n\r\n```\r\n[\r\n  &quot;621506&quot;,\r\n  &quot;624722&quot;,\r\n  &quot;631044&quot;,\r\n  &quot;633359&quot;,\r\n  &quot;699327&quot;,\r\n  &quot;710710&quot;,\r\n  &quot;711493&quot;,\r\n  &quot;713413&quot;,\r\n  &quot;713824&quot;,\r\n  &quot;713903&quot;\r\n]\r\n```\r\n\r\nI want to get those values and use them to match the IDs of the other JSON...\r\n\r\nSomething like:\r\n```\r\njq --argjson ids &quot;$ARGS.positional[]&quot; &#39;.data[] | select(.id | IN($ids[]))&#39; accounts.json\r\n```\r\n\r\nBut I get the error:\r\n```\r\njq: invalid JSON text passed to --argjson\r\n```\r\n\r\nI&#39;ve tried scavenging Stack Overflow, Phind.com, ChatGPT but I haven&#39;t found any solution yet. \r\n\r\n## Examples - JSON files:\r\n1st JSON file (extract the customer Id)\r\n```\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;depositAccount&quot;,\r\n    &quot;id&quot;: &quot;991231&quot;,\r\n    &quot;attributes&quot;: {\r\n      &quot;name&quot;: &quot;William Heckerd&quot;,\r\n      &quot;status&quot;: &quot;Closed&quot;,\r\n      &quot;closeReason&quot;: &quot;Fraud&quot;,\r\n      &quot;fraudReason&quot;: &quot;ACHActivity&quot;,\r\n      &quot;updatedAt&quot;: &quot;2023-02-24T19:41:30.224Z&quot;\r\n    },\r\n    &quot;relationships&quot;: {\r\n      &quot;customer&quot;: {\r\n        &quot;data&quot;: {\r\n          &quot;type&quot;: &quot;customer&quot;,\r\n          &quot;id&quot;: &quot;123456&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n2nd JSON file - Based on the customer Id filter it out:\r\n\r\n```json\r\n{\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;individualCustomer&quot;,\r\n      &quot;id&quot;: &quot;567898765&quot;,\r\n      &quot;attributes&quot;: {\r\n        &quot;createdAt&quot;: &quot;2023-09-10T08:32:07.921Z&quot;,\r\n        &quot;fullName&quot;: {\r\n          &quot;first&quot;: &quot;Foo&quot;,\r\n          &quot;last&quot;: &quot;Example&quot;\r\n        },\r\n        &quot;email&quot;: &quot;theemail@gmail.com&quot;,\r\n        &quot;status&quot;: &quot;Archived&quot;,\r\n        &quot;archiveReason&quot;: &quot;FraudClientIdentified&quot;\r\n      }\r\n    }\r\n  ]\r\n}\r\n\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/77288554/use-the-output-of-a-jq-command-as-args-of-another-jq-command-to-compare-2-json-f",
        "title": "Use the output of a jq command as args of another jq command to compare 2 json files"
    },
    {
        "tags": [
            "arrays",
            "dictionary",
            "merge",
            "jq",
            "element"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697221594,
                "creation_date": 1697221594,
                "answer_id": 77289958,
                "question_id": 77289827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`ls` is not suitable for parsing. Instead, you could iterate over all of the files directly within one call to jq, for example using `inputs`, and get each filename using `input_filename`. For example:\r\n```sh\r\njq -n &#39;reduce inputs as $in ([]; . + [{\r\n  name: input_filename,\r\n  size: $in | length\r\n}])&#39; *.json\r\n```",
                "title": "How do I get the length of elements of each json file in directory containing several jsons"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697221979,
                "creation_date": 1697221979,
                "answer_id": 77289988,
                "question_id": 77289827,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `input_filename` to get the file name:\r\n\r\n```\r\njq -n &#39;[inputs | { name: input_filename, size: length }]&#39; *.json\r\n```",
                "title": "How do I get the length of elements of each json file in directory containing several jsons"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1697221979,
        "creation_date": 1697220103,
        "question_id": 77289827,
        "body_markdown": "I have a directory with only json files each having a minimum of atleast 1 element\r\n\r\n```\r\nfoo.json\r\nbar.json\r\nbaz.json\r\n```\r\n\r\nI want to create a new json array with above json files which I am able to with following:\r\n\r\n```\r\nls | jq -R &#39;{name: split(&quot;\\\\n&quot;) | .[]}&#39; | jq -s &#39;.&#39;\r\n```\r\n\r\nwhich results as:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo.json&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar.json&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;baz.json&quot;\r\n  }\r\n]\r\n```\r\n\r\nBut what I need is length of the corresponding elements respective to each of the json file along with the name as below:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;foo.json&quot;,\r\n    &quot;size&quot;: 5\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;bar.json&quot;,\r\n    &quot;size&quot;: 10\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;baz.json&quot;,\r\n    &quot;size&quot;: 15\r\n  }\r\n]\r\n```\r\n\r\nThis command gives only size of the json without any mapping to the actual filename\r\n\r\n```\r\njq -s &#39;map(length) &#39; ./*.json\r\n```\r\n\r\nlike:\r\n\r\n\r\n```\r\n[\r\n  5,\r\n  10,\r\n  15\r\n]\r\n  \r\n```\r\n\r\nAny pointers to have the two commands merged and evolved in better way to get the expected output as mentioned above would be much appreciated\r\n\r\n\r\n\r\n\r\n\r\n\r\nTried adding size to each element through\r\n\r\n```\r\nls | jq -R &#39;{name: split(&quot;\\\\n&quot;), size: map(length) | .[]}&#39;\r\n```\r\n\r\nBut is resulting in error in iterating\r\n",
        "link": "https://stackoverflow.com/questions/77289827/how-do-i-get-the-length-of-elements-of-each-json-file-in-directory-containing-se",
        "title": "How do I get the length of elements of each json file in directory containing several jsons"
    },
    {
        "tags": [
            "csv",
            "google-cloud-platform",
            "jq",
            "gcloud"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 31027,
                    "reputation": 1824,
                    "user_id": 84940,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/ZLTRkURm.jpg?s=256",
                    "display_name": "sudocracy",
                    "link": "https://stackoverflow.com/users/84940/sudocracy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697583689,
                "post_id": 77290075,
                "comment_id": 136297414,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 279352,
                    "reputation": 526,
                    "user_id": 574460,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/323d130ec7ea0488a27caaaab3ec0a93?s=256&d=identicon&r=PG",
                    "display_name": "JuanToroMarty",
                    "link": "https://stackoverflow.com/users/574460/juantoromarty"
                },
                "reply_to_user": {
                    "account_id": 31027,
                    "reputation": 1824,
                    "user_id": 84940,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/ZLTRkURm.jpg?s=256",
                    "display_name": "sudocracy",
                    "link": "https://stackoverflow.com/users/84940/sudocracy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697728087,
                "post_id": 77290075,
                "comment_id": 136318833,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 31027,
                    "reputation": 1824,
                    "user_id": 84940,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://i.sstatic.net/ZLTRkURm.jpg?s=256",
                    "display_name": "sudocracy",
                    "link": "https://stackoverflow.com/users/84940/sudocracy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698276208,
                "post_id": 77290075,
                "comment_id": 136386248,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697860300,
                "last_edit_date": 1697860300,
                "creation_date": 1697859997,
                "answer_id": 77334662,
                "question_id": 77290075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming this is the output you want for the following input:\r\n\r\n### Output\r\n```csv\r\n&quot;windy-bearing-129522&quot;,&quot;env&quot;,&quot;test&quot;\r\n&quot;windy-bearing-129522&quot;,&quot;version&quot;,&quot;alpha&quot;\r\n&quot;canvas-syntax-130823&quot;,&quot;env&quot;,&quot;test&quot;\r\n&quot;canvas-syntax-130823&quot;,&quot;version&quot;,&quot;beta&quot;\r\n```\r\n### Input\r\n```json\r\n[\r\n  {\r\n    &quot;labels&quot;: {\r\n      &quot;env&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;alpha&quot;\r\n    },\r\n    &quot;projectId&quot;: &quot;windy-bearing-129522&quot;,\r\n  },\r\n  {\r\n    &quot;labels&quot;: {\r\n      &quot;env&quot;: &quot;test&quot;,\r\n      &quot;version&quot;: &quot;beta&quot;\r\n    },\r\n   &quot;projectId&quot;: &quot;canvas-syntax-130823&quot;\r\n  }\r\n]\r\n```\r\n### Solution\r\n\r\nThis would work ([demo][1]):\r\n\r\n```bash\r\njq --raw-output &#39;.[] | { projectId, label : (.labels | to_entries) [] } |\r\n                       [.projectId, .label.key, .label.value ] | @csv   &#39;\r\n```\r\n\r\nReadable form:\r\n\r\n```jq\r\n.[] | { projectId, label : (.labels | to_entries) [] } \r\n    | [.projectId, .label.key, .label.value ]  \r\n    | @csv\r\n```\r\n\r\n### Approach\r\n\r\nEssentially, the first filter creates an object for each label as follows:\r\n```json\r\n{\r\n  &quot;projectId&quot;: &quot;windy-bearing-129522&quot;,\r\n  &quot;label&quot;: {\r\n    &quot;key&quot;: &quot;env&quot;,\r\n    &quot;value&quot;: &quot;test&quot;\r\n  }\r\n}\r\n```\r\n\r\nThe second filter produces the following which pipes into the `@csv` to get it in the format we need:\r\n\r\n```json\r\n[\r\n  &quot;windy-bearing-129522&quot;,\r\n  &quot;env&quot;,\r\n  &quot;test&quot;\r\n]\r\n```\r\n\r\nA few things to note:\r\n\r\n- We use the `to_entries` function to convert every label to be of the form `{ key : &quot;some-key&quot;, value: &quot;some-value&quot; }`.\r\n- The `[]` operator in the `label : (.labels | to_entries) []` is the one that makes it so that multiple labels under the same projects actually become separate objects.\r\n- The `--raw-output` flag does not escape the quotes around the strings.\r\n\r\n\r\n[1]: https://jqplay.org/s/JEjS4zkM0Js",
                "title": "How to arrange in a csv document the label values of several GCP projects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1697860300,
        "creation_date": 1697223207,
        "question_id": 77290075,
        "body_markdown": "My problem here is that the labels of every projects are not the same number or keys.\r\nSo, I need to retrive all the labels of every project I have access and put it together in a CSV document.\r\n\r\nRight now Im trying with \r\n```gcloud projects list --format=&quot;csv[no-heading](labels)&quot;``` \r\nto get them, but as I said, the problem is how I get the column names across all the projects and then how should I put the values to fit.\r\n\r\nThe result of the above command is a list of key=value separated by &quot;;&quot; that I do not how to arrange correctly.\r\n\r\nI have tried with `--format=&quot;json&quot; | jq -r &#39;.[].labels&#39;` and formating the output, but I get to the same problem on how to fix all the keys across all the projects.\r\n\r\nMaybe I&#39;m just tired and should rest, but any advice will be appreciated.",
        "link": "https://stackoverflow.com/questions/77290075/how-to-arrange-in-a-csv-document-the-label-values-of-several-gcp-projects",
        "title": "How to arrange in a csv document the label values of several GCP projects"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697310427,
                "post_id": 77294135,
                "comment_id": 136264954,
                "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": 1697310466,
                "post_id": 77294135,
                "comment_id": 136264957,
                "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": 1697310643,
                "post_id": 77294135,
                "comment_id": 136264974,
                "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": 1697310680,
                "post_id": 77294135,
                "comment_id": 136264977,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8787589,
                    "reputation": 49,
                    "user_id": 6568885,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-y6IQQ0EAKNE/AAAAAAAAAAI/AAAAAAAAASQ/XAR6ebYRajA/s256-rj/photo.jpg",
                    "display_name": "Venu Reddy",
                    "link": "https://stackoverflow.com/users/6568885/venu-reddy"
                },
                "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": 1697310768,
                "post_id": 77294135,
                "comment_id": 136264985,
                "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": 1697310785,
                "post_id": 77294135,
                "comment_id": 136264989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1697311672,
                "post_id": 77294135,
                "comment_id": 136265065,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8787589,
                    "reputation": 49,
                    "user_id": 6568885,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-y6IQQ0EAKNE/AAAAAAAAAAI/AAAAAAAAASQ/XAR6ebYRajA/s256-rj/photo.jpg",
                    "display_name": "Venu Reddy",
                    "link": "https://stackoverflow.com/users/6568885/venu-reddy"
                },
                "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": 1697312016,
                "post_id": 77294135,
                "comment_id": 136265105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2940217,
                    "reputation": 15344,
                    "user_id": 2518285,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sETWZ.jpg?s=256",
                    "display_name": "Brett Donald",
                    "link": "https://stackoverflow.com/users/2518285/brett-donald"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697312106,
                "post_id": 77294135,
                "comment_id": 136265116,
                "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": 1697312780,
                "post_id": 77294135,
                "comment_id": 136265177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8787589,
                    "reputation": 49,
                    "user_id": 6568885,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-y6IQQ0EAKNE/AAAAAAAAAAI/AAAAAAAAASQ/XAR6ebYRajA/s256-rj/photo.jpg",
                    "display_name": "Venu Reddy",
                    "link": "https://stackoverflow.com/users/6568885/venu-reddy"
                },
                "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": 1697313877,
                "post_id": 77294135,
                "comment_id": 136265273,
                "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": 1697314744,
                "post_id": 77294135,
                "comment_id": 136265344,
                "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": 1697391259,
                "post_id": 77294135,
                "comment_id": 136271251,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8787589,
                    "reputation": 49,
                    "user_id": 6568885,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-y6IQQ0EAKNE/AAAAAAAAAAI/AAAAAAAAASQ/XAR6ebYRajA/s256-rj/photo.jpg",
                    "display_name": "Venu Reddy",
                    "link": "https://stackoverflow.com/users/6568885/venu-reddy"
                },
                "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": 1697431285,
                "post_id": 77294135,
                "comment_id": 136274246,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697312518,
                "creation_date": 1697312518,
                "answer_id": 77294234,
                "question_id": 77294135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not a particularly _clean_ solution, but the following works:\r\n\r\n```bash\r\ncondition=A # or condition=B\r\njq --arg condition &quot;$condition&quot; &#39;\r\n  def maybeReorderHost:\r\n    ( if $condition == &quot;A&quot; then &quot;HOST-A&quot; else &quot;HOST-B&quot; end) as $priorityPattern |\r\n    if type != &quot;object&quot; then . else (\r\n      if .RedisHost? == null then . else (\r\n        .RedisHost |= (split(&quot;;&quot;) as $hostArr |\r\n        [[$hostArr[] | select(index($priorityPattern) != null)],\r\n         [$hostArr[] | select(index($priorityPattern) == null)]]\r\n        | add | join(&quot;;&quot;) )\r\n    ) end\r\n  ) end;\r\n\r\n  walk(maybeReorderHost)\r\n&#39; &lt;FileA.json\r\n```\r\n\r\nWe&#39;re using `split(&quot;;&quot;)` to split your string into an array; filtering for the array elements that _do_ match your desired pattern; filtering for the array elements that _don&#39;t_ match your pattern; and then concatenating those two sublists together.",
                "title": "Reorder values inside a JSON-embedded string based on a flag&#39;s value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697370459,
                "creation_date": 1697370459,
                "answer_id": 77296494,
                "question_id": 77294135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the format of `.RedisHost` is fixed, you can try :\r\n\r\n```\r\nthis=B\r\njq --arg this $this\\\r\n    &#39;(if $this == &quot;A&quot; then &quot;B&quot; else &quot;A&quot; end) as $that|\r\n     (.. | select(type == &quot;object&quot; and has(&quot;RedisHost&quot;))\r\n           .RedisHost?) = &quot;HOST-\\($this);HOST-\\($that)&quot;&#39; File1.json\r\n```",
                "title": "Reorder values inside a JSON-embedded string based on a flag&#39;s value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697430636,
                "creation_date": 1697430636,
                "answer_id": 77299409,
                "question_id": 77294135,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I solved it myself.\r\n\r\n```\r\n   # To detect the condition at the pipeline level based on the environment \r\n\r\n    detect=&lt; To detect the condition to apply &gt; # more at Pipeline\r\n\r\n   # Defining list of host variables\r\n\r\n    host_A=HOST-A; host_B=HOST-B\r\n\r\n   # construct host order based on $detect \r\n \r\n    if [[ $detect =~ A ]]; then order_host=&quot;$host_A;$host_B&quot;; elif\r\n       [[ $detect =~ B ]] ; then \r\n       order_host=&quot;$host_B;$host_A&quot; ; else \r\n       echo &quot;Invalid &quot;;\r\n    fi\r\n\r\n   # find the RedisHost and replace it with the constructed order_host\r\n\r\n    jq --arg myvar &quot;$order_host&quot; &#39;(..|objects|select(.RedisHost).RedisHost)|=$myvar&#39; File1.json)&quot;\r\n    jq --arg myvar &quot;$order_host&quot; &#39;(..|objects|select(.RedisHost).RedisHost)|=$myvar&#39; File2.json)&quot;\r\n```\r\n\r\n",
                "title": "Reorder values inside a JSON-embedded string based on a flag&#39;s value"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1697430636,
        "creation_date": 1697310318,
        "last_edit_date": 1697312638,
        "question_id": 77294135,
        "body_markdown": "I have two JSON files with different schema.\r\nThe sample data in the JSON files as\r\n\r\nFile1.json\r\n```\r\n{\r\n  &quot;ServiceSettings&quot;: {\r\n    &quot;ServiceName&quot;: &quot;my-service&quot;,\r\n    &quot;RedisSettings&quot;: {\r\n      &quot;RedisHost&quot;: &quot;HOST-A;HOST-B&quot; \r\n    }\r\n  }\r\n}\r\n```\r\nFile2.json:\r\n```\r\n{\r\n  &quot;RedisHost&quot;: &quot;HOST-A;HOST-B&quot;\r\n}\r\n\r\n```\r\n\r\nI have a requirement as below and the conditions are passed through the pipelines, dynamically\r\n\r\nI set a variable preset as\r\n\r\n`host_orderA=&quot;HOST-A;HOST-B&quot;`\r\n&amp;\r\n`host_orderB=&quot;HOST-B;HOST-A&quot;`\r\n\r\n 1. if the condition is A, the RedisHost should be\r\n\r\n    ```\r\n    &quot;RedisHost&quot;: &quot;HOST-A;HOST-B&quot;\r\n    ```\r\n\r\n 2. if the condition is B, the RedisHost should be \r\n\r\n    ```\r\n    &quot;RedisHost&quot;: &quot;HOST-B;HOST-A&quot;\r\n    ```\r\n 3. Irrespective of the order of hosts list HOST-A &amp; HOST-B in the actual JSON files, I want to order the hosts in the JSON and print or output data into a variable or use `sponge` to replace in the same JSON files, based on the conditions, 1 &amp; 2 above.\r\n\r\nI tried a few things using sed &amp; JQ but was unable to attain proper output. I prefer to use JQ to replace it as it&#39;s JSON-friendly. ",
        "link": "https://stackoverflow.com/questions/77294135/reorder-values-inside-a-json-embedded-string-based-on-a-flags-value",
        "title": "Reorder values inside a JSON-embedded string based on a flag&#39;s value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697368658,
                "creation_date": 1697368658,
                "answer_id": 77296396,
                "question_id": 77296368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `inputs` in combination with the `-n` flag to address all input documents:\r\n\r\n```sh\r\njq -n &#39;{Everything: [inputs.Data[]]}&#39; *.json\r\n```\r\n```json\r\n{\r\n  &quot;Everything&quot;: [\r\n    {\r\n      &quot;data&quot;: &quot;data1&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data2&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data3&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/6UvRKUcq_S1)",
                "title": "Use jq to append array contents from multiple files into one master array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697583191,
                "creation_date": 1697583191,
                "answer_id": 77312652,
                "question_id": 77296368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use the `-s` switch, there will be an implicit array wrapping around all objects emitted by the `*.json`, and so you can also do this without having to explicitly reference the `inputs` object:\r\n\r\n```json\r\n&#167; jq -s &#39;{ Everything:[ .[].Data[] ] }&#39; *.json\r\n{\r\n  &quot;Everything&quot;: [\r\n    {\r\n      &quot;data&quot;: &quot;data1&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data2&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data1&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;: &quot;data2&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Use jq to append array contents from multiple files into one master array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697583191,
        "creation_date": 1697368154,
        "last_edit_date": 1697368220,
        "question_id": 77296368,
        "body_markdown": "I&#39;m attempting to use [jq](https://jqlang.github.io/jq/) to combine the data of many JSON files. However, most solutions I tried clobber the data and I end up losing most of it.\r\n\r\nEach file looks something like this\r\n```\r\n{\r\n  &quot;Brand&quot;:&quot;brand&quot;,\r\n  &quot;Fulfilled&quot;:5600,\r\n  &quot;Total&quot;:5626,\r\n  &quot;Data&quot;:[\r\n    {\r\n      &quot;data&quot;:&quot;data1&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;:&quot;data2&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to pull the contents from the main &#39;Data&#39; array from each file and make it look something like this:\r\n\r\n```\r\n{\r\n  &quot;Everything&quot;:[\r\n    {\r\n      &quot;data&quot;:&quot;data1&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;:&quot;data2&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;:&quot;data3&quot;\r\n    },\r\n    {\r\n      &quot;data&quot;:&quot;data4&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/77296368/use-jq-to-append-array-contents-from-multiple-files-into-one-master-array",
        "title": "Use jq to append array contents from multiple files into one master array"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697433755,
                "last_edit_date": 1697433755,
                "creation_date": 1697433633,
                "answer_id": 77299539,
                "question_id": 77299184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Filter below works but the top level structure is lost from output\r\n\r\n```\r\njq &#39;.connections.connection[].field[] | select(.usesEncryption)&#39; EnvironmentExtensions.json\r\n```",
                "title": "jq select using a boolean attribute in deep nested array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697489968,
                "last_edit_date": 1697489968,
                "creation_date": 1697444736,
                "answer_id": 77300427,
                "question_id": 77299184,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To modify the inner array, either use (requires jq 1.7):\r\n\r\n```\r\n.connections.connection[].field[] |= select(.usesEncryption)\r\n```\r\n\r\nor (works with jq 1.6)\r\n\r\n```\r\n.connections.connection[].field |= map(select(.usesEncryption))\r\n```\r\n\r\nAlternatively, rebuild both arrays (jq 1.6):\r\n\r\n```\r\n.connections.connection |= map(.field |= map(select(.usesEncryption)))\r\n```",
                "title": "jq select using a boolean attribute in deep nested array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697489968,
        "creation_date": 1697425218,
        "last_edit_date": 1697482687,
        "question_id": 77299184,
        "body_markdown": "How can i select / filter all connection with field.usesEncryption is true using jq from JSON data below\r\n\r\n```\r\n{\r\n  &quot;connections&quot;: {\r\n    &quot;connection&quot;: [\r\n      {\r\n        &quot;field&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;url&quot;,\r\n            &quot;encryptedValueSet&quot;: false,\r\n            &quot;usesEncryption&quot;: false,\r\n            &quot;componentOverride&quot;: false,\r\n            &quot;useDefault&quot;: false\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;user&quot;,\r\n            &quot;encryptedValueSet&quot;: false,\r\n            &quot;usesEncryption&quot;: false,\r\n            &quot;componentOverride&quot;: false,\r\n            &quot;useDefault&quot;: false\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;password&quot;,\r\n            &quot;encryptedValueSet&quot;: true,\r\n            &quot;usesEncryption&quot;: true,\r\n            &quot;componentOverride&quot;: false,\r\n            &quot;useDefault&quot;: false\r\n          }\r\n        ],\r\n        &quot;id&quot;: &quot;3ea89002-51f5-4369-9539-63c3bd406a64&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n\r\nI tried following but not working as desired\r\n\r\n```\r\njq &#39;. | select(.connections.connection[].field[] | .usesEncryption==true)&#39; EnvironmentExtensions.json\r\njq &#39;. | .connections.connection[].field[] | select(.usesEncryption==true)&#39; EnvironmentExtensions.json\r\n```",
        "link": "https://stackoverflow.com/questions/77299184/jq-select-using-a-boolean-attribute-in-deep-nested-array",
        "title": "jq select using a boolean attribute in deep nested array"
    },
    {
        "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": 1697426505,
                "post_id": 77299198,
                "comment_id": 136273918,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1259559,
                    "reputation": 559,
                    "user_id": 1218259,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/4e9cc591cf1f05ba1349ef6eaccbbd37?s=256&d=identicon&r=PG",
                    "display_name": "Jumwah",
                    "link": "https://stackoverflow.com/users/1218259/jumwah"
                },
                "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": 1697428321,
                "post_id": 77299198,
                "comment_id": 136274036,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1697428023,
                "last_edit_date": 1697428023,
                "creation_date": 1697427524,
                "answer_id": 77299279,
                "question_id": 77299198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If names are guaranteed to be unique within one file, you could temporarily turn file A into an `INDEX`, so checking the containedness of a `.name` becomes a matter of checking keys with `has`. Then, iterate over the items of file B using `reduce` on `input[]`, and if a name is present as key, update the according field by adding its old value to the current item (order matters). Finally, revert the object structure back to an array by collecting all field values into an array, using `[.[]]`.\r\n\r\n```sh\r\njq &#39;reduce input[] as $i (INDEX(.name);\r\n  if has($i.name) then .[$i.name] |= $i + . end\r\n) | [.[]]&#39; fileA.json fileB.json\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpha&quot;,\r\n    &quot;value&quot;: &quot;apple&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;types&quot;: [\r\n        &quot;granny&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;beta&quot;,\r\n    &quot;value&quot;: &quot;banana&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;gamma&quot;,\r\n    &quot;value&quot;: &quot;guava&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/ybgr2NojOAs)",
                "title": "Merge objects in JSON lists using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697763390,
                "last_edit_date": 1697763390,
                "creation_date": 1697429720,
                "answer_id": 77299369,
                "question_id": 77299198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this: \r\n```\r\njq &#39;map(. + (input | map(select(.name == .name)))[0])&#39; jsonA.json jsonB.json\r\n```",
                "title": "Merge objects in JSON lists using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697581044,
                "creation_date": 1697581044,
                "answer_id": 77312537,
                "question_id": 77299198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If we treat the first file as a list of elements, and the second file as a lookup from which we have to retrieve the matching values for each of those elements, then all we need to do is match each element to its corresponding element in the lookup ([demo][1]):\r\n\r\n```jq\r\nINDEX(.[0][] ; .name) as $elements  |\r\nINDEX(.[1][] ; .name) as $lookup    |\r\n$elements | keys []   as $key       |\r\n$elements[$key]       as $value     |\r\n$lookup[$key]         as $match     | ( $match // {} ) * $value\r\n```\r\n\r\nA few things to note:\r\n\r\n- If the corresponding element is missing in the lookup, we use an empty object as the matched element. \r\n- We ensure that the element&#39;s original values are one the right side of `*` operator so that it&#39;s attribute values supersede the matched object&#39;s attribute values.\r\n- We trigger the iteration on each key with this expression `$elements | keys []`\r\n- The `INDEX` function converts the original arrays into keyed objects so that they are easy to work with.\r\n\r\n\r\n[1]: https://jqplay.org/s/p0hEpyfYrvV",
                "title": "Merge objects in JSON lists using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697857492,
                "last_edit_date": 1697857492,
                "creation_date": 1697581895,
                "answer_id": 77312583,
                "question_id": 77299198,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the same basic ideas of treating the first file as list elements and the second file as lookup from which we have to retrieve matching values (as discussed in [this answer][1]), here is a more terse solution ([demo][2]):\r\n\r\n```jq\r\n  ( .[0][] ) as $element \r\n| ( .[1] | map(select(.name == $element.name)) [] // {} ) as $match \r\n| $match * $element\r\n```\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/77312537/84940\r\n  [2]: https://jqplay.org/s/wRRPjrOCGJi",
                "title": "Merge objects in JSON lists using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1697857492,
        "creation_date": 1697425838,
        "last_edit_date": 1697486795,
        "question_id": 77299198,
        "body_markdown": "I want to merge two JSON files, where the objects in the base file (A) are augmented by matching objects in file (B), but not overwritten where A and B have different values for the same key.\r\n\r\nFor example, I have a JSON file (A) with contents like\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpha&quot;,\r\n    &quot;value&quot;: &quot;apple&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;beta&quot;,\r\n    &quot;value&quot;: &quot;banana&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;gamma&quot;,\r\n    &quot;value&quot;: &quot;guava&quot;\r\n  }\r\n]\r\n```\r\nand a second JSON file (B), with the same basic structure but optionally with additional keys (`metadata` in this example, but it could be anything):\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpha&quot;,\r\n    &quot;value&quot;: &quot;apple&quot;,\r\n    &quot;metadata&quot;: {\r\n      &quot;types&quot;: [\r\n        &quot;granny&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;beta&quot;,\r\n    &quot;value&quot;: &quot;blueberry&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;omega&quot;,\r\n    &quot;value&quot;: &quot;orange&quot;\r\n  }\r\n]\r\n```\r\nI want to merge the two lists together, key/values from objects in B are added into the same object (matched by `name`) in A.  My JQ to achieve this is like:\r\n\r\n```\r\njq -s &#39;[ .[0][] as $a | .[1][] as $b | select ($a.name == $b.name) | $a * $b ]&#39; b.json a.json\r\n```\r\n\r\nThis works to add the `metadata` into A and retains A&#39;s values for other keys.  However, `gamma` is missing from the result.  From the example above, I want a result where:\r\n\r\n* alpha should have the metadata\r\n* beta should be banana, not blueberry.\r\n* gamma should be in the final list\r\n* omega should NOT be in the final list\r\n* Order of objects in the list should be maintained.\r\n\r\nI want this:\r\n```\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;alpha&quot;,\r\n    &quot;value&quot;: &quot;apple&quot;\r\n    &quot;metadata&quot;: {\r\n      &quot;types&quot;: [\r\n        &quot;granny&quot;\r\n      ]\r\n    }\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;beta&quot;,\r\n    &quot;value&quot;: &quot;banana&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;gamma&quot;,\r\n    &quot;value&quot;: &quot;guava&quot;\r\n  }\r\n]\r\n```\r\nHow do I adapt this query to also include top level objects from A, but not from B?",
        "link": "https://stackoverflow.com/questions/77299198/merge-objects-in-json-lists-using-jq",
        "title": "Merge objects in JSON lists using JQ"
    },
    {
        "tags": [
            "curl",
            "formatting",
            "jq",
            "neovim"
        ],
        "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": 1697606100,
                "post_id": 77311449,
                "comment_id": 136299272,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 2,
        "last_activity_date": 1697570021,
        "creation_date": 1697567474,
        "last_edit_date": 1697570021,
        "question_id": 77311449,
        "body_markdown": "I&#39;m currently facing an issue with the rest.nvim plugin in Neovim. The plugin allows making HTTP requests within Neovim and provides a convenient way to format responses. I&#39;ve configured it to use jq for formatting JSON responses, but it&#39;s not working as expected.\r\nlink to repo [rest-nvim/rest.nvim](https://github.com/rest-nvim/rest.nvim)\r\n\r\n**Solution**\r\nThere was a breaking introduced to the plugin. A temporary fix here [here][1], \r\n\r\nspecify commit before breaking change in plugin config:\r\n\r\n \r\n\r\n       return {\r\n      {\r\n        &quot;rest-nvim/rest.nvim&quot;,\r\n        requires = { &quot;nvim-lua/plenary.nvim&quot; },\r\n        -- latest commit breaks formatting\r\n        commit = &quot;8b62563&quot;,\r\n        opts = {\r\n          result_split_in_place = true,\r\n        },\r\n      },\r\n    }\r\n\r\n**Problem:**\r\nWhen I send an HTTP request using the rest.nvim plugin, the JSON responses are not being formatted correctly. Instead of getting a formatted JSON output, I receive the raw JSON response. I have jq installed on my system. Despite this, the formatting does not seem to take effect.\r\n\r\n\r\n**Troubleshooting Steps Taken:**\r\n1. Ensured jq is installed on my system.\r\n2. Verified that the rest.nvim plugin is correctly installed and configured.\r\n3. Checked the plugin&#39;s documentation and forums for similar issues, but couldn&#39;t find a solution.\r\n\r\n\r\n**Example file:** *testing.http*\r\n\r\n```\r\nGET https://random-data-api.com/api/address/random_address\r\nContent-Type: application/json\r\n```\r\n\r\n**Response:**\r\n\r\n```\r\nGET https://random-data-api.com/api/address/random_address\r\n#+END\r\n#+RESPONSE\r\n{&quot;id&quot;:3318,&quot;uid&quot;:&quot;09951d24-0ba7-46e7-90c9-c75a1d1fa014&quot;,&quot;city&quot;:&quot;Buckridgetown&quot;,&quot;street_name&quot;:&quot;Eusebio Viaduct&quot;,&quot;street_address&quot;:&quot;11676 Reatha Road&quot;,&quot;secondary_address&quot;:&quot;Suite 204&quot;,&quot;building_number&quot;:&quot;3557&quot;,&quot;mail_box&quot;:&quot;PO Box 7129&quot;,&quot;community&quot;:&quot;Willow Village&quot;,&quot;zip_code&quot;:&quot;37775&quot;,&quot;zip&quot;:&quot;42017-6516&quot;,&quot;postcode&quot;:&quot;25460&quot;,&quot;time_zone&quot;:&quot;America/St_Johns&quot;,&quot;street_suffix&quot;:&quot;Park&quot;,&quot;city_suffix&quot;:&quot;stad&quot;,&quot;city_prefix&quot;:&quot;North&quot;,&quot;state&quot;:&quot;Rhode Island&quot;,&quot;state_abbr&quot;:&quot;WI&quot;,&quot;country&quot;:&quot;United States Minor Outlying Islands&quot;,&quot;country_code&quot;:&quot;PG&quot;,&quot;latitude&quot;:-74.28963865772323,&quot;longitude&quot;:67.39583760610813,&quot;full_address&quot;:&quot;6652 Sanford Vista, South Trudichester, FL 91950-9038&quot;}\r\n#+END\r\n```\r\n\r\n\r\n\r\n**Configuration:**\r\nHere&#39;s my current configuration for the rest.nvim plugin:\r\n\r\n```\r\nreturn {\r\n\t&quot;rest-nvim/rest.nvim&quot;,\r\n\trequires = { &quot;nvim-lua/plenary.nvim&quot; },\r\n\tconfig = function()\r\n\t\trequire(&quot;rest-nvim&quot;).setup({\r\n\r\n\t\t-- Open request results in a horizontal split\r\n\t\tresult_split_horizontal = false,\r\n\t\t-- Keep the http file buffer above|left when split horizontal|vertical\r\n\t\tresult_split_in_place = false,\r\n\t\t-- Skip SSL verification, useful for unknown certificates\r\n\t\tskip_ssl_verification = false,\r\n\t\t-- Encode URL before making request\r\n\t\tencode_url = true,\r\n\t\t-- Highlight request on run\r\n\t\thighlight = {\r\n\t\t\tenabled = true,\r\n\t\t\ttimeout = 150,\r\n\t\t},\r\n\t\tresult = {\r\n\t\t-- toggle showing URL, HTTP info, headers at top the of result window\r\n\t\tshow_url = true,\r\n\t\t-- show the generated curl command in case you want to launch\r\n\t\t-- the same request via the terminal (can be verbose)\r\n\t\tshow_curl_command = false,\r\n\t\tshow_http_info = true,\r\n\t\tshow_headers = false,\r\n\t\t-- executables or functions for formatting response body [optional]\r\n\t\t-- set them to false if you want to disable them\r\n\t\t\tformatters = {\r\n\t\t\tjson = &quot;jq&quot;,\r\n\t\t\thtml = function(body)\r\n\t\t\t\treturn vim.fn.system({ &quot;tidy&quot;, &quot;-i&quot;, &quot;-q&quot;, &quot;-&quot; }, body)\r\n\t\t\t\tend,\r\n\t\t\t},\r\n\t\t},\r\n\t\t-- Jump to request line on run\r\n\t\tjump_to_request = false,\r\n\t\tenv_file = &quot;.env&quot;,\r\n\t\tcustom_dynamic_variables = {},\r\n\t\tyank_dry_run = true,\r\n\t})\r\n\t\tlocal opts = { noremap = true, silent = true }\r\n\t\tvim.api.nvim_set_keymap(&quot;n&quot;, &quot;&lt;leader&gt;rr&quot;, &quot;&lt;Plug&gt;RestNvim&quot;, opts)\r\n\t\tvim.api.nvim_set_keymap(&quot;n&quot;, &quot;&lt;leader&gt;rp&quot;, &quot;&lt;Plug&gt;RestNvimPreview&quot;, opts)\r\n\t\tvim.api.nvim_set_keymap(&quot;n&quot;, &quot;&lt;leader&gt;rl&quot;, &quot;&lt;Plug&gt;RestNvimLast&quot;, opts)\r\n\tend,\r\n}\r\n```\r\n\r\n\r\n  [1]: https://github.com/rest-nvim/rest.nvim/issues/246%20Solution",
        "link": "https://stackoverflow.com/questions/77311449/issue-with-rest-nvim-plugin-json-formatting",
        "title": "Issue with rest.nvim Plugin: JSON Formatting"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7712415,
                    "reputation": 65767,
                    "user_id": 5841306,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Civ0G.jpg?s=256",
                    "display_name": "Barbaros &#214;zhan",
                    "link": "https://stackoverflow.com/users/5841306/barbaros-%c3%96zhan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697609327,
                "post_id": 77313769,
                "comment_id": 136299644,
                "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": 1697609361,
                "post_id": 77313769,
                "comment_id": 136299652,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1697693438,
                "last_edit_date": 1697693438,
                "creation_date": 1697609292,
                "answer_id": 77313832,
                "question_id": 77313769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "**Update**\r\n\r\n[pmf](https://stackoverflow.com/users/2158479/pmf) suggested change (see comments): \r\n```bash\r\ncat myjson.json | jq &#39;.policies = [.policies[] | select(.isEnabled == false)]&#39;\r\n```\r\n\r\n**Previous Response**\r\n\r\nThis should keep the whole structure of the JSON but filter out policies (depending on `isEnabled == false`) in place.\r\n\r\n```bash\r\ncat myjson.json | jq &#39;.policies = (.policies[] | select(.isEnabled == false) | . )&#39;\r\n```\r\n\r\nExplanation:\r\n1. `(.policies[] | select(.isEnabled == false)` -&gt; Take each policy and filter out the results on the given condition.\r\n2. `| . )` -&gt; aggregate the results\r\n3. `.policies = ()` -&gt; reassign the field with the newly filtered array",
                "title": "jq filter on array and return matching elements with full array name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1697693438,
        "creation_date": 1697608298,
        "last_edit_date": 1697609572,
        "question_id": 77313769,
        "body_markdown": "i have below JSON which i am trying to filter using `&quot;isEnabled&quot;` value. I am able to filter  but loosing original array as result only shows filtered data. is there any way to return result in same array?\r\n\r\n```json\r\n{\r\n  &quot;startIndex&quot;: 0,\r\n  &quot;pageSize&quot;: 200,\r\n  &quot;totalCount&quot;: 174,\r\n  &quot;resultSize&quot;: 174,\r\n  &quot;sortType&quot;: &quot;asc&quot;,\r\n  &quot;sortBy&quot;: &quot;policyId&quot;,\r\n  &quot;queryTimeMS&quot;: 1697604282484,\r\n  &quot;policies&quot;: [\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;guid&quot;: &quot;d3a007c9-a877-44b8-a526-57f484916cd6&quot;,\r\n      &quot;isEnabled&quot;: true,\r\n      &quot;version&quot;: 210,\r\n      &quot;service&quot;: &quot;Prod-Hue&quot;,\r\n      &quot;name&quot;: &quot;all - url&quot;,\r\n```\r\n\r\n\r\n\r\nMy JQ line\r\n```sh\r\ncat myjson.json | jq &#39;.policies[] | select(.isEnabled == false)&#39;\r\n```\r\n\r\nalso tried enclosing entire jq expression in () but no joy.",
        "link": "https://stackoverflow.com/questions/77313769/jq-filter-on-array-and-return-matching-elements-with-full-array-name",
        "title": "jq filter on array and return matching elements with full array name"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1697624142,
                "creation_date": 1697624142,
                "answer_id": 77315415,
                "question_id": 77315351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just loop through the array and replace objects with `Object.value()` which creates an array with values of the object.   \r\n\r\n**EDIT**: My bad somehow I got this question and thought it&#39;s about JS. I will still leave this though, might help someone x)\r\n\r\n&lt;!-- begin snippet: js hide: false console: true babel: false --&gt;\r\n\r\n&lt;!-- language: lang-js --&gt;\r\n\r\n    const data = [\r\n      {\r\n        &quot;k1&quot;: &quot;o1k1&quot;,\r\n        &quot;k2&quot;: &quot;o1k2&quot;,\r\n        &quot;k_opt1&quot;: &quot;o1k_xxx&quot;\r\n      },\r\n      {\r\n        &quot;k1&quot;: &quot;o2k1&quot;,\r\n        &quot;k2&quot;: &quot;o2k2&quot;,\r\n        &quot;k_opt2&quot;: &quot;o2k_yyy&quot;\r\n      }\r\n    ]\r\n\r\n\r\n    function getKeys(arr) {\r\n      arr.forEach((dataset, i) =&gt; {\r\n        arr[i] = Object.values(dataset)\r\n      })\r\n      return arr\r\n    }\r\n\r\n    console.log(getKeys(data))\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n",
                "title": "jq: how to get array of arrays with json object values from an array of objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1697625214,
                "last_edit_date": 1697625214,
                "creation_date": 1697624347,
                "answer_id": 77315436,
                "question_id": 77315351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Double-nest `map(…)` or `[.[]]` (or even `.[] |= …` on the array, not the object). All of these do what you want:\r\n```sh\r\njq &#39;map(map(.))&#39;     # nesting map(…) and map(…)\r\njq &#39;map([.[]])&#39;      # nesting map(…) and [.[]]\r\njq &#39;[.[] | [.[]]]&#39;   # nesting [.[]] and [.[]]\r\njq &#39;[.[] | map(.)]&#39;  # nesting [.[]] and map(…)\r\n\r\njq &#39;.[] |= map(.)&#39;   # nesting .[] |= … and map(…)\r\njq &#39;.[] |= [.[]]&#39;    # nesting .[] |= … and [.[]]\r\n```\r\n[Demo](https://jqplay.org/s/IxeXYf0_Z68)",
                "title": "jq: how to get array of arrays with json object values from an array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697625214,
        "creation_date": 1697623578,
        "question_id": 77315351,
        "body_markdown": "having input json like so\r\n\r\n    [\r\n      {\r\n        &quot;k1&quot;: &quot;o1k1&quot;,\r\n        &quot;k2&quot;: &quot;o1k2&quot;,\r\n        &quot;k_opt1&quot;: &quot;o1k_xxx&quot;\r\n      },\r\n      {\r\n        &quot;k1&quot;: &quot;o2k1&quot;,\r\n        &quot;k2&quot;: &quot;o2k2&quot;,\r\n        &quot;k_opt2&quot;: &quot;o2k_yyy&quot;\r\n      }\r\n    ]\r\ni would like to get array of arrays with object values, so:\r\n\r\n    [\r\n      [\r\n        &quot;o1k1&quot;,\r\n        &quot;o1k2&quot;,\r\n        &quot;o1k_xxx&quot;\r\n      ],\r\n      [\r\n        &quot;o2k1&quot;,\r\n        &quot;o2k2&quot;,\r\n        &quot;o2k_yyy&quot;\r\n      ]\r\n    ]\r\n\r\ntried `.[] | to_entries[].value`, but it eats up the individual arrays - and produces just:\r\n\r\n      &quot;o1k1&quot;,\r\n      &quot;o1k2&quot;,\r\n      &quot;o1k_xxx&quot;,\r\n      &quot;o2k1&quot;,\r\n      &quot;o2k2&quot;,\r\n      &quot;o2k_yyy&quot;\r\n\r\nhttps://jqplay.org/s/riVFB79OCQS. Any advise?",
        "link": "https://stackoverflow.com/questions/77315351/jq-how-to-get-array-of-arrays-with-json-object-values-from-an-array-of-objects",
        "title": "jq: how to get array of arrays with json object values from an array of objects"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1512071,
                    "reputation": 87,
                    "user_id": 1413912,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9f6d47c21440fac413c63729c6304553?s=256&d=identicon&r=PG",
                    "display_name": "jeffery",
                    "link": "https://stackoverflow.com/users/1413912/jeffery"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697632242,
                "post_id": 77316284,
                "comment_id": 136303904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697632284,
                "post_id": 77316284,
                "comment_id": 136303915,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1697632240,
                "creation_date": 1697632240,
                "answer_id": 77316326,
                "question_id": 77316284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\nto_entries[] | select(.value[] | contains(&quot;fe80::4dd:baff:fecb:ef91&quot;)).key\r\n```\r\n\r\nWill log `.key` (`ens5` in the example), or nothing if the IP can&#39;t be found.\r\n\r\n\r\n----------\r\n\r\n##### [Try it online](https://jqplay.org/s/clBy8gk4m1A)",
                "title": "Filter json string based on value and extract key"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697634014,
                "creation_date": 1697634014,
                "answer_id": 77316548,
                "question_id": 77316284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want a &quot;recursive search&quot; - you can also use `paths()` + `strings`\r\n```jq\r\npaths(strings | select(. == &quot;fe80::4dd:baff:fecb:ef91&quot;))[-2]\r\n```\r\n\r\nhttps://jqplay.org/s/s4Dqorimh84",
                "title": "Filter json string based on value and extract key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1697634014,
        "creation_date": 1697631955,
        "question_id": 77316284,
        "body_markdown": "I have the following json string:\r\n\r\n    {\r\n      &quot;lo&quot;: [\r\n        &quot;127.0.0.1&quot;,\r\n        &quot;::1&quot;\r\n      ],\r\n      &quot;ens5&quot;: [\r\n        &quot;10.77.23.18&quot;,\r\n        &quot;fe80::4dd:baff:fecb:ef91&quot;\r\n      ],\r\n      &quot;ens6&quot;: [\r\n        &quot;10.77.18.149&quot;,\r\n        &quot;fe80::445:b3ff:fe48:bd98&quot;\r\n      ]\r\n    }\r\n\r\nFrom which I want to filter the key to the given value.\r\n\r\ne.g. Given the string &quot;fe80::4dd:baff:fecb:ef91&quot; I want to get the value &quot;ens5&quot;\r\n\r\nP.S I have no control over the format of the json string.",
        "link": "https://stackoverflow.com/questions/77316284/filter-json-string-based-on-value-and-extract-key",
        "title": "Filter json string based on value and extract key"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1697643106,
                "creation_date": 1697643106,
                "answer_id": 77317715,
                "question_id": 77317448,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way that uses `to_entries` to access key and value, and stores it in a variable for later:\r\n```sh\r\n.items[] | (\r\n  .data | to_entries[]\r\n  | select(.value | strings | startswith(&quot;http://my-cluster-dns&quot;))\r\n) as $data\r\n| [.metadata.namespace, .metadata.name, $data.key, $data.value]\r\n| join(&quot;,&quot;) # or @csv\r\n```\r\n```csv\r\nmy-namespace,cluster-agent-config,DATA_2,http://my-cluster-dns.my-service:8080\r\nher-namespace,cluster-agent-misc,DATA_1,http://my-cluster-dns.my-service:9000\r\n```\r\n[Demo](https://jqplay.org/s/WRICu7japHb)\r\n\r\nNote: For proper escaping (and quoting), use `@csv` instead of `join(&quot;,&quot;)`.",
                "title": "Filter data from a complex json object with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1697643106,
        "creation_date": 1697640941,
        "question_id": 77317448,
        "body_markdown": "I have to extract each data from configMaps of a Kubernetes cluster which respond to certain criteria. I try to do it with jq but I can&#39;t get over it ...\r\n\r\nHere is my k8s extraction :\r\n```json\r\n{\r\n    &quot;apiVersion&quot;: &quot;v1&quot;,\r\n    &quot;items&quot;: [\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;data&quot;: {\r\n                &quot;DATA_1&quot;: false,\r\n                &quot;DATA_2&quot;: &quot;http://my-cluster-dns.my-service:8080&quot;,\r\n                &quot;DATA_3&quot;: 200\r\n            },\r\n            &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;cluster-agent-config&quot;,\r\n                &quot;namespace&quot;: &quot;my-namespace&quot;,\r\n            }\r\n        },\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;data&quot;: {\r\n                &quot;agent-log.yaml&quot;: &quot;log-level: INFO\\nmax-filesize-mb: 50\\nmax-backups: 5\\nwrite-to-stdout: true&quot;\r\n            },\r\n            &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;cluster-agent-log&quot;,\r\n                &quot;namespace&quot;: &quot;your-namespace&quot;,             \r\n            }\r\n        },\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;data&quot;: {\r\n                &quot;agent-monitoring.yml&quot;: &quot;metric-collection-interval-seconds: 30\\ncluster-metric-collection-interval-seconds: 60\\nmetadata-collection-interval-seconds: 60\\ncontainer-registration-batch-size: 5\\npod-registration-batch-size: 6\\nmetric-upload-retry-count: 2\\nmetric-upload-retry-interval-milliseconds: 5\\nmax-pods-to-register-count: 750\\nmax-pod-logs-tail-lines-count: 500\\ninstrumentation-max-polling-attempts: 10\\npod-filter: {}\\nns-to-monitor-regex: \\&quot;.*\\&quot;&quot;\r\n            },\r\n            &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;cluster-agent-mon&quot;,\r\n                &quot;namespace&quot;: &quot;his-namespace&quot;,\r\n            }\r\n        },\r\n        {\r\n            &quot;apiVersion&quot;: &quot;v1&quot;,\r\n            &quot;data&quot;: {\r\n                &quot;DATA_1&quot;: &quot;http://my-cluster-dns.my-service:9000&quot;,\r\n                &quot;DATA_2&quot;: &quot;something&quot;,\r\n            },\r\n            &quot;kind&quot;: &quot;ConfigMap&quot;,\r\n            &quot;metadata&quot;: {\r\n                &quot;name&quot;: &quot;cluster-agent-misc&quot;,\r\n                &quot;namespace&quot;: &quot;her-namespace&quot;,\r\n            }\r\n        }\r\n    ],\r\n    &quot;kind&quot;: &quot;List&quot;,\r\n    &quot;metadata&quot;: {\r\n        &quot;resourceVersion&quot;: &quot;&quot;\r\n    }\r\n}\r\n```\r\n\r\nI would like to have something like that in output (csv) :\r\n```csv\r\nmy-namespace,cluster-agent-config,DATA_2,http://my-cluster-dns.my-service:8080\r\nher-namespace,cluster-agent-misc,DATA_1,http://my-cluster-dns.my-service:9000\r\n```\r\n\r\nThe criteria here was &quot;the data contains an url beginning with http://my-cluster-dns&quot;.\r\n\r\nI achieve to get the values I am looking for but I lost the other metadata (and the corresponding keys) ... For example with this jq statement `jq -r &#39;.items[].data[] | select(contains(&quot;http://my-cluster-dns&quot;))&#39;`\r\n\r\nOr I can get the other metadata but the filter applies on them too (and for certain criteria, this doesn&#39;t fill my needs) for exemple with this one `jq -r &#39;.items[] | . as $item | .data[] | $item.metadata.name, $item.metadata.namespace, . | select(contains(&quot;http://my-cluster-dns&quot;))&#39;`\r\n\r\nFinally, I think I&#39;m close with this : `.items[] | . as $item | .data[] | [{ name: $item.metadata.name, namespace: $item.metadata.namespace, value: . }]` but I can&#39;t find the way to filter correctly.",
        "link": "https://stackoverflow.com/questions/77317448/filter-data-from-a-complex-json-object-with-jq",
        "title": "Filter data from a complex json object with jq"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14247854,
                    "reputation": 5561,
                    "user_id": 10292330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u5G8t.png?s=256",
                    "display_name": "OysterShucker",
                    "link": "https://stackoverflow.com/users/10292330/oystershucker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697660759,
                "post_id": 77319296,
                "comment_id": 136309463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2705066,
                    "reputation": 329,
                    "user_id": 2334833,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a2b63e032d5bedffa0a2519ed94d4ea1?s=256&d=identicon&r=PG",
                    "display_name": "Aksanth",
                    "link": "https://stackoverflow.com/users/2334833/aksanth"
                },
                "reply_to_user": {
                    "account_id": 14247854,
                    "reputation": 5561,
                    "user_id": 10292330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u5G8t.png?s=256",
                    "display_name": "OysterShucker",
                    "link": "https://stackoverflow.com/users/10292330/oystershucker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697661101,
                "post_id": 77319296,
                "comment_id": 136309528,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14247854,
                    "reputation": 5561,
                    "user_id": 10292330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u5G8t.png?s=256",
                    "display_name": "OysterShucker",
                    "link": "https://stackoverflow.com/users/10292330/oystershucker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697661166,
                "post_id": 77319296,
                "comment_id": 136309534,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14247854,
                    "reputation": 5561,
                    "user_id": 10292330,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/u5G8t.png?s=256",
                    "display_name": "OysterShucker",
                    "link": "https://stackoverflow.com/users/10292330/oystershucker"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697661617,
                "post_id": 77319296,
                "comment_id": 136309608,
                "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": 1697662327,
                "post_id": 77319296,
                "comment_id": 136309740,
                "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": 1697663083,
                "post_id": 77319296,
                "comment_id": 136309839,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697661884,
                "creation_date": 1697661884,
                "answer_id": 77319493,
                "question_id": 77319296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using jq, just define for each field what it should iterate over and collect:\r\n```sh\r\n{\r\n  order: .orders | map({\r\n    items: .order | map(\r\n      .items[] | {name, type} | .type |= (map(\r\n        .value |= .[].value\r\n      ) | from_entries)\r\n    ),\r\n    id\r\n  })\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;order&quot;: [\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 1&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;blue&quot;,\r\n            &quot;model&quot;: &quot;Stereo&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 2&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;Yellow&quot;,\r\n            &quot;model&quot;: &quot;NewModel&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715874&quot;\r\n    },\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 6&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Range&quot;: &quot;10&quot;,\r\n            &quot;Type&quot;: &quot;AllRegion&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 4&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;Yellow&quot;,\r\n            &quot;model&quot;: &quot;OldModel&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715875&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/zs3XSIYn_DA)",
                "title": "JQ Query - Restructuring a nested JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1697808927,
                "last_edit_date": 1697808927,
                "creation_date": 1697663332,
                "answer_id": 77319609,
                "question_id": 77319296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would do it with the json module. Suppose your original json is stored as `original_data`.\r\n\r\nThen you can iterate over it to construct your desired format:\r\n\r\n - For each order, it create a new entry\r\n - For each item in the order, extract the name of the item and organize the &quot;type&quot; information into a dictionary where the &quot;name&quot; becomes a key, and the &quot;value&quot; becomes the corresponding value.\r\n - This transformed data is stored in a new data structure\r\n - store the new structure as json with `.dumps`\r\n\r\nSo code would be like this:\r\n\r\n```python\r\n    import json\r\n    # Initialize the result structure\r\n    result_data = {&quot;order&quot;: []}\r\n    \r\n    # Iterate through &quot;orders&quot;\r\n    for order_info in original_data[&quot;orders&quot;]:\r\n        order = {&quot;items&quot;: [], &quot;id&quot;: order_info[&quot;id&quot;]}\r\n    \r\n        # Iterate through the &quot;order&quot; items\r\n        for item in order_info[&quot;order&quot;]:\r\n            item_data = {\r\n                &quot;name&quot;: item[&quot;items&quot;][0][&quot;name&quot;],\r\n                &quot;type&quot;: {}\r\n            }\r\n    \r\n            # Iterate through &quot;type&quot; \r\n            for type_entry in item[&quot;items&quot;][0][&quot;type&quot;]:\r\n                item_data[&quot;type&quot;][type_entry[&quot;name&quot;]] = type_entry[&quot;value&quot;][0][&quot;value&quot;]\r\n    \r\n            order[&quot;items&quot;].append(item_data)\r\n    \r\n        result_data[&quot;order&quot;].append(order)\r\n    \r\n    # Convert the result to JSON format\r\n    result_json = json.dumps(result_data, indent=2)\r\n    \r\n    # Print the resulting JSON\r\n    print(result_json)\r\n```\r\n\r\nWhich yields the following JSON (as desired):\r\n\r\n    {\r\n      &quot;order&quot;: [\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 1&quot;,\r\n              &quot;type&quot;: {\r\n                &quot;Color&quot;: &quot;blue&quot;,\r\n                &quot;model&quot;: &quot;Stereo&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Item 2&quot;,\r\n              &quot;type&quot;: {\r\n                &quot;Color&quot;: &quot;Yellow&quot;,\r\n                &quot;model&quot;: &quot;NewModel&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;id&quot;: &quot;715874&quot;\r\n        },\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 6&quot;,\r\n              &quot;type&quot;: {\r\n                &quot;Range&quot;: &quot;10&quot;,\r\n                &quot;Type&quot;: &quot;AllRegion&quot;\r\n              }\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;Item 4&quot;,\r\n              &quot;type&quot;: {\r\n                &quot;Color&quot;: &quot;Yellow&quot;,\r\n                &quot;model&quot;: &quot;OldModel&quot;\r\n              }\r\n            }\r\n          ],\r\n          &quot;id&quot;: &quot;715875&quot;\r\n        }\r\n      ]\r\n    }",
                "title": "JQ Query - Restructuring a nested JSON"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698292170,
                "creation_date": 1698292170,
                "answer_id": 77364010,
                "question_id": 77319296,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach ([demo][1]) without using nested mutations (`|=`):\r\n\r\n```jq\r\ndef transform:\r\n    { name, type : [ .type[] | { (.name) : .value[].value } ] | add };\r\n\r\n{ order : [ .orders[] | { items: [ .order[].items[] | transform ], id } ] }\r\n```\r\n\r\nWe keep the transformation of the `items` in a separate function for readability.\r\n\r\n[1]:https://jqplay.org/s/A0pMZGQtlr6",
                "title": "JQ Query - Restructuring a nested JSON"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1698292170,
        "creation_date": 1697659783,
        "last_edit_date": 1697732006,
        "question_id": 77319296,
        "body_markdown": "I have a JSON which looks like this:\r\n\r\n````\r\n{\r\n  &quot;orders&quot;: [\r\n    {\r\n      &quot;order&quot;: [\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 1&quot;,\r\n              &quot;id&quot;: [],\r\n              &quot;type&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Color&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;blue&quot;\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;model&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;Stereo&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 2&quot;,\r\n              &quot;id&quot;: [],\r\n              &quot;type&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Color&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;Yellow&quot;\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;model&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;NewModel&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715874&quot;\r\n    },\r\n    {\r\n      &quot;order&quot;: [\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 6&quot;,\r\n              &quot;id&quot;: [],\r\n              &quot;type&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Range&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;10&quot;\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;Type&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;AllRegion&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;items&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;Item 4&quot;,\r\n              &quot;id&quot;: [],\r\n              &quot;type&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Color&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;Yellow&quot;\r\n                    }\r\n                  ]\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;model&quot;,\r\n                  &quot;value&quot;: [\r\n                    {\r\n                      &quot;value&quot;: &quot;OldModel&quot;\r\n                    }\r\n                  ]\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715875&quot;\r\n    }\r\n  ]\r\n}\r\n````\r\n\r\nI am trying to convert to this format \r\n\r\n````\r\n{\r\n  &quot;order&quot;: [\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 1&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;blue&quot;,\r\n            &quot;model&quot;: &quot;Stereo&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 2&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;Yellow&quot;,\r\n            &quot;model&quot;: &quot;NewModel&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715874&quot;\r\n    },\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;Item 6&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;blue&quot;,\r\n            &quot;Type&quot;: &quot;AllRegion&quot;\r\n          }\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;Item 4&quot;,\r\n          &quot;type&quot;: {\r\n            &quot;Color&quot;: &quot;Yellow&quot;,\r\n            &quot;model&quot;: &quot;OldModel&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;id&quot;: &quot;715875&quot;\r\n    }\r\n  ]\r\n}\r\n````\r\n\r\nI tried using queries like this, not able to achieve the format i am looking for..\r\n\r\n.orders[] |  { orders : [ .order[] |{ .order[].items : .], id  : .id } ]}\r\n\r\n  { orders : [ .orders[] |{ order : [.items[].name[] ], id  : .id } ]}\r\n\r\n\r\nPlease help. thanks in Advance.  I am parsing this in Python, if any other Lib can parse this similar to JQ thats also helpfull.\r\n",
        "link": "https://stackoverflow.com/questions/77319296/jq-query-restructuring-a-nested-json",
        "title": "JQ Query - Restructuring a nested JSON"
    },
    {
        "tags": [
            "dictionary",
            "select",
            "replace",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1697662940,
                "creation_date": 1697662940,
                "answer_id": 77319580,
                "question_id": 77319427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `select` filters on the left-hand side of the assignment:\r\n```sh\r\n( .services[]\r\n  | select(.name == &quot;check-api&quot;).plugins[]\r\n  | select(.name == &quot;oauth2&quot;).config.provision_key\r\n) = &quot;xxxxxx&quot;\r\n```\r\n```json\r\n{\r\n  &quot;consumers&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;api-user2&quot;\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;oauth2-devops-app&quot;\r\n    }\r\n  ],\r\n  &quot;services&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;check-api&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;allow&quot;: [\r\n              &quot;acl-devops&quot;\r\n            ],\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false\r\n          },\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;cors&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;provision_key&quot;: &quot;xxxxxx&quot;,\r\n            &quot;token_expiration&quot;: 300\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;check-api2&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/GkgTcuw7NxN)",
                "title": "jq replace value with map and select over a list based on two conditions"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1697665073,
                "last_edit_date": 1697665073,
                "creation_date": 1697663630,
                "answer_id": 77319642,
                "question_id": 77319427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I like [@pmf&#39;s answer](https://stackoverflow.com/a/77319580/1409374) better, but here&#39;s another way to do it.\r\n```lang-jq\r\n.services\r\n|= map(if .name==&quot;check-api&quot;\r\n       then .plugins |= map(if .name==&quot;oauth2&quot;\r\n                            then .config.provision_key=&quot;xxxxxx&quot;\r\n                            end)\r\n       end)\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/Yd_A7HWLbAT &quot;Click me!&quot;).",
                "title": "jq replace value with map and select over a list based on two conditions"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698288596,
                "last_edit_date": 1698288596,
                "creation_date": 1698288256,
                "answer_id": 77363835,
                "question_id": 77319427,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The minimal change solution to what you already had is this ([demo][1]):\r\n\r\n```jq\r\n.services |= map_values( \r\n    select(.name == &quot;check-api&quot; ).plugins[] \r\n    |= (select(.name == &quot;oauth2&quot; ).config.provision_key |= &quot;xxxxxx&quot;)\r\n)\r\n```\r\n\r\nAnd the same without `map_values` ([demo][2]):\r\n\r\n```jq\r\n.services[] |= ( select(.name == &quot;check-api&quot; ).plugins[]\r\n            |= ( select(.name == &quot;oauth2&quot; ).config.provision_key |= &quot;xxxxxx&quot; ))\r\n\r\n```\r\n---\r\nThe issue with your approach is that you are filtering the `service` elements and not the `plugin` elements. \r\n\r\nYour selection criteria shown below asks if each `service` element has a `name` matching `check-api` and has **at least one plugin element** with a `name` matching `oauth2`. In the case of the sample input, the second condition is essentially redundant as both `service` elements satisfy it.\r\n\r\n```jq\r\nselect(.name == &quot;check-api&quot; and .plugins[].name == &quot;oauth2&quot;)\r\n```\r\n\r\nevals to:\r\n\r\n```jq\r\nselect(true and [false, false, true][]). #true\r\nselect(false and [false, true][]) #false\r\n```\r\n\r\nOnce, you picked the service element, you are then essentially picking **all** the plugins under that service when you do: `.plugins[].config.provision_key`.\r\n\r\nIn the presented solution, essentially, we make it so that once the plugins are selected, then we iterate through each of the plugins the same way you did for services, and then pick the corresponding `provision_key` of those elements to change.\r\n\r\n[1]:https://jqplay.org/s/BIUx1VhVhlX\r\n[2]:https://jqplay.org/s/3W0CTvvPUyF",
                "title": "jq replace value with map and select over a list based on two conditions"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1698288596,
        "creation_date": 1697661174,
        "last_edit_date": 1697661289,
        "question_id": 77319427,
        "body_markdown": "I am trying to replace the value &quot;data-omitted&quot; inside **services** &quot;check-api&quot; with &quot;xxxxxx&quot; inside plugin &quot;oauth2&quot; in the following json file:\r\n\r\n\r\n\r\n```\r\n{\r\n  &quot;consumers&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;api-user2&quot;\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;oauth2-devops-app&quot;\r\n    }\r\n  ],\r\n  &quot;services&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;check-api&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;allow&quot;: [\r\n              &quot;acl-devops&quot;\r\n            ],\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false\r\n          },\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;cors&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;provision_key&quot;: &quot;data-omitted&quot;,\r\n            &quot;token_expiration&quot;: 300\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;check-api2&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nthe jq sentence that i am trying and is the most close to my goal is with the following:\r\n\r\n```\r\ncat file.json | jq &#39;.services |= map_values(select(.name == &quot;check-api&quot; and .plugins[].name == &quot;oauth2&quot;).plugins[].config.provision_key |= &quot;xxxxxx&quot;)&#39;\r\n```\r\n\r\nbut the result is inserted in all the plugins&#39;s names for that service:\r\n\r\n\r\n```\r\n{\r\n  &quot;consumers&quot;: [\r\n    {\r\n      &quot;username&quot;: &quot;api-user2&quot;\r\n    },\r\n    {\r\n      &quot;username&quot;: &quot;oauth2-devops-app&quot;\r\n    }\r\n  ],\r\n  &quot;services&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;check-api&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;allow&quot;: [\r\n              &quot;acl-devops&quot;\r\n            ],\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false,\r\n            &quot;provision_key&quot;: &quot;xxxxxx&quot;\r\n          },\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false,\r\n            &quot;provision_key&quot;: &quot;xxxxxx&quot;\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;cors&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;provision_key&quot;: &quot;xxxxxx&quot;,\r\n            &quot;token_expiration&quot;: 300\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;check-api2&quot;,\r\n      &quot;plugins&quot;: [\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;deny&quot;: null,\r\n            &quot;hide_groups_header&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;acl&quot;\r\n        },\r\n        {\r\n          &quot;config&quot;: {\r\n            &quot;credentials&quot;: false,\r\n            &quot;preflight_continue&quot;: false\r\n          },\r\n          &quot;enabled&quot;: true,\r\n          &quot;name&quot;: &quot;oauth2&quot;\r\n        }\r\n      ],\r\n      &quot;port&quot;: 5000,\r\n      &quot;write_timeout&quot;: 60000\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nHow can i select two conditions but based on a list of elements?\r\nAny comment is appreciated. Thanks in advance.",
        "link": "https://stackoverflow.com/questions/77319427/jq-replace-value-with-map-and-select-over-a-list-based-on-two-conditions",
        "title": "jq replace value with map and select over a list based on two conditions"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14152927,
                    "reputation": 770,
                    "user_id": 10224443,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xUCwH.jpg?s=256",
                    "display_name": "urbanSoft",
                    "link": "https://stackoverflow.com/users/10224443/urbansoft"
                },
                "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": 1697705471,
                "post_id": 77322217,
                "comment_id": 136314316,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697710782,
                "last_edit_date": 1697710782,
                "creation_date": 1697705833,
                "answer_id": 77322330,
                "question_id": 77322217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your requirement almost fits what `to_entries` is doing. But you need to carry down the type in a top-down recursion (because with a bottom-up approach, like when [using `walk`](https://stackoverflow.com/revisions/77322330/1), the objects beforehand converted to arrays by `to_entries` become indistinguishable from proper arrays when determining the type afterwards). So, a recursive function could set up type and value, and in case value is an object, use `to_entries` and prepend the name to it recursion results:\r\n```sh\r\ndef f: {\r\n  type: type,\r\n  value: (objects |= (to_entries | map({name: .key} + (.value | f))))\r\n};\r\nf.value\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;id&quot;,\r\n    &quot;type&quot;: &quot;number&quot;,\r\n    &quot;value&quot;: 123456\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name&quot;,\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;Test&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;more&quot;,\r\n    &quot;type&quot;: &quot;array&quot;,\r\n    &quot;value&quot;: [\r\n      1,\r\n      2,\r\n      3\r\n    ]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;instance&quot;,\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;value&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;id&quot;,\r\n        &quot;type&quot;: &quot;number&quot;,\r\n        &quot;value&quot;: 987654\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;name&quot;,\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;Different&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/i9rbtKFMg2p)\r\n\r\nA note regarding your [comment](https://stackoverflow.com/questions/77322217/recursively-transform-json-and-add-data-with-jq/77322330#comment136314316_77322217) that arrays should &quot;stay the same&quot;: While this clarified that arrays should not be transformed (e.g. using numeric indices as their items&#39; &quot;names&quot;), it&#39;s still unclear whether you want array items that are again objects themselves also be transformed or not (while staying inside the untransformed array). For example, change `[1, 2, 3]` in your example to `[1, {&quot;x&quot;:2}, 3]`. The above assumes that this array should be reproduced as is ([Demo](https://jqplay.org/s/t_9TxMWE7S8)). If, however, you want the recursion to be propagated down into array items as well, also update arrays (before objects, to not run into the bottom-up issue), e.g. using `arrays |= map(f.value) | objects |= …` ([Demo](https://jqplay.org/s/6UAQudofLqt)), which would produce `[1, [{&quot;name&quot;: &quot;x&quot;, &quot;type&quot;: &quot;number&quot;, &quot;value&quot;: 2}], 3]` for the altered example.",
                "title": "Recursively transform JSON and add data with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698275770,
                "last_edit_date": 1698275770,
                "creation_date": 1697872897,
                "answer_id": 77335086,
                "question_id": 77322217,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Incase it is useful, here&#39;s a solution that transforms the elements of both arrays and objects to show their types ([demo][1]):\r\n\r\n```jq\r\ndef transform: \r\n  [to_entries[] | { type : .value.type, name : .key, value : .value.value }];\r\n  \r\nwalk({ type : type, value: (if type == &quot;object&quot; then transform else . end)} )\r\n```\r\n\r\nFor this input:\r\n```json\r\n{\r\n  &quot;id&quot;: 123456,\r\n  &quot;name&quot;: &quot;Test&quot;,\r\n  &quot;more&quot;: [1, 2, { &quot;c&quot; : 1 }],\r\n  &quot;instance&quot;: {\r\n    &quot;id&quot;: 987654,\r\n    &quot;name&quot;: { &quot;a&quot; : 1, &quot;b&quot; : 2 }\r\n  }\r\n}\r\n```\r\n\r\nIt will produce this output:\r\n```\r\n{\r\n  &quot;type&quot;: &quot;object&quot;,\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;type&quot;: &quot;number&quot;,\r\n      &quot;name&quot;: &quot;id&quot;,\r\n      &quot;value&quot;: 123456\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;string&quot;,\r\n      &quot;name&quot;: &quot;name&quot;,\r\n      &quot;value&quot;: &quot;Test&quot;\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;array&quot;,\r\n      &quot;name&quot;: &quot;more&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;number&quot;,\r\n          &quot;value&quot;: 1\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;number&quot;,\r\n          &quot;value&quot;: 2\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;value&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;number&quot;,\r\n              &quot;name&quot;: &quot;c&quot;,\r\n              &quot;value&quot;: 1\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;type&quot;: &quot;object&quot;,\r\n      &quot;name&quot;: &quot;instance&quot;,\r\n      &quot;value&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;number&quot;,\r\n          &quot;name&quot;: &quot;id&quot;,\r\n          &quot;value&quot;: 987654\r\n        },\r\n        {\r\n          &quot;type&quot;: &quot;object&quot;,\r\n          &quot;name&quot;: &quot;name&quot;,\r\n          &quot;value&quot;: [\r\n            {\r\n              &quot;type&quot;: &quot;number&quot;,\r\n              &quot;name&quot;: &quot;a&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;type&quot;: &quot;number&quot;,\r\n              &quot;name&quot;: &quot;b&quot;,\r\n              &quot;value&quot;: 2\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/O6aep2bS2Qr",
                "title": "Recursively transform JSON and add data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1698275770,
        "creation_date": 1697704899,
        "last_edit_date": 1697705648,
        "question_id": 77322217,
        "body_markdown": "I&#39;d like to use [`jq`](https://jqlang.github.io/jq/) to recursively transform arbitrary JSON files:\r\n\r\n### Input\r\n\r\n```json\r\n{\r\n  &quot;id&quot;: 123456,\r\n  &quot;name&quot;: &quot;Test&quot;,\r\n  &quot;more&quot;: [1, 2, 3],\r\n  &quot;instance&quot;: {\r\n    &quot;id&quot;: 987654,\r\n    &quot;name&quot;: &quot;Different&quot;\r\n  }\r\n}\r\n```\r\n\r\n### Output\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot; : &quot;id&quot;,\r\n    &quot;type&quot;: &quot;number&quot;,\r\n    &quot;value&quot;: 123456\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;name&quot;,\r\n    &quot;type&quot;: &quot;string&quot;,\r\n    &quot;value&quot;: &quot;Test&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;:&quot;more&quot;,\r\n    &quot;type&quot;: &quot;array&quot;,\r\n    &quot;value&quot;: [1, 2, 3]\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;instance&quot;,\r\n    &quot;type&quot;: &quot;object&quot;,\r\n    &quot;value&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;id&quot;,\r\n        &quot;type&quot;: &quot;number&quot;,\r\n        &quot;value&quot;: 987654\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;name&quot;,\r\n        &quot;type&quot;: &quot;string&quot;,\r\n        &quot;value&quot;: &quot;Different&quot;\r\n      }\r\n    ]\r\n  }  \r\n]\r\n```\r\n\r\n### Transformation Explanation\r\n\r\nEach key-value pair should be transformed to an object containing the keys `name, type, value`. While `name` should be the original _key_. `type` should be the _type_ of the original value perceived by jq&#39;s `type` operator. Since Key-value pairs are transformed to complex objects, pairs on the same hierarchy become part of the same array.\r\n\r\nIs this possible to achieve via [`jq`](https://jqlang.github.io/jq/manual/)?",
        "link": "https://stackoverflow.com/questions/77322217/recursively-transform-json-and-add-data-with-jq",
        "title": "Recursively transform JSON and add data with jq"
    },
    {
        "tags": [
            "json",
            "key",
            "jq",
            "depth"
        ],
        "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": 1697735910,
                "post_id": 77325832,
                "comment_id": 136320424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12736132,
                    "reputation": 3,
                    "user_id": 9251025,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a894d89e75f3390ccfc11a68529eac97?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "john-soda",
                    "link": "https://stackoverflow.com/users/9251025/john-soda"
                },
                "reply_to_user": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1697736240,
                "post_id": 77325832,
                "comment_id": 136320481,
                "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": 1697736411,
                "post_id": 77325832,
                "comment_id": 136320523,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12736132,
                    "reputation": 3,
                    "user_id": 9251025,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a894d89e75f3390ccfc11a68529eac97?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "john-soda",
                    "link": "https://stackoverflow.com/users/9251025/john-soda"
                },
                "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": 1697736598,
                "post_id": 77325832,
                "comment_id": 136320562,
                "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": 1697737185,
                "post_id": 77325832,
                "comment_id": 136320667,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1697755316,
                "last_edit_date": 1697755316,
                "creation_date": 1697754623,
                "answer_id": 77327380,
                "question_id": 77325832,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To produce a stream of key-depths, you could write:\r\n\r\n    jq &#39;paths(scalars) | map(strings) | length&#39; input.json\r\n\r\nOr with an eye on potential efficiency enhancements, you could use the generic stream-oriented `count/1`:\r\n\r\n```\r\ndef count(stream):\r\n  reduce stream as $_ (0; .+1);\r\n\r\npaths(scalars) | count(.[] | strings)\r\n```\r\n\r\nOr to compute the maximum key depth using a generic stream-oriented &quot;max&quot; function:\r\n```\r\ndef count(stream):\r\n  reduce stream as $_ (0; .+1);\r\n\r\n# max(empty) is empty\r\ndef max(stream):\r\n  reduce (stream | [.]) as $x (null;\r\n    if . == null or $x &gt; . then $x else . end )\r\n  | if . == null then empty else .[0] end;\r\n\r\nmax(paths(scalars) | count(.[] | strings))\r\n```\r\n",
                "title": "how to count the number of keys in an json in front of a nested scalar wih jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1697830667,
        "creation_date": 1697735669,
        "last_edit_date": 1697830667,
        "question_id": 77325832,
        "body_markdown": "I have deep nested jsons and I want to count how many keys I have in front of a scalar with jq.\r\nHere a very simplified example\r\n\r\n```\r\n{\r\n    &quot;one&quot;: {\r\n        &quot;two&quot;: {\r\n            &quot;three&quot;: [\r\n                {\r\n                    &quot;four&quot;: [\r\n                        {\r\n                            &quot;five&quot;: [\r\n                                {\r\n                                    &quot;six&quot;: [\r\n                                        {\r\n                                            &quot;sevenA&quot;: {\r\n                                                &quot;eightA&quot;: [\r\n                                                    {\r\n                                                        &quot;nineA&quot;: &quot;Blub&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineB&quot;: &quot;def&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineC&quot;: &quot;foo&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineD&quot;: 22\r\n                                                    }\r\n                                                ]\r\n                                            }\r\n                                        },\r\n                                        {\r\n                                            &quot;sevenB&quot;: {\r\n                                                &quot;eightB&quot;: [\r\n                                                    {\r\n                                                        &quot;nineE&quot;: &quot;Bla&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineF&quot;: &quot;int&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineG&quot;: &quot;s&quot;\r\n                                                    },\r\n                                                    {\r\n                                                        &quot;nineH&quot;: 60\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\n\r\nWith the following command I am able to count keys and arrays in front of the scalar.\r\n```\r\njq &#39;[paths(scalars)] | map(length)&#39;\r\n[\r\n  14,\r\n  14,\r\n  14,\r\n  14,\r\n  14,\r\n  14,\r\n  14,\r\n  14\r\n] \r\n```\r\nlike this\r\n\r\n```\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenA.eightA.[].nineA&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenA.eightA.[].nineB&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenA.eightA.[].nineC&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenA.eightA.[].nineD&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenB.eightB.[].nineE&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenB.eightB.[].nineF&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenB.eightB.[].nineG&quot;,\r\n  &quot;one.two.three.[].four.[].five.[].six.[].sevenB.eightB.[].nineH&quot;\r\n\r\n```\r\nSo I get as result 14 for my example above.\r\n\r\nBut I would like to count only the keys like this.\r\n```\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineE&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineF&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineG&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineH&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineE&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineF&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineG&quot;\r\n&quot;.one.two.three[].four[].five[].six[].sevenB.eightB[].nineH&quot;\r\n```\r\nthat I count 9 keys in front of the scalar or 8 keys in front of the key value pair for the scalar.  \r\n\r\nCould somebody maybe help me how I could do this with jq?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77325832/how-to-count-the-number-of-keys-in-an-json-in-front-of-a-nested-scalar-wih-jq",
        "title": "how to count the number of keys in an json in front of a nested scalar wih jq"
    },
    {
        "tags": [
            "timezone",
            "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": 1697748311,
                "post_id": 77326940,
                "comment_id": 136322349,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6653032,
                    "reputation": 113,
                    "user_id": 5134446,
                    "user_type": "registered",
                    "accept_rate": 75,
                    "profile_image": "https://www.gravatar.com/avatar/74403df7e01129bc15b9c0aa0456980a?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "surz",
                    "link": "https://stackoverflow.com/users/5134446/surz"
                },
                "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": 1697748843,
                "post_id": 77326940,
                "comment_id": 136322415,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6470809,
                    "reputation": 1275,
                    "user_id": 5011027,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8c4b297dbedf97443b1a9f8bf6beb711?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "til",
                    "link": "https://stackoverflow.com/users/5011027/til"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699525409,
                "post_id": 77326940,
                "comment_id": 136544148,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 2,
        "last_activity_date": 1697747658,
        "creation_date": 1697747658,
        "question_id": 77326940,
        "body_markdown": "How to convert UTC datetime to local daylight saving time (AEDT) using JQ (jq-1.6)\r\n\r\n```date -d&quot;2023-10-19T04:59:59Z&quot;```\r\n\r\n&gt; Thu 19 Oct 2023 15:59:59 AEDT\r\n\r\nJQ returns the localtime but not in DST (1 hour extra)\r\n\r\n```echo &#39;&quot;2023-10-19T04:59:59Z&quot;&#39; | jq &#39;fromdate | localtime | todate&#39;```\r\n\r\n&gt; &quot;2023-10-19T16:59:59Z&quot;\r\n\r\nAlso not sure why the time changes right after parsing (1 hour extra)\r\n\r\n```echo &#39;&quot;2023-10-19T04:59:59Z&quot;&#39; | jq &#39;fromdate | todate&#39;```\r\n\r\n&gt; &quot;2023-10-19T05:59:59Z&quot;\r\n",
        "link": "https://stackoverflow.com/questions/77326940/jq-convert-utc-datetime-to-local-daylight-saving-time",
        "title": "JQ convert UTC datetime to local daylight saving time"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1697804256,
                "last_edit_date": 1697804256,
                "creation_date": 1697803012,
                "answer_id": 77330743,
                "question_id": 77330695,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`contains` requires a string as input. With `empty`, however, you eliminate the input entirely. You could change your approach using the empty string as void input:\r\n```sh\r\nselect(\r\n  (.object.optionalA // &quot;&quot; | contains(&quot;d&quot;)) \r\n  or \r\n  (.object.optionalB // &quot;&quot; | contains(&quot;Z&quot;))\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/XnqTKlg9Glv)\r\n\r\nOr use the alternative operator `//` also instead of the boolean operator `or`, so in case of `empty` the next expression can be evaluated:\r\n```sh\r\nselect(\r\n  (.object.optionalA // empty | contains(&quot;d&quot;)) \r\n  //\r\n  (.object.optionalB // empty | contains(&quot;Z&quot;))\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/FMd9o_PmZ8J)\r\n\r\nAnother way could be using `has` to query the presence of a field:\r\n```sh\r\nselect(\r\n  (.object | has(&quot;optionalA&quot;) and (.optionalA | contains(&quot;d&quot;)))\r\n  or\r\n  (.object | has(&quot;optionalB&quot;) and (.optionalB | contains(&quot;Z&quot;)))\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/oZ2SBbEv39U)\r\n\r\nYet another to use the error suppression operator `?` to handle the case of absent fields:\r\n```sh\r\nselect(\r\n  .object | (.optionalA | contains(&quot;d&quot;)?) // (.optionalB | contains(&quot;Z&quot;)?)\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/g4NqSKxhjY0)\r\n\r\nOutput\r\n```json\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;optionalA&quot;: &quot;d&quot;\r\n  }\r\n}\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;optionalB&quot;: &quot;Z&quot;\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "How to deal with multiple optional fields in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1697804256,
        "creation_date": 1697802516,
        "question_id": 77330695,
        "body_markdown": "I have JSON objects that can contain different fields.\r\n```\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;optionalA&quot;: &quot;d&quot;\r\n  }\r\n}\r\n{\r\n  &quot;object&quot;: {\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;optionalB&quot;: &quot;Z&quot;\r\n  }\r\n}\r\n```\r\nIn this example, the object can have the field optionalA or optionalB.\r\n\r\nI want to filter on both if they are present. My command looks like this:\r\n```\r\njq &#39;select(\r\n  (.object.optionalA // empty | contains(&quot;d&quot;)) \r\n  or \r\n  (.object.optionalB // empty | contains(&quot;Z&quot;))\r\n)&#39;\r\n```\r\n\r\nBut this gives me only the result of the first filter, while the second seems ignored.\r\nWhy is this not working, and how can I filter on the respective key that&#39;s present?\r\n",
        "link": "https://stackoverflow.com/questions/77330695/how-to-deal-with-multiple-optional-fields-in-jq",
        "title": "How to deal with multiple optional fields in jq?"
    },
    {
        "tags": [
            "java",
            "jq",
            "zsh",
            "processbuilder"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6651855,
                    "reputation": 285825,
                    "user_id": 5133585,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/dfqcw.png?s=256",
                    "display_name": "Sweeper",
                    "link": "https://stackoverflow.com/users/5133585/sweeper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697867567,
                "post_id": 77334870,
                "comment_id": 136336263,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6651855,
                    "reputation": 285825,
                    "user_id": 5133585,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/dfqcw.png?s=256",
                    "display_name": "Sweeper",
                    "link": "https://stackoverflow.com/users/5133585/sweeper"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1697868333,
                "post_id": 77334870,
                "comment_id": 136336305,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22922007,
                    "reputation": 15,
                    "user_id": 17057696,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/19ca05d52001e72c6a15aa40a02ce24d?s=256&d=identicon&r=PG",
                    "display_name": "Vasily",
                    "link": "https://stackoverflow.com/users/17057696/vasily"
                },
                "reply_to_user": {
                    "account_id": 6651855,
                    "reputation": 285825,
                    "user_id": 5133585,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/dfqcw.png?s=256",
                    "display_name": "Sweeper",
                    "link": "https://stackoverflow.com/users/5133585/sweeper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697869512,
                "post_id": 77334870,
                "comment_id": 136336355,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6651855,
                    "reputation": 285825,
                    "user_id": 5133585,
                    "user_type": "registered",
                    "accept_rate": 96,
                    "profile_image": "https://i.sstatic.net/dfqcw.png?s=256",
                    "display_name": "Sweeper",
                    "link": "https://stackoverflow.com/users/5133585/sweeper"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697870094,
                "post_id": 77334870,
                "comment_id": 136336382,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2053598,
                    "reputation": 44705,
                    "user_id": 1831987,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/38b1c37530189ec4471a43a618e33f67?s=256&d=identicon&r=PG",
                    "display_name": "VGR",
                    "link": "https://stackoverflow.com/users/1831987/vgr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1697917722,
                "post_id": 77334870,
                "comment_id": 136340550,
                "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": 1697966752,
                "post_id": 77334870,
                "comment_id": 136343516,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22922007,
                    "reputation": 15,
                    "user_id": 17057696,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/19ca05d52001e72c6a15aa40a02ce24d?s=256&d=identicon&r=PG",
                    "display_name": "Vasily",
                    "link": "https://stackoverflow.com/users/17057696/vasily"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698035358,
                "post_id": 77334870,
                "comment_id": 136349418,
                "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": 1698174058,
                "post_id": 77334870,
                "comment_id": 136371023,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1697973504,
                "last_edit_date": 1697973504,
                "creation_date": 1697964235,
                "answer_id": 77339247,
                "question_id": 77334870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Make sure that `jq` can be found in the `PATH` environment variable of your process or use the absolute path to the `jq` binary (e.g. `/usr/bin/jq`).\r\n\r\nThat said, your process builder is unnecessarily complicated and forks 3 processes when a single one suffices:\r\n\r\n```\r\nbuilder.command(\r\n    &quot;jq&quot;, // or the absolute path\r\n    &quot;-c&quot;,\r\n    &quot;--arg&quot;,\r\n    &quot;s&quot;,\r\n    &quot;2023-10-20T21:08:58.992978+0300&quot;,\r\n    &quot;select(.timestamp | . &gt;= $s)&quot;);\r\n```\r\n\r\nThis also avoids any shell quoting issues.",
                "title": "ProcessBuilder don&#39;t return result of JQ select"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1697973504,
        "creation_date": 1697866836,
        "last_edit_date": 1697869219,
        "question_id": 77334870,
        "body_markdown": "I have follow code:\r\n\r\n```\r\nProcessBuilder builder = new ProcessBuilder();\r\n\r\nbuilder.command(&quot;sh&quot;, &quot;-c&quot;, &quot;cat eve.json | jq -c --arg s &#39;2023-10-20T21:08:58.992978+0300&#39; &#39;select(.timestamp | . &gt;= $s)&#39;&quot;);\r\nbuilder.directory(new File(&quot;/Users/naysav/projectsIT/moshub/intrusion-detection-reactor/&quot;));\r\n\r\nProcess process = builder.start();\r\nInputStreamReader in = new InputStreamReader(process.getInputStream());\r\nList&lt;String&gt; inList = new BufferedReader(in).lines().toList();\r\n```\r\n\r\nAnd file eve.json with follow lines:\r\n\r\n    {&quot;timestamp&quot;:&quot;2023-10-20T21:08:58.992978+0300&quot;,&quot;event_type&quot;:&quot;stats&quot;,&quot;stats&quot;:{&quot;uptime&quot;:87708,&quot;capture&quot;:{&quot;kernel_packets&quot;:439437,&quot;kernel_drops&quot;:0,&quot;errors&quot;:0,&quot;afpacket&quot;:{&quot;busy_loop_avg&quot;:0,&quot;polls&quot;:428507,&quot;poll_signal&quot;:0,&quot;poll_timeout&quot;:386160,&quot;poll_data&quot;:42347,&quot;poll_errors&quot;:0,&quot;send_errors&quot;:0}},&quot;decoder&quot;:{&quot;pkts&quot;:439437,&quot;bytes&quot;:578328975,&quot;invalid&quot;:0,&quot;ipv4&quot;:436981,&quot;ipv6&quot;:2061,&quot;ethernet&quot;:439437,&quot;arp&quot;:395,&quot;unknown_ethertype&quot;:0,&quot;chdlc&quot;:0,&quot;raw&quot;:0,&quot;null&quot;:0,&quot;sll&quot;:0,&quot;tcp&quot;:434317,&quot;udp&quot;:4148,&quot;sctp&quot;:0,&quot;esp&quot;:0,&quot;icmpv4&quot;:88,&quot;icmpv6&quot;:487,&quot;ppp&quot;:0,&quot;pppoe&quot;:0,&quot;geneve&quot;:0,&quot;gre&quot;:0,&quot;vlan&quot;:0,&quot;vlan_qinq&quot;:0,&quot;vlan_qinqinq&quot;:0,&quot;vxlan&quot;:0,&quot;vntag&quot;:0,&quot;ieee8021ah&quot;:0,&quot;teredo&quot;:0,&quot;ipv4_in_ipv6&quot;:0,&quot;ipv6_in_ipv6&quot;:0,&quot;mpls&quot;:0,&quot;avg_pkt_size&quot;:1316,&quot;max_pkt_size&quot;:1514,&quot;max_mac_addrs_src&quot;:0,&quot;max_mac_addrs_dst&quot;:0,&quot;erspan&quot;:0,&quot;nsh&quot;:0,&quot;event&quot;:{&quot;ipv4&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;iplen_smaller_than_hlen&quot;:0,&quot;trunc_pkt&quot;:0,&quot;opt_invalid&quot;:0,&quot;opt_invalid_len&quot;:0,&quot;opt_malformed&quot;:0,&quot;opt_pad_required&quot;:2,&quot;opt_eol_required&quot;:0,&quot;opt_duplicate&quot;:0,&quot;opt_unknown&quot;:0,&quot;wrong_ip_version&quot;:0,&quot;icmpv6&quot;:0,&quot;frag_pkt_too_large&quot;:0,&quot;frag_overlap&quot;:0,&quot;frag_ignored&quot;:0},&quot;icmpv4&quot;:{&quot;pkt_too_small&quot;:0,&quot;unknown_type&quot;:0,&quot;unknown_code&quot;:0,&quot;ipv4_trunc_pkt&quot;:0,&quot;ipv4_unknown_ver&quot;:0},&quot;icmpv6&quot;:{&quot;unknown_type&quot;:0,&quot;unknown_code&quot;:0,&quot;pkt_too_small&quot;:0,&quot;ipv6_unknown_version&quot;:0,&quot;ipv6_trunc_pkt&quot;:0,&quot;mld_message_with_invalid_hl&quot;:0,&quot;unassigned_type&quot;:0,&quot;experimentation_type&quot;:0},&quot;ipv6&quot;:{&quot;pkt_too_small&quot;:0,&quot;trunc_pkt&quot;:0,&quot;trunc_exthdr&quot;:0,&quot;exthdr_dupl_fh&quot;:0,&quot;exthdr_useless_fh&quot;:0,&quot;exthdr_dupl_rh&quot;:0,&quot;exthdr_dupl_hh&quot;:0,&quot;exthdr_dupl_dh&quot;:0,&quot;exthdr_dupl_ah&quot;:0,&quot;exthdr_dupl_eh&quot;:0,&quot;exthdr_invalid_optlen&quot;:0,&quot;wrong_ip_version&quot;:0,&quot;exthdr_ah_res_not_null&quot;:0,&quot;hopopts_unknown_opt&quot;:0,&quot;hopopts_only_padding&quot;:0,&quot;dstopts_unknown_opt&quot;:0,&quot;dstopts_only_padding&quot;:0,&quot;rh_type_0&quot;:0,&quot;zero_len_padn&quot;:416,&quot;fh_non_zero_reserved_field&quot;:0,&quot;data_after_none_header&quot;:0,&quot;unknown_next_header&quot;:0,&quot;icmpv4&quot;:0,&quot;frag_pkt_too_large&quot;:0,&quot;frag_overlap&quot;:0,&quot;frag_invalid_length&quot;:0,&quot;frag_ignored&quot;:0,&quot;ipv4_in_ipv6_too_small&quot;:0,&quot;ipv4_in_ipv6_wrong_version&quot;:0,&quot;ipv6_in_ipv6_too_small&quot;:0,&quot;ipv6_in_ipv6_wrong_version&quot;:0},&quot;tcp&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;invalid_optlen&quot;:0,&quot;opt_invalid_len&quot;:0,&quot;opt_duplicate&quot;:0},&quot;udp&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;hlen_invalid&quot;:0,&quot;len_invalid&quot;:0},&quot;sll&quot;:{&quot;pkt_too_small&quot;:0},&quot;ethernet&quot;:{&quot;pkt_too_small&quot;:0},&quot;ppp&quot;:{&quot;pkt_too_small&quot;:0,&quot;vju_pkt_too_small&quot;:0,&quot;ip4_pkt_too_small&quot;:0,&quot;ip6_pkt_too_small&quot;:0,&quot;wrong_type&quot;:0,&quot;unsup_proto&quot;:0},&quot;pppoe&quot;:{&quot;pkt_too_small&quot;:0,&quot;wrong_code&quot;:0,&quot;malformed_tags&quot;:0},&quot;gre&quot;:{&quot;pkt_too_small&quot;:0,&quot;wrong_version&quot;:0,&quot;version0_recur&quot;:0,&quot;version0_flags&quot;:0,&quot;version0_hdr_too_big&quot;:0,&quot;version0_malformed_sre_hdr&quot;:0,&quot;version1_chksum&quot;:0,&quot;version1_route&quot;:0,&quot;version1_ssr&quot;:0,&quot;version1_recur&quot;:0,&quot;version1_flags&quot;:0,&quot;version1_no_key&quot;:0,&quot;version1_wrong_protocol&quot;:0,&quot;version1_malformed_sre_hdr&quot;:0,&quot;version1_hdr_too_big&quot;:0},&quot;vlan&quot;:{&quot;header_too_small&quot;:0,&quot;unknown_type&quot;:0,&quot;too_many_layers&quot;:0},&quot;ieee8021ah&quot;:{&quot;header_too_small&quot;:0},&quot;vntag&quot;:{&quot;header_too_small&quot;:0,&quot;unknown_type&quot;:0},&quot;ipraw&quot;:{&quot;invalid_ip_version&quot;:0},&quot;ltnull&quot;:{&quot;pkt_too_small&quot;:0,&quot;unsupported_type&quot;:0},&quot;sctp&quot;:{&quot;pkt_too_small&quot;:0},&quot;esp&quot;:{&quot;pkt_too_small&quot;:0},&quot;mpls&quot;:{&quot;header_too_small&quot;:0,&quot;pkt_too_small&quot;:0,&quot;bad_label_router_alert&quot;:0,&quot;bad_label_implicit_null&quot;:0,&quot;bad_label_reserved&quot;:0,&quot;unknown_payload_type&quot;:0},&quot;vxlan&quot;:{&quot;unknown_payload_type&quot;:0},&quot;geneve&quot;:{&quot;unknown_payload_type&quot;:0},&quot;erspan&quot;:{&quot;header_too_small&quot;:0,&quot;unsupported_version&quot;:0,&quot;too_many_vlan_layers&quot;:0},&quot;dce&quot;:{&quot;pkt_too_small&quot;:0},&quot;chdlc&quot;:{&quot;pkt_too_small&quot;:0},&quot;nsh&quot;:{&quot;header_too_small&quot;:0,&quot;unsupported_version&quot;:0,&quot;bad_header_length&quot;:0,&quot;reserved_type&quot;:0,&quot;unsupported_type&quot;:0,&quot;unknown_payload&quot;:0}},&quot;too_many_layers&quot;:0},&quot;tcp&quot;:{&quot;syn&quot;:101,&quot;synack&quot;:94,&quot;rst&quot;:8,&quot;active_sessions&quot;:2,&quot;sessions&quot;:96,&quot;ssn_memcap_drop&quot;:0,&quot;ssn_from_cache&quot;:15,&quot;ssn_from_pool&quot;:81,&quot;pseudo&quot;:0,&quot;pseudo_failed&quot;:0,&quot;invalid_checksum&quot;:0,&quot;midstream_pickups&quot;:0,&quot;pkt_on_wrong_thread&quot;:0,&quot;ack_unseen_data&quot;:0,&quot;segment_memcap_drop&quot;:0,&quot;segment_from_cache&quot;:10973,&quot;segment_from_pool&quot;:284,&quot;stream_depth_reached&quot;:13,&quot;reassembly_gap&quot;:0,&quot;overlap&quot;:0,&quot;overlap_diff_data&quot;:0,&quot;insert_data_normal_fail&quot;:0,&quot;insert_data_overlap_fail&quot;:0,&quot;memuse&quot;:1212416,&quot;reassembly_memuse&quot;:237568},&quot;flow&quot;:{&quot;memcap&quot;:0,&quot;total&quot;:882,&quot;active&quot;:9,&quot;tcp&quot;:96,&quot;udp&quot;:625,&quot;icmpv4&quot;:0,&quot;icmpv6&quot;:161,&quot;tcp_reuse&quot;:0,&quot;get_used&quot;:0,&quot;get_used_eval&quot;:0,&quot;get_used_eval_reject&quot;:0,&quot;get_used_eval_busy&quot;:0,&quot;get_used_failed&quot;:0,&quot;wrk&quot;:{&quot;spare_sync_avg&quot;:99,&quot;spare_sync&quot;:9,&quot;spare_sync_incomplete&quot;:1,&quot;spare_sync_empty&quot;:0,&quot;flows_evicted_needs_work&quot;:19,&quot;flows_evicted_pkt_inject&quot;:21,&quot;flows_evicted&quot;:100,&quot;flows_injected&quot;:19,&quot;flows_injected_max&quot;:2},&quot;end&quot;:{&quot;state&quot;:{&quot;new&quot;:509,&quot;established&quot;:272,&quot;closed&quot;:92,&quot;local_bypassed&quot;:0,&quot;capture_bypassed&quot;:0},&quot;tcp_state&quot;:{&quot;none&quot;:0,&quot;syn_sent&quot;:2,&quot;syn_recv&quot;:0,&quot;established&quot;:0,&quot;fin_wait1&quot;:0,&quot;fin_wait2&quot;:0,&quot;time_wait&quot;:0,&quot;last_ack&quot;:0,&quot;close_wait&quot;:0,&quot;closing&quot;:0,&quot;closed&quot;:92},&quot;tcp_liberal&quot;:0},&quot;mgr&quot;:{&quot;full_hash_pass&quot;:1970,&quot;rows_per_sec&quot;:6553,&quot;rows_maxlen&quot;:2,&quot;flows_checked&quot;:1833,&quot;flows_notimeout&quot;:1058,&quot;flows_timeout&quot;:775,&quot;flows_evicted&quot;:775,&quot;flows_evicted_needs_work&quot;:19},&quot;spare&quot;:9857,&quot;emerg_mode_entered&quot;:0,&quot;emerg_mode_over&quot;:0,&quot;recycler&quot;:{&quot;recycled&quot;:756,&quot;queue_avg&quot;:0,&quot;queue_max&quot;:3},&quot;memuse&quot;:11428608},&quot;defrag&quot;:{&quot;ipv4&quot;:{&quot;fragments&quot;:0,&quot;reassembled&quot;:0},&quot;ipv6&quot;:{&quot;fragments&quot;:0,&quot;reassembled&quot;:0},&quot;max_frag_hits&quot;:0},&quot;flow_bypassed&quot;:{&quot;local_pkts&quot;:0,&quot;local_bytes&quot;:0,&quot;local_capture_pkts&quot;:0,&quot;local_capture_bytes&quot;:0,&quot;closed&quot;:0,&quot;pkts&quot;:0,&quot;bytes&quot;:0},&quot;detect&quot;:{&quot;engines&quot;:[{&quot;id&quot;:0,&quot;last_reload&quot;:&quot;2023-10-19T20:47:10.316815+0300&quot;,&quot;rules_loaded&quot;:2,&quot;rules_failed&quot;:0}],&quot;alert&quot;:4,&quot;alert_queue_overflow&quot;:0,&quot;alerts_suppressed&quot;:0},&quot;app_layer&quot;:{&quot;flow&quot;:{&quot;http&quot;:84,&quot;ftp&quot;:0,&quot;smtp&quot;:0,&quot;tls&quot;:8,&quot;ssh&quot;:0,&quot;imap&quot;:0,&quot;smb&quot;:1,&quot;dcerpc_tcp&quot;:0,&quot;dns_tcp&quot;:1,&quot;nfs_tcp&quot;:0,&quot;ntp&quot;:70,&quot;ftp-data&quot;:0,&quot;tftp&quot;:0,&quot;ike&quot;:0,&quot;krb5_tcp&quot;:0,&quot;quic&quot;:0,&quot;dhcp&quot;:70,&quot;snmp&quot;:0,&quot;sip&quot;:0,&quot;rfb&quot;:0,&quot;mqtt&quot;:0,&quot;telnet&quot;:0,&quot;rdp&quot;:0,&quot;http2&quot;:0,&quot;bittorrent-dht&quot;:0,&quot;failed_tcp&quot;:0,&quot;dcerpc_udp&quot;:0,&quot;dns_udp&quot;:197,&quot;nfs_udp&quot;:0,&quot;krb5_udp&quot;:0,&quot;failed_udp&quot;:288},&quot;tx&quot;:{&quot;http&quot;:305,&quot;ftp&quot;:0,&quot;smtp&quot;:0,&quot;tls&quot;:0,&quot;ssh&quot;:0,&quot;imap&quot;:0,&quot;smb&quot;:1,&quot;dcerpc_tcp&quot;:0,&quot;dns_tcp&quot;:4,&quot;nfs_tcp&quot;:0,&quot;ntp&quot;:74,&quot;ftp-data&quot;:0,&quot;tftp&quot;:0,&quot;ike&quot;:0,&quot;krb5_tcp&quot;:0,&quot;quic&quot;:0,&quot;dhcp&quot;:213,&quot;snmp&quot;:0,&quot;sip&quot;:0,&quot;rfb&quot;:0,&quot;mqtt&quot;:0,&quot;telnet&quot;:0,&quot;rdp&quot;:0,&quot;http2&quot;:0,&quot;bittorrent-dht&quot;:0,&quot;dcerpc_udp&quot;:0,&quot;dns_udp&quot;:403,&quot;nfs_udp&quot;:0,&quot;krb5_udp&quot;:0},&quot;error&quot;:{&quot;http&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ftp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;smtp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;tls&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ssh&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;imap&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;smb&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dcerpc_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dns_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;nfs_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ntp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ftp-data&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;tftp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ike&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;krb5_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;quic&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dhcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;snmp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;sip&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;rfb&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;mqtt&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;telnet&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;rdp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;http2&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;bittorrent-dht&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;failed_tcp&quot;:{&quot;gap&quot;:0},&quot;dcerpc_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dns_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;nfs_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;krb5_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0}},&quot;expectations&quot;:0},&quot;memcap_pressure&quot;:8,&quot;memcap_pressure_max&quot;:8,&quot;http&quot;:{&quot;memuse&quot;:208,&quot;memcap&quot;:0},&quot;ftp&quot;:{&quot;memuse&quot;:0,&quot;memcap&quot;:0},&quot;file_store&quot;:{&quot;open_files&quot;:0}}}\r\n    ...\r\n\r\n\r\n\r\nEnvironment: Java 17, Mac OS (Ventura 13), Spring Boot 3.1.1\r\n\r\nMy goal is parsing json-logs from file from some date.\r\nFor this I try using `jq`, but when it run by java result is empty list.\r\n\r\nRunning by zsh terminal returns expected result:\r\n\r\n`cat eve.json | jq -c --arg s &#39;2023-10-20T21:08:15.000153+0300&#39; \r\n\r\n    {&quot;timestamp&quot;:&quot;2023-10-20T21:08:18.976750+0300&quot;,&quot;event_type&quot;:&quot;stats&quot;,&quot;stats&quot;:{&quot;uptime&quot;:87668,&quot;capture&quot;:{&quot;kernel_packets&quot;:439437,&quot;kernel_drops&quot;:0,&quot;errors&quot;:0,&quot;afpacket&quot;:{&quot;busy_loop_avg&quot;:0,&quot;polls&quot;:427733,&quot;poll_signal&quot;:0,&quot;poll_timeout&quot;:385386,&quot;poll_data&quot;:42347,&quot;poll_errors&quot;:0,&quot;send_errors&quot;:0}},&quot;decoder&quot;:{&quot;pkts&quot;:439437,&quot;bytes&quot;:578328975,&quot;invalid&quot;:0,&quot;ipv4&quot;:436981,&quot;ipv6&quot;:2061,&quot;ethernet&quot;:439437,&quot;arp&quot;:395,&quot;unknown_ethertype&quot;:0,&quot;chdlc&quot;:0,&quot;raw&quot;:0,&quot;null&quot;:0,&quot;sll&quot;:0,&quot;tcp&quot;:434317,&quot;udp&quot;:4148,&quot;sctp&quot;:0,&quot;esp&quot;:0,&quot;icmpv4&quot;:88,&quot;icmpv6&quot;:487,&quot;ppp&quot;:0,&quot;pppoe&quot;:0,&quot;geneve&quot;:0,&quot;gre&quot;:0,&quot;vlan&quot;:0,&quot;vlan_qinq&quot;:0,&quot;vlan_qinqinq&quot;:0,&quot;vxlan&quot;:0,&quot;vntag&quot;:0,&quot;ieee8021ah&quot;:0,&quot;teredo&quot;:0,&quot;ipv4_in_ipv6&quot;:0,&quot;ipv6_in_ipv6&quot;:0,&quot;mpls&quot;:0,&quot;avg_pkt_size&quot;:1316,&quot;max_pkt_size&quot;:1514,&quot;max_mac_addrs_src&quot;:0,&quot;max_mac_addrs_dst&quot;:0,&quot;erspan&quot;:0,&quot;nsh&quot;:0,&quot;event&quot;:{&quot;ipv4&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;iplen_smaller_than_hlen&quot;:0,&quot;trunc_pkt&quot;:0,&quot;opt_invalid&quot;:0,&quot;opt_invalid_len&quot;:0,&quot;opt_malformed&quot;:0,&quot;opt_pad_required&quot;:2,&quot;opt_eol_required&quot;:0,&quot;opt_duplicate&quot;:0,&quot;opt_unknown&quot;:0,&quot;wrong_ip_version&quot;:0,&quot;icmpv6&quot;:0,&quot;frag_pkt_too_large&quot;:0,&quot;frag_overlap&quot;:0,&quot;frag_ignored&quot;:0},&quot;icmpv4&quot;:{&quot;pkt_too_small&quot;:0,&quot;unknown_type&quot;:0,&quot;unknown_code&quot;:0,&quot;ipv4_trunc_pkt&quot;:0,&quot;ipv4_unknown_ver&quot;:0},&quot;icmpv6&quot;:{&quot;unknown_type&quot;:0,&quot;unknown_code&quot;:0,&quot;pkt_too_small&quot;:0,&quot;ipv6_unknown_version&quot;:0,&quot;ipv6_trunc_pkt&quot;:0,&quot;mld_message_with_invalid_hl&quot;:0,&quot;unassigned_type&quot;:0,&quot;experimentation_type&quot;:0},&quot;ipv6&quot;:{&quot;pkt_too_small&quot;:0,&quot;trunc_pkt&quot;:0,&quot;trunc_exthdr&quot;:0,&quot;exthdr_dupl_fh&quot;:0,&quot;exthdr_useless_fh&quot;:0,&quot;exthdr_dupl_rh&quot;:0,&quot;exthdr_dupl_hh&quot;:0,&quot;exthdr_dupl_dh&quot;:0,&quot;exthdr_dupl_ah&quot;:0,&quot;exthdr_dupl_eh&quot;:0,&quot;exthdr_invalid_optlen&quot;:0,&quot;wrong_ip_version&quot;:0,&quot;exthdr_ah_res_not_null&quot;:0,&quot;hopopts_unknown_opt&quot;:0,&quot;hopopts_only_padding&quot;:0,&quot;dstopts_unknown_opt&quot;:0,&quot;dstopts_only_padding&quot;:0,&quot;rh_type_0&quot;:0,&quot;zero_len_padn&quot;:416,&quot;fh_non_zero_reserved_field&quot;:0,&quot;data_after_none_header&quot;:0,&quot;unknown_next_header&quot;:0,&quot;icmpv4&quot;:0,&quot;frag_pkt_too_large&quot;:0,&quot;frag_overlap&quot;:0,&quot;frag_invalid_length&quot;:0,&quot;frag_ignored&quot;:0,&quot;ipv4_in_ipv6_too_small&quot;:0,&quot;ipv4_in_ipv6_wrong_version&quot;:0,&quot;ipv6_in_ipv6_too_small&quot;:0,&quot;ipv6_in_ipv6_wrong_version&quot;:0},&quot;tcp&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;invalid_optlen&quot;:0,&quot;opt_invalid_len&quot;:0,&quot;opt_duplicate&quot;:0},&quot;udp&quot;:{&quot;pkt_too_small&quot;:0,&quot;hlen_too_small&quot;:0,&quot;hlen_invalid&quot;:0,&quot;len_invalid&quot;:0},&quot;sll&quot;:{&quot;pkt_too_small&quot;:0},&quot;ethernet&quot;:{&quot;pkt_too_small&quot;:0},&quot;ppp&quot;:{&quot;pkt_too_small&quot;:0,&quot;vju_pkt_too_small&quot;:0,&quot;ip4_pkt_too_small&quot;:0,&quot;ip6_pkt_too_small&quot;:0,&quot;wrong_type&quot;:0,&quot;unsup_proto&quot;:0},&quot;pppoe&quot;:{&quot;pkt_too_small&quot;:0,&quot;wrong_code&quot;:0,&quot;malformed_tags&quot;:0},&quot;gre&quot;:{&quot;pkt_too_small&quot;:0,&quot;wrong_version&quot;:0,&quot;version0_recur&quot;:0,&quot;version0_flags&quot;:0,&quot;version0_hdr_too_big&quot;:0,&quot;version0_malformed_sre_hdr&quot;:0,&quot;version1_chksum&quot;:0,&quot;version1_route&quot;:0,&quot;version1_ssr&quot;:0,&quot;version1_recur&quot;:0,&quot;version1_flags&quot;:0,&quot;version1_no_key&quot;:0,&quot;version1_wrong_protocol&quot;:0,&quot;version1_malformed_sre_hdr&quot;:0,&quot;version1_hdr_too_big&quot;:0},&quot;vlan&quot;:{&quot;header_too_small&quot;:0,&quot;unknown_type&quot;:0,&quot;too_many_layers&quot;:0},&quot;ieee8021ah&quot;:{&quot;header_too_small&quot;:0},&quot;vntag&quot;:{&quot;header_too_small&quot;:0,&quot;unknown_type&quot;:0},&quot;ipraw&quot;:{&quot;invalid_ip_version&quot;:0},&quot;ltnull&quot;:{&quot;pkt_too_small&quot;:0,&quot;unsupported_type&quot;:0},&quot;sctp&quot;:{&quot;pkt_too_small&quot;:0},&quot;esp&quot;:{&quot;pkt_too_small&quot;:0},&quot;mpls&quot;:{&quot;header_too_small&quot;:0,&quot;pkt_too_small&quot;:0,&quot;bad_label_router_alert&quot;:0,&quot;bad_label_implicit_null&quot;:0,&quot;bad_label_reserved&quot;:0,&quot;unknown_payload_type&quot;:0},&quot;vxlan&quot;:{&quot;unknown_payload_type&quot;:0},&quot;geneve&quot;:{&quot;unknown_payload_type&quot;:0},&quot;erspan&quot;:{&quot;header_too_small&quot;:0,&quot;unsupported_version&quot;:0,&quot;too_many_vlan_layers&quot;:0},&quot;dce&quot;:{&quot;pkt_too_small&quot;:0},&quot;chdlc&quot;:{&quot;pkt_too_small&quot;:0},&quot;nsh&quot;:{&quot;header_too_small&quot;:0,&quot;unsupported_version&quot;:0,&quot;bad_header_length&quot;:0,&quot;reserved_type&quot;:0,&quot;unsupported_type&quot;:0,&quot;unknown_payload&quot;:0}},&quot;too_many_layers&quot;:0},&quot;tcp&quot;:{&quot;syn&quot;:101,&quot;synack&quot;:94,&quot;rst&quot;:8,&quot;active_sessions&quot;:2,&quot;sessions&quot;:96,&quot;ssn_memcap_drop&quot;:0,&quot;ssn_from_cache&quot;:15,&quot;ssn_from_pool&quot;:81,&quot;pseudo&quot;:0,&quot;pseudo_failed&quot;:0,&quot;invalid_checksum&quot;:0,&quot;midstream_pickups&quot;:0,&quot;pkt_on_wrong_thread&quot;:0,&quot;ack_unseen_data&quot;:0,&quot;segment_memcap_drop&quot;:0,&quot;segment_from_cache&quot;:10973,&quot;segment_from_pool&quot;:284,&quot;stream_depth_reached&quot;:13,&quot;reassembly_gap&quot;:0,&quot;overlap&quot;:0,&quot;overlap_diff_data&quot;:0,&quot;insert_data_normal_fail&quot;:0,&quot;insert_data_overlap_fail&quot;:0,&quot;memuse&quot;:1212416,&quot;reassembly_memuse&quot;:237568},&quot;flow&quot;:{&quot;memcap&quot;:0,&quot;total&quot;:882,&quot;active&quot;:9,&quot;tcp&quot;:96,&quot;udp&quot;:625,&quot;icmpv4&quot;:0,&quot;icmpv6&quot;:161,&quot;tcp_reuse&quot;:0,&quot;get_used&quot;:0,&quot;get_used_eval&quot;:0,&quot;get_used_eval_reject&quot;:0,&quot;get_used_eval_busy&quot;:0,&quot;get_used_failed&quot;:0,&quot;wrk&quot;:{&quot;spare_sync_avg&quot;:99,&quot;spare_sync&quot;:9,&quot;spare_sync_incomplete&quot;:1,&quot;spare_sync_empty&quot;:0,&quot;flows_evicted_needs_work&quot;:19,&quot;flows_evicted_pkt_inject&quot;:21,&quot;flows_evicted&quot;:100,&quot;flows_injected&quot;:19,&quot;flows_injected_max&quot;:2},&quot;end&quot;:{&quot;state&quot;:{&quot;new&quot;:509,&quot;established&quot;:272,&quot;closed&quot;:92,&quot;local_bypassed&quot;:0,&quot;capture_bypassed&quot;:0},&quot;tcp_state&quot;:{&quot;none&quot;:0,&quot;syn_sent&quot;:2,&quot;syn_recv&quot;:0,&quot;established&quot;:0,&quot;fin_wait1&quot;:0,&quot;fin_wait2&quot;:0,&quot;time_wait&quot;:0,&quot;last_ack&quot;:0,&quot;close_wait&quot;:0,&quot;closing&quot;:0,&quot;closed&quot;:92},&quot;tcp_liberal&quot;:0},&quot;mgr&quot;:{&quot;full_hash_pass&quot;:1966,&quot;rows_per_sec&quot;:6553,&quot;rows_maxlen&quot;:2,&quot;flows_checked&quot;:1832,&quot;flows_notimeout&quot;:1057,&quot;flows_timeout&quot;:775,&quot;flows_evicted&quot;:775,&quot;flows_evicted_needs_work&quot;:19},&quot;spare&quot;:9857,&quot;emerg_mode_entered&quot;:0,&quot;emerg_mode_over&quot;:0,&quot;recycler&quot;:{&quot;recycled&quot;:756,&quot;queue_avg&quot;:0,&quot;queue_max&quot;:3},&quot;memuse&quot;:11428608},&quot;defrag&quot;:{&quot;ipv4&quot;:{&quot;fragments&quot;:0,&quot;reassembled&quot;:0},&quot;ipv6&quot;:{&quot;fragments&quot;:0,&quot;reassembled&quot;:0},&quot;max_frag_hits&quot;:0},&quot;flow_bypassed&quot;:{&quot;local_pkts&quot;:0,&quot;local_bytes&quot;:0,&quot;local_capture_pkts&quot;:0,&quot;local_capture_bytes&quot;:0,&quot;closed&quot;:0,&quot;pkts&quot;:0,&quot;bytes&quot;:0},&quot;detect&quot;:{&quot;engines&quot;:[{&quot;id&quot;:0,&quot;last_reload&quot;:&quot;2023-10-19T20:47:10.316815+0300&quot;,&quot;rules_loaded&quot;:2,&quot;rules_failed&quot;:0}],&quot;alert&quot;:4,&quot;alert_queue_overflow&quot;:0,&quot;alerts_suppressed&quot;:0},&quot;app_layer&quot;:{&quot;flow&quot;:{&quot;http&quot;:84,&quot;ftp&quot;:0,&quot;smtp&quot;:0,&quot;tls&quot;:8,&quot;ssh&quot;:0,&quot;imap&quot;:0,&quot;smb&quot;:1,&quot;dcerpc_tcp&quot;:0,&quot;dns_tcp&quot;:1,&quot;nfs_tcp&quot;:0,&quot;ntp&quot;:70,&quot;ftp-data&quot;:0,&quot;tftp&quot;:0,&quot;ike&quot;:0,&quot;krb5_tcp&quot;:0,&quot;quic&quot;:0,&quot;dhcp&quot;:70,&quot;snmp&quot;:0,&quot;sip&quot;:0,&quot;rfb&quot;:0,&quot;mqtt&quot;:0,&quot;telnet&quot;:0,&quot;rdp&quot;:0,&quot;http2&quot;:0,&quot;bittorrent-dht&quot;:0,&quot;failed_tcp&quot;:0,&quot;dcerpc_udp&quot;:0,&quot;dns_udp&quot;:197,&quot;nfs_udp&quot;:0,&quot;krb5_udp&quot;:0,&quot;failed_udp&quot;:288},&quot;tx&quot;:{&quot;http&quot;:305,&quot;ftp&quot;:0,&quot;smtp&quot;:0,&quot;tls&quot;:0,&quot;ssh&quot;:0,&quot;imap&quot;:0,&quot;smb&quot;:1,&quot;dcerpc_tcp&quot;:0,&quot;dns_tcp&quot;:4,&quot;nfs_tcp&quot;:0,&quot;ntp&quot;:74,&quot;ftp-data&quot;:0,&quot;tftp&quot;:0,&quot;ike&quot;:0,&quot;krb5_tcp&quot;:0,&quot;quic&quot;:0,&quot;dhcp&quot;:213,&quot;snmp&quot;:0,&quot;sip&quot;:0,&quot;rfb&quot;:0,&quot;mqtt&quot;:0,&quot;telnet&quot;:0,&quot;rdp&quot;:0,&quot;http2&quot;:0,&quot;bittorrent-dht&quot;:0,&quot;dcerpc_udp&quot;:0,&quot;dns_udp&quot;:403,&quot;nfs_udp&quot;:0,&quot;krb5_udp&quot;:0},&quot;error&quot;:{&quot;http&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ftp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;smtp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;tls&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ssh&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;imap&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;smb&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dcerpc_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dns_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;nfs_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ntp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ftp-data&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;tftp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;ike&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;krb5_tcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;quic&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dhcp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;snmp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;sip&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;rfb&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;mqtt&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;telnet&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;rdp&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;http2&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;bittorrent-dht&quot;:{&quot;gap&quot;:0,&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;failed_tcp&quot;:{&quot;gap&quot;:0},&quot;dcerpc_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;dns_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;nfs_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0},&quot;krb5_udp&quot;:{&quot;alloc&quot;:0,&quot;parser&quot;:0,&quot;internal&quot;:0}},&quot;expectations&quot;:0},&quot;memcap_pressure&quot;:8,&quot;memcap_pressure_max&quot;:8,&quot;http&quot;:{&quot;memuse&quot;:208,&quot;memcap&quot;:0},&quot;ftp&quot;:{&quot;memuse&quot;:0,&quot;memcap&quot;:0},&quot;file_store&quot;:{&quot;open_files&quot;:0}}}\r\n    ...\r\n    \r\n\r\nAlso ProcessBuilder returns expected result when using `grep`:\r\n\r\n`builder.command(&quot;sh&quot;, &quot;-c&quot;, &quot;cat eve.json | grep &#39;2023-10-20T21:08:58.992978+0300&#39;&quot;);`\r\n\r\nIf I run the `cat eve.json | jq -c --arg s &#39;2023-10-20T21:08:58.992978+0300&#39; &#39;select(.timestamp | . &gt;= $s)` through a `script.sh` by ProcessBuilder, the result is the same.\r\n\r\nWhat am I missing?\r\n",
        "link": "https://stackoverflow.com/questions/77334870/processbuilder-dont-return-result-of-jq-select",
        "title": "ProcessBuilder don&#39;t return result of JQ select"
    },
    {
        "tags": [
            "json",
            "shell",
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 93689,
                    "reputation": 426801,
                    "user_id": 256196,
                    "user_type": "moderator",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/d84b558fd67be10d5a718fb94231909d?s=256&d=identicon&r=PG",
                    "display_name": "Bohemian",
                    "link": "https://stackoverflow.com/users/256196/bohemian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1698017324,
                "post_id": 77342021,
                "comment_id": 136348292,
                "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": 1698021677,
                "post_id": 77342021,
                "comment_id": 136348582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1698018079,
                "creation_date": 1698018079,
                "answer_id": 77342048,
                "question_id": 77342021,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think that you can use:\r\n\r\n    to_entries[] | select(.value.result != &quot;success&quot;) | .key\r\n\r\nThis will yield the keys of the entries whose result is not &quot;success&quot;. With your supplied JSON, it will yield no results (because all the steps were successful).\r\n\r\nWith the following JSON:\r\n\r\n    {\r\n      &quot;affected-apps&quot;: {\r\n        &quot;result&quot;: &quot;success&quot;,\r\n        &quot;outputs&quot;: {\r\n          &quot;affected_apps_array&quot;: [\r\n            &quot;logger&quot;,\r\n            &quot;aws-sdk-wrapper&quot;,\r\n            &quot;transaction&quot;,\r\n            &quot;deposit&quot;,\r\n            &quot;identity&quot;,\r\n            &quot;user&quot;,\r\n            &quot;core&quot;\r\n          ]\r\n        }\r\n      },\r\n      &quot;build-affected-apps&quot;: {\r\n        &quot;result&quot;: &quot;success&quot;,\r\n        &quot;outputs&quot;: {}\r\n      },\r\n      &quot;load-affected-apps&quot;: {\r\n        &quot;result&quot;: &quot;failure&quot;,\r\n        &quot;outputs&quot;: {}\r\n      }\r\n    }\r\n\r\nit will yield:\r\n\r\n    &quot;load-affected-apps&quot;",
                "title": "How can I loop through a json object via `jq`?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1698026158,
        "creation_date": 1698017121,
        "last_edit_date": 1698026158,
        "question_id": 77342021,
        "body_markdown": "I have a json object which is not an array.\r\n\r\n```\r\n{\r\n  &quot;affected-apps&quot;: {\r\n    &quot;result&quot;: &quot;success&quot;,\r\n    &quot;outputs&quot;: {\r\n      &quot;affected_apps_array&quot;: [\r\n        &quot;logger&quot;,\r\n        &quot;aws-sdk-wrapper&quot;,\r\n        &quot;transaction&quot;,\r\n        &quot;deposit&quot;,\r\n        &quot;identity&quot;,\r\n        &quot;user&quot;,\r\n        &quot;core&quot;\r\n      ]\r\n    }\r\n  },\r\n  &quot;build-affected-apps&quot;: {\r\n    &quot;result&quot;: &quot;success&quot;,\r\n    &quot;outputs&quot;: {}\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d like to loop through the object to find any `result` is not equal to `success`. I have searched a lot but only found how to do that if the json is an array. But my json a an object. How can I loop through the object for each key?",
        "link": "https://stackoverflow.com/questions/77342021/how-can-i-loop-through-a-json-object-via-jq",
        "title": "How can I loop through a json object via `jq`?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698060647,
                "post_id": 77344181,
                "comment_id": 136353061,
                "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": 1698060659,
                "post_id": 77344181,
                "comment_id": 136353065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1698055274,
                "creation_date": 1698055274,
                "answer_id": 77344278,
                "question_id": 77344181,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think the array of cars should be defined as an object where each car is a key-value pair, or as an array of objects\r\n\r\nsomething like this\r\n\r\n    {\r\n      &quot;cars&quot;: {\r\n        &quot;ms-23-amw&quot;: {\r\n          &quot;brand&quot;: &quot;audi&quot;,\r\n          &quot;model&quot;: &quot;a8&quot;,\r\n          &quot;displayname&quot;: &quot;audi a8&quot;,\r\n          &quot;engine&quot;: &quot;4.5l&quot;\r\n        },\r\n        &quot;sj-08-rew&quot;: {\r\n          &quot;brand&quot;: &quot;bmw&quot;,\r\n          &quot;model&quot;: &quot;335i&quot;,\r\n          &quot;displayname&quot;: &quot;bmw 3 series&quot;,\r\n          &quot;engine&quot;: &quot;3.5l&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nand now use the `jq` to get the model for `ms-23-amw`:\r\n\r\n    jq &#39;.cars.&quot;ms-23-amw&quot;.model&#39; cars.json\r\n\r\noutput\r\n\r\n    &quot;a8&quot;",
                "title": "Can JQ work with numbers/lines as category?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1698081323,
        "creation_date": 1698054319,
        "last_edit_date": 1698081323,
        "question_id": 77344181,
        "body_markdown": "Let say I have the following JSON:\r\n```lang-json\r\n{\r\n  &quot;MS-23-AMW&quot;: {\r\n    &quot;brand&quot;: &quot;audi&quot;,\r\n    &quot;model&quot;: &quot;A8&quot;,\r\n    &quot;displayName&quot;: &quot;Audi A8&quot;,\r\n    &quot;engine&quot;: &quot;4.5L&quot;\r\n  },\r\n  &quot;SJ-08-REW&quot;: {\r\n    &quot;brand&quot;: &quot;bmw&quot;,\r\n    &quot;model&quot;: &quot;335i&quot;,\r\n    &quot;displayName&quot;: &quot;bmw 3 series&quot;,\r\n    &quot;engine&quot;: &quot;3.5L&quot;\r\n  }\r\n}\r\n```\r\n\r\nHow could I get the model lets say for `MS-23-AMV` with JQ?\r\n\r\nI tried `jq &quot;cars.MS-23-AMW&quot; cars.json` but i get `jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:`. Any ideas?",
        "link": "https://stackoverflow.com/questions/77344181/can-jq-work-with-numbers-lines-as-category",
        "title": "Can JQ work with numbers/lines as category?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1698083263,
                "last_edit_date": 1698083263,
                "creation_date": 1698082705,
                "answer_id": 77347276,
                "question_id": 77347258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You tried applying `@csv` to an array containing non-strings. You have to decompose them to get to the values.\r\n```sh\r\njq -r &#39;\r\n  .document.results.summary.run.[] | . as {$run_number}\r\n  | .cinfo[] | [$run_number, .name, .state, .city]\r\n  | @csv\r\n&#39; input.json\r\n```\r\n\r\nIf all goes well (I could have tested it if you had provided `input.json`), this should produce\r\n```csv\r\n&quot;42&quot;,&quot;Joe shmo&quot;,&quot;AZ&quot;,&quot;Phoenix&quot;\r\n&quot;42&quot;,&quot;Jane shmo&quot;,&quot;CA&quot;,&quot;Blythe&quot;\r\n&quot;84&quot;,&quot;Jake shmo&quot;,&quot;NY&quot;,&quot;Albany&quot;\r\n&quot;84&quot;,&quot;Jay shmo&quot;,&quot;TN&quot;,&quot;Franklin&quot;\r\n```",
                "title": "Use jq to transform JSON output to CSV complex structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698084733,
                "creation_date": 1698084733,
                "answer_id": 77347452,
                "question_id": 77347258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t have a valid JSON file in your code sample. Perhaps you meant to write this:\r\n\r\n    [\r\n      [\r\n        &quot;42&quot;,\r\n        [\r\n          {\r\n            &quot;name&quot;: &quot;Joe shmo&quot;,\r\n            &quot;state&quot;: &quot;AZ&quot;,\r\n            &quot;city&quot;: &quot;Phoenix&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Jane shmo&quot;,\r\n            &quot;state&quot;: &quot;CA&quot;,\r\n            &quot;city&quot;: &quot;Blythe&quot;\r\n          }\r\n        ]\r\n      ],\r\n      [\r\n        &quot;84&quot;,\r\n        [\r\n          {\r\n            &quot;name&quot;: &quot;Jake shmo&quot;,\r\n            &quot;state&quot;: &quot;NY&quot;,\r\n            &quot;city&quot;: &quot;Albany&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Jay shmo&quot;,\r\n            &quot;state&quot;: &quot;TN&quot;,\r\n            &quot;city&quot;: &quot;Franklin&quot;\r\n          }\r\n        ]\r\n      ]\r\n    ]\r\n\r\nIn this case, you can use the command:\r\n\r\n    jq -r &#39;.[] | .[0] as $run_number | .[1][] | [$run_number, .name, .state, .city] | @csv&#39; input.json\r\n\r\nand you will receive this result:\r\n\r\n    &quot;42&quot;,&quot;Joe shmo&quot;,&quot;AZ&quot;,&quot;Phoenix&quot;\r\n    &quot;42&quot;,&quot;Jane shmo&quot;,&quot;CA&quot;,&quot;Blythe&quot;\r\n    &quot;84&quot;,&quot;Jake shmo&quot;,&quot;NY&quot;,&quot;Albany&quot;\r\n    &quot;84&quot;,&quot;Jay shmo&quot;,&quot;TN&quot;,&quot;Franklin&quot;\r\n\r\n",
                "title": "Use jq to transform JSON output to CSV complex structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698281496,
                "creation_date": 1698281496,
                "answer_id": 77363561,
                "question_id": 77347258,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another approach would be to tag the following to the end of the `jq` filter you already have ([demo][1]):\r\n\r\n```\r\n| [ .[0] ] + (.[1] [] | [ .[] ]) | @csv\r\n```\r\n\r\nThe complete filter would be:\r\n\r\n```\r\n  .document.results.summary.run.[] \r\n| [.run_number, .cinfo] \r\n| [ .[0] ] + (.[1] [] | [ .[] ])\r\n| @csv\r\n```\r\n\r\nTo understand how it works, let&#39;s break it down to see what would happen to the first row produced by `[.run_number, .cinfo]`:\r\n\r\n- The `.[1] []` would first unpack the info array so it would produce two objects, i.e.,\r\n\r\n  ```\r\n  {&quot;name&quot;:&quot;Joe shmo&quot;,&quot;state&quot;:&quot;AZ&quot;,&quot;city&quot;:&quot;Phoenix&quot;}\r\n  {&quot;name&quot;:&quot;Jane shmo&quot;,&quot;state&quot;:&quot;CA&quot;,&quot;city&quot;:&quot;Blythe&quot;}\r\n  ```\r\n- These two objects are piped to `[ .[] ]` which would turn them into arrays as follows:\r\n\r\n  ```\r\n  [&quot;Joe shmo&quot;,&quot;AZ&quot;,&quot;Phoenix&quot;]\r\n  [&quot;Jane shmo&quot;,&quot;CA&quot;,&quot;Blythe&quot;]\r\n  ```\r\n\r\n- Now, when you add that to `[ .[0] ]` (which would be `[ &quot;42&quot; ]`), `jq` would do an array concat to both arrays in the stream, resulting in:\r\n\r\n  ```\r\n  [&quot;42&quot;,&quot;Joe shmo&quot;,&quot;AZ&quot;,&quot;Phoenix&quot;]\r\n  [&quot;42&quot;,&quot;Jane shmo&quot;,&quot;CA&quot;,&quot;Blythe&quot;]\r\n  ```\r\n- This gets passed into `@csv` filter producing the row we need.\r\n\r\nThe entire process repeats for the other `run` as well, and we have the desired output.\r\n\r\n[1]: https://jqplay.org/s/668P7sqEF96",
                "title": "Use jq to transform JSON output to CSV complex structure"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1698281496,
        "creation_date": 1698082460,
        "question_id": 77347258,
        "body_markdown": "I have an existing json file that I need to transform, but am having trouble with it.  \r\n\r\nHere&#39;s an example of the structure: \r\n\r\n```\r\n\r\njq -r &#39;.document.results.summary.run.[] | [.run_number, .cinfo] &#39; input.json\r\n\r\n[\r\n  &quot;42&quot;,\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;Joe shmo&quot;,\r\n      &quot;state&quot;: &quot;AZ&quot;,\r\n      &quot;city&quot;: &quot;Phoenix&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Jane shmo&quot;,\r\n      &quot;state&quot;: &quot;CA&quot;,\r\n      &quot;city&quot;: &quot;Blythe&quot;\r\n  ]\r\n]\r\n[\r\n  &quot;84&quot;,\r\n  [\r\n    {\r\n      &quot;name&quot;: &quot;Jake shmo&quot;,\r\n      &quot;state&quot;: &quot;NY&quot;,\r\n      &quot;city&quot;: &quot;Albany&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Jay shmo&quot;,\r\n      &quot;state&quot;: &quot;TN&quot;,\r\n      &quot;city&quot;: &quot;Franklin&quot;\r\n  ]\r\n]\r\n\r\nI need to convert this to a CSV to look like: \r\n&quot;run_number&quot;,&quot;cinfo.name&quot;,&quot;cinfo.state&quot;,&quot;cinfo.city&quot;\r\n\r\nExample: \r\n&quot;42&quot;,&quot;Joe shmo&quot;,&quot;AZ&quot;,&quot;Phoenix&quot;\r\n&quot;42&quot;,&quot;Jane shmo&quot;,&quot;CA&quot;,&quot;Blythe&quot;\r\n&quot;84&quot;,&quot;Jake shmo&quot;,&quot;NY&quot;,&quot;Albany&quot;\r\n&quot;84&quot;,&quot;Jay shmo&quot;,&quot;TN&quot;,&quot;Franklin&quot;\r\n\r\n```\r\n\r\n\r\n\r\n\r\nI tried to use | @csv I get: \r\n\r\n`jq: error (at input.json:1397): array ([{&quot;@name&quot;:&quot;...) is not valid in a csv row\r\n`\r\nI believe that this is because it is an array of multiple indexes. How can I transform the output using jq? ",
        "link": "https://stackoverflow.com/questions/77347258/use-jq-to-transform-json-output-to-csv-complex-structure",
        "title": "Use jq to transform JSON output to CSV complex structure"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1698085512,
                "creation_date": 1698085512,
                "answer_id": 77347520,
                "question_id": 77347441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` and JSON only support the ASCII double quotes, not the &quot;smart ones&quot;.\r\n\r\n```\r\n... | jq &#39;.ResourceTagMappingList[] | select(contains({Tags: [{Key: “CostCenter”} ]}) | not)&#39;\r\n... | jq &#39;.ResourceTagMappingList[] | select(contains({Tags: [{Key: &quot;CostCenter&quot;} ]}) | not)&#39;\r\n#                                                                   ~          ~",
                "title": "jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1698085512,
        "creation_date": 1698084647,
        "question_id": 77347441,
        "body_markdown": "I am making an API call to AWS and getting the output in the following format : \r\n\r\n    {\r\n        &quot;ResourceTagMappingList&quot;: [\r\n            {\r\n                &quot;ResourceARN&quot;: &quot;&lt;arn&gt;&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;CostCenter&quot;,\r\n                        &quot;Value&quot;: &quot;&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Region&quot;,\r\n                        &quot;Value&quot;: &quot;us-west-2&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Team&quot;,\r\n                        &quot;Value&quot;: &quot;SRE&quot;\r\n                    }\r\n                ]\r\n    {\r\n        &quot;ResourceTagMappingList&quot;: [\r\n            {\r\n                &quot;ResourceARN&quot;: &quot;&lt;arn&gt;&quot;,\r\n                &quot;Tags&quot;: [\r\n                    {\r\n                        &quot;Key&quot;: &quot;CostCenter&quot;,\r\n                        &quot;Value&quot;: &quot;Development&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Region&quot;,\r\n                        &quot;Value&quot;: &quot;us-west-2&quot;\r\n                    },\r\n                    {\r\n                        &quot;Key&quot;: &quot;Team&quot;,\r\n                        &quot;Value&quot;: &quot;Architects&quot;\r\n                    }\r\n                ]\r\n            }, and so on\r\n\r\nand i am trying to get the entire `ResourceTagMappingList` for when `Costcenter` is untagged. and i ran the jq query for this : \r\n\r\n    aws resourcegroupstaggingapi get-resources --tags-per-page 100 | jq &#39;.ResourceTagMappingList[] | select(contains({Tags: [{Key: “CostCenter”} ]}) | not)&#39;\r\n\r\nBut i keep running into the following : \r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .ResourceTagMappingList[] | select(contains({Tags: [{Key: “CostCenter”} ]}) | not)                                                          \r\n    jq: 1 compile error\r\n    Exception ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;utf-8&#39;&gt;\r\n    BrokenPipeError: [Errno 32] Broken pipe\r\n    [2]    exit 120   aws resourcegroupstaggingapi get-resources --tags-per-page 100 --tag-filters | \r\n           exit 1     jq .ResourceTagMappingList[]\r\n    Exception ignored in: &lt;_io.TextIOWrapper name=&#39;&lt;stdout&gt;&#39; mode=&#39;w&#39; encoding=&#39;utf-8&#39;&gt;\r\n    BrokenPipeError: [Errno 32] Broken pipe\r\n\r\n\r\nI&#39;m not sure what i&#39;m doing wrong here. any help will be appreciated. Thank you. I am on Mac and using CLI version `aws-cli/2.13.25`\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77347441/jq-error-syntax-error-unexpected-invalid-character-unix-shell-quoting-issues",
        "title": "jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1698090314,
        "creation_date": 1698090314,
        "question_id": 77347936,
        "body_markdown": "I have a JSON file and it has data like this,\r\n\r\n```\r\n{  \r\n  &quot;key&quot;: &quot;SEA-739&quot;,\r\n  &quot;status&quot;: &quot;Open&quot;,\r\n  &quot;assignee&quot;: null\r\n}\r\n{\r\n  &quot;key&quot;: &quot;SEA-738&quot;,\r\n  &quot;status&quot;: &quot;Resolved&quot;,\r\n  &quot;assignee&quot;: &quot;user2@mycompany.com&quot;\r\n}\r\n```\r\n\r\nFrom the above file, I need to extract only one JSON stanza that I intend to evaluate/test. Expected output,\r\n\r\n```\r\n{  \r\n  &quot;key&quot;: &quot;SEA-739&quot;,\r\n  &quot;status&quot;: &quot;Open&quot;,\r\n  &quot;assignee&quot;: null\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/77347936/how-do-i-print-one-json-stanza-from-a-json-file-in-the-linux-terminal",
        "title": "How do I print one JSON stanza from a JSON file in the linux terminal"
    },
    {
        "tags": [
            "select",
            "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": 1698147790,
                "post_id": 77351746,
                "comment_id": 136365748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698147875,
                "post_id": 77351746,
                "comment_id": 136365767,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 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": 2,
                "creation_date": 1698150285,
                "post_id": 77351746,
                "comment_id": 136366176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1698166785,
                "last_edit_date": 1698166785,
                "creation_date": 1698148543,
                "answer_id": 77351853,
                "question_id": 77351746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There&#39;s a common misconception that `select` would descend into the input structure, then &quot;select from&quot; those subordinate items the ones matching a condition, and return them. This notion probably comes from the function&#39;s name, for which &quot;filter&quot; or &quot;asserting&quot; could have been a better choice, because the structures involved in the evaluation of the condition, and the ones returned if the condition was met, are actually in no way related. In fact, while the former may descend arbitrarily deep (including not at all, or using variables with &quot;external&quot; values), the latter is always either the entire, unaltered input (if the condition was met), or nothing (in the sense of no output at all, just like with `empty`). Moreover, if the condition (just like with the input context) is a stream of values, the output, if produced, is still the input value but accordingly multiplied into a stream of values as well (actually, the single-value case is no exception to that, if you consider it being a stream of just one value). That said, let&#39;s answer your questions:\r\n\r\n&gt; 1. why `select(.project[].name |contains(&quot;ma&quot;))|.name` doesn&#39;t work ? what is the wrong understanding behind that usage ?\r\n\r\nStarting with the top-level as the current context, `select` will either reproduce it, or have no output at all, depending on the boolean evaluation of the condition. Then, at `|`, output that is present becomes the new (yet same) context, and is taken as input for `.name`, which either produces the value of that field, or `null` if there was no field of that name, or an error if the input was neither an object nor `null` itself.\r\n\r\nGiven your sample data, the object `{&quot;project&quot;: …}`, as context, `.project[].name | contains(&quot;ma&quot;)` produces `true` exactly once, so `select` reproduces its input, also once. However, as this object does not have a field called `name`, `.name` produces `null`, also once.\r\n\r\nAs an exercise, try changing either the string values present in the fields, or the substring searched for, so that more than one item matches, and you will get as many `null` outputs - and likewise no output if there is no match.\r\n\r\nNow, instead of trying to extract `.name` from there, you could, of course, descend again to its actual location, but at this point you have lost the instances that conveyed where the condition was met. With your successful approach, `.project[] | select( .name |contains(&quot;ma&quot;)) |.name`, you\r\n- `.project[]`: descended into the array items, producing a stream of (in this case: four) objects as the new contexts,\r\n- `select( .name |contains(&quot;ma&quot;))`: reproduced the same objects if and only if their `name` field&#39;s value contained the substring given (here: one object makes it)\r\n- `.name`: extract the desired value in the right context.\r\n\r\nTo avoid code duplication, you could even pull the extraction of `.name` out of, i.e. before the condition, making it already the context for `select` and the final output:\r\n\r\n```sh\r\njq -r &#39;.project[].name | select(contains(&quot;ma&quot;))&#39;\r\n```\r\n```\r\ndungeon master\r\n```\r\n[Demo](https://jqplay.org/s/vdwmhyGdZ05)\r\n\r\n---\r\n\r\n&gt; 2. what is the different concept between `.array[].key` and `.array[] | .key` is wrong that cause the above not working ?\r\n\r\nAs described above, `|` changes the context. If you had `.array[].key1, .key2`, `.key2` would be evaluated in the same context as `.array[].key1`. With `.array[] | .key1, .key2`, both keys are evaluated in the same context of `.array[]` (which is a stream of probably multiple items).\r\n",
                "title": "How to use &#39;select&#39; properly in jq?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1698166889,
                "last_edit_date": 1698166889,
                "creation_date": 1698166534,
                "answer_id": 77354022,
                "question_id": 77351746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`select` either lets through a value, or filters it out. But it does not change the value in any way.\r\n\r\n---\r\n\r\n```jq\r\n{ &quot;project&quot;: [ {…},{…},{…},{…} ] } | select( .project[].name | contains( &quot;ma&quot; ) )\r\n```\r\n\r\nOnly one value is passed to `select`: `{ &quot;project&quot; : [ ... ] }`. It will either return this value or return nothing. This isn&#39;t what you want. You don&#39;t want the entire structure, but a single project. So this is wrong no matter what&#39;s inside the `select`.\r\n\r\n---\r\n\r\n```jq\r\n{ &quot;project&quot;: [ {…},{…},{…},{…} ] } | .project[] | select( .name | contains( &quot;ma&quot; ) )\r\n```\r\n\r\n`select` is called four times, one for each of the projects (`{…}`). Each time, it will either return the project, or nothing. So you&#39;ll end up with zero to four projects. This is what you want.\r\n\r\n---\r\n\r\nThink of `select` as the `grep` command line utility.\r\n\r\n```none\r\n$ cat file\r\nfoo\r\nbar\r\nbaz\r\n\r\n$ grep a file\r\nbar\r\nbaz\r\n\r\n$ cat file.json\r\n&quot;foo&quot;\r\n&quot;bar&quot;\r\n&quot;baz&quot;\r\n\r\n$ jq &#39;select( contains( &quot;a&quot; ) )&#39; file.json\r\n&quot;bar&quot;\r\n&quot;baz&quot;\r\n\r\n$ cat file2.json\r\n[ &quot;foo&quot;, &quot;bar&quot;, &quot;baz&quot; ]\r\n\r\n$ jq &#39;.[] | select( contains( &quot;a&quot; ) )&#39; file2.json\r\n&quot;bar&quot;\r\n&quot;baz&quot;\r\n```\r\n\r\n`select` simply works with values instead of lines.\r\n",
                "title": "How to use &#39;select&#39; properly in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1698198966,
        "creation_date": 1698147620,
        "last_edit_date": 1698198966,
        "question_id": 77351746,
        "body_markdown": "Given a json like this:\r\n\r\n\r\n    {\r\n    \r\n        &quot;project&quot; : [\r\n            {\r\n                &quot;name&quot; : &quot;dungeon master&quot;,\r\n                &quot;date&quot; : &quot;2022-05-11T16:07:29.000Z&quot;,\r\n                &quot;status&quot; : &quot;active&quot;\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;great gatsby&quot;,\r\n                &quot;date&quot; : &quot;2023-04-20T19:49:26.000Z&quot;,\r\n                &quot;status&quot; : &quot;active&quot;\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;hundred years&quot;,\r\n                &quot;date&quot; : &quot;2022-11-29T23:37:29.000Z&quot;,\r\n                &quot;status&quot; : &quot;active&quot;\r\n            },\r\n            {\r\n                &quot;name&quot; : &quot;passage to india&quot;,\r\n                &quot;date&quot; : &quot;2022-11-22T04:16:50.000Z&quot;,\r\n                &quot;status&quot; : &quot;active&quot;\r\n            }      \r\n       \r\n        ]\r\n    }\r\n\r\n\r\nto get the key **&#39;name&#39;** that has the string **&#39;ma&#39;**, I build up the jq using this chain of thought step by step:\r\n\r\n    .project[] | .name |contains(&quot;ma&quot;)\r\n    &gt;&gt;true\r\n    false\r\n    false\r\n    false\r\n\r\n    .project[] | select( .name |contains(&quot;ma&quot;))\r\n    &gt;&gt;{\r\n      &quot;name&quot;: &quot;dungeon master&quot;,\r\n      &quot;date&quot;: &quot;2022-05-11T16:07:29.000Z&quot;,\r\n      &quot;status&quot;: &quot;active&quot;\r\n    }\r\n\r\n    .project[] | select( .name |contains(&quot;ma&quot;)) |.name\r\n    &gt;&gt; &quot;dungeon master&quot;\r\n    #success\r\n\r\nbut if I use the abbreviation way, it doesn&#39;t work:\r\n\r\n    .project[].name |contains(&quot;ma&quot;)\r\n    &gt;&gt;true\r\n    false\r\n    false\r\n    false\r\n    \r\n    select(.project[].name |contains(&quot;ma&quot;))\r\n    &gt;&gt;get back whole json \r\n    \r\n    select(.project[].name |contains(&quot;ma&quot;))|.name \r\n    &gt;&gt; null \r\n\r\nUsing **&#39;select&#39;** on the abbreviation **&#39;.array[].key&#39;** seems having totally different output. I think I missed some important understanding about jq here.  \r\n  \r\nMy questions:\r\n\r\n 1. why ```select(.project[].name |contains(&quot;ma&quot;))|.name``` doesn&#39;t work ? what is the wrong understanding behind that usage ?\r\n 2. what is the different concept between ```.array[].key``` and ```.array[] | .key``` is wrong that cause the above not working ?",
        "link": "https://stackoverflow.com/questions/77351746/how-to-use-select-properly-in-jq",
        "title": "How to use &#39;select&#39; properly in jq?"
    },
    {
        "tags": [
            "json",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1698229432,
                "creation_date": 1698229432,
                "answer_id": 77358669,
                "question_id": 77358545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way would be to combine string interpolation by writing the filter inside the `&quot;..&quot;`\r\n\r\n```\r\njq --raw-output \r\n  &#39;&quot;\\(.name): \\( .snapshots | map(select(.name != &quot;current&quot;)) | length )&quot;&#39;\r\n```\r\n\r\ndemo - [jqplay][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/jjhspVblxVM",
                "title": "How to get number of elements in json using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698259922,
                "creation_date": 1698259922,
                "answer_id": 77362198,
                "question_id": 77358545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may find it useful to define a count function and use that. Using `reduce` can make it a little quicker too for larger inputs.\r\n\r\n```\r\ndef count(f): reduce (.[] | f) as $i (0; if $i then . + 1 end);\r\n&quot;\\(.name): \\(.snapshots | count(.name != &quot;current&quot;))&quot;\r\n```",
                "title": "How to get number of elements in json using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698263625,
                "creation_date": 1698263625,
                "answer_id": 77362535,
                "question_id": 77358545,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "... or use the generic stream-oriented `count/1` function:\r\n```\r\ndef count(s): reduce s as $_ (0; .+1);\r\n\r\n&quot;\\(.name): \\(count(.snapshots[] | select(.name != &quot;current&quot;)))&quot;\r\n```",
                "title": "How to get number of elements in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1698266723,
        "creation_date": 1698228569,
        "last_edit_date": 1698266723,
        "question_id": 77358545,
        "body_markdown": "I&#39;d like to get the count of elements in an json array using jq (without the elements with &quot;name&quot;: &quot;current&quot; in the snapshots array).\r\n\r\n```\r\n{\r\n  &quot;name&quot;: &quot;test1&quot;,\r\n  &quot;snapshots&quot;: [\r\n    {\r\n      &quot;description&quot;: &quot;You are here!&quot;,\r\n      &quot;name&quot;: &quot;current&quot;,\r\n      &quot;digest&quot;: &quot;ccc&quot;,\r\n      &quot;running&quot;: 1\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;You are here!&quot;,\r\n      &quot;name&quot;: &quot;snap1&quot;,\r\n      &quot;digest&quot;: &quot;ddd&quot;,\r\n      &quot;running&quot;: 1\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;test2&quot;,\r\n  &quot;snapshots&quot;: [\r\n    {\r\n      &quot;digest&quot;: &quot;bbb&quot;,\r\n      &quot;description&quot;: &quot;You are here!&quot;,\r\n      &quot;name&quot;: &quot;current&quot;,\r\n      &quot;running&quot;: 1\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;You are here!&quot;,\r\n      &quot;name&quot;: &quot;snap1&quot;,\r\n      &quot;digest&quot;: &quot;aaa&quot;,\r\n      &quot;running&quot;: 1\r\n    },\r\n    {\r\n      &quot;description&quot;: &quot;You are here!&quot;,\r\n      &quot;name&quot;: &quot;snap2&quot;,\r\n      &quot;digest&quot;: &quot;abc&quot;,\r\n      &quot;running&quot;: 1\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThis is the result I&#39;m looking for (excluding the entries with &quot;name: &quot;current&quot; in the snapshots array):\r\n\r\n```\r\ntest1: 1\r\ntest2: 2\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77358545/how-to-get-number-of-elements-in-json-using-jq",
        "title": "How to get number of elements in json using jq"
    },
    {
        "tags": [
            "bash",
            "date",
            "sh",
            "jq",
            "iso8601"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1698269333,
                "post_id": 77362948,
                "comment_id": 136385536,
                "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": 1698269426,
                "post_id": 77362948,
                "comment_id": 136385544,
                "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": 1698270038,
                "post_id": 77362948,
                "comment_id": 136385640,
                "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": 1698283038,
                "post_id": 77362948,
                "comment_id": 136386790,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698269516,
                "last_edit_date": 1698269516,
                "creation_date": 1698269478,
                "answer_id": 77362994,
                "question_id": 77362948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you&#39;re using a Linux based operating system, the [GNU `date`][1] command can format times and understands timestamps given in ISO-8601 format:\r\n\r\n```sh\r\n$ date -d &quot;$released_at&quot; +&quot;%A, %B %d, %Y&quot;\r\nWednesday, September 27, 2023\r\n```\r\n\r\n\r\n  [1]: https://man7.org/linux/man-pages/man1/date.1.html",
                "title": "Format date time using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1698275493,
                "last_edit_date": 1698275493,
                "creation_date": 1698270192,
                "answer_id": 77363059,
                "question_id": 77362948,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq provides access to your local operating system&#39;s `strftime` and `strptime` functions. (Note that one needs to be careful about portability when using these: Some libc implementations provide more operators than POSIX guarantees).\r\n\r\n```bash\r\njq &#39;\r\n  .[0].released_at |                # extract field\r\n  split(&quot;.&quot;)[0] |                  # strip seconds (not portably parsable)\r\n  strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) |  # parse with strptime\r\n  strftime(&quot;%A, %B, %Y&quot;)           # format with strftime\r\n&#39; &lt;&lt;&#39;EOF&#39;\r\n[\r\n  {&quot;released_at&quot;: &quot;2023-09-27T17:36:07.182Z&quot;}\r\n]\r\nEOF\r\n```\r\n\r\n...emits as output:\r\n\r\n```json\r\n&quot;Wednesday, September, 2023&quot;\r\n```",
                "title": "Format date time using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1698275493,
        "creation_date": 1698268665,
        "question_id": 77362948,
        "body_markdown": "I have a bash (sh) script that makes several API calls and returns string values.\r\nOne of them is a &#39;created_at&#39; attribute of the JSON object returned.\r\n\r\n`released_at=$(echo -E &quot;${json_response}&quot; | jq -r &#39;.[0].released_at&#39;&quot;)`\r\n\r\nValue returned in ISO 8601 format: `&quot;released_at&quot;: &quot;2023-09-27T17:36:07.182Z&quot;`\r\n\r\nI would like it to be displayed as `Wednesday, September 27, 2023`\r\n\r\nWhat would be the shortest way to achieve that?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/77362948/format-date-time-using-jq",
        "title": "Format date time using jq"
    },
    {
        "tags": [
            "json",
            "sorting",
            "datetime",
            "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": 1698321351,
                "post_id": 77366770,
                "comment_id": 136392135,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20920312,
                    "reputation": 31,
                    "user_id": 15369090,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/05963edf1c1e4c920518a379754b4535?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LostHat",
                    "link": "https://stackoverflow.com/users/15369090/losthat"
                },
                "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": 1698321688,
                "post_id": 77366770,
                "comment_id": 136392215,
                "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": 1698321862,
                "post_id": 77366770,
                "comment_id": 136392247,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20920312,
                    "reputation": 31,
                    "user_id": 15369090,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/05963edf1c1e4c920518a379754b4535?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "LostHat",
                    "link": "https://stackoverflow.com/users/15369090/losthat"
                },
                "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": 1698322169,
                "post_id": 77366770,
                "comment_id": 136392318,
                "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": 1698323305,
                "post_id": 77366770,
                "comment_id": 136392575,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698322988,
                "creation_date": 1698322988,
                "answer_id": 77366978,
                "question_id": 77366770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This worked out:\r\n\r\n    jq -s &#39;.[0].items |= sort_by(.assets[0].lastModified) | .[0].items&#39;",
                "title": "How to sort json based on date with jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1698322988,
        "creation_date": 1698321189,
        "last_edit_date": 1698321603,
        "question_id": 77366770,
        "body_markdown": "How can I sort this json output based on the &quot;lastModified&quot; value? I&#39;ve tried on looking at other topics, but can&#39;t make it work with jq. This example is just one entry of many.\r\n\r\nI&#39;ve tried `jq -s &#39;.[].items |= sort_by(.lastModified)&#39;` but that&#39;s not working.\r\n\r\nEach item in .items array should be sorted by date based on the &quot;lastModified&quot; value, so that in the output they would be listed from oldest to newest.\r\n\r\n    [\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;Y29tbW9KJHDGGViZjdihjdfgJDHF72Q2NNlNTE4MQ&quot;,\r\n          &quot;repository&quot;: &quot;files&quot;,\r\n          &quot;format&quot;: &quot;raw&quot;,\r\n          &quot;group&quot;: &quot;/artifactory&quot;,\r\n          &quot;name&quot;: &quot;artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm&quot;,\r\n          &quot;version&quot;: null,\r\n          &quot;assets&quot;: [\r\n            {\r\n              &quot;downloadUrl&quot;: &quot;https://nexusrepo.com/repository/files/artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm&quot;,\r\n              &quot;path&quot;: &quot;artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm&quot;,\r\n              &quot;id&quot;: &quot;MKUKYTGkNTEFYGidfUDFWQ4Mw&quot;,\r\n              &quot;repository&quot;: &quot;files&quot;,\r\n              &quot;format&quot;: &quot;raw&quot;,\r\n              &quot;checksum&quot;: {\r\n                &quot;sha1&quot;: &quot;f7ff96bc6c0cc6ca6163a61635b&quot;,\r\n                &quot;sha256&quot;: &quot;97c152220522a2b91032f3a884313a88431a4371a4ef22e2e517cb3b&quot;,\r\n                &quot;sha512&quot;: &quot;52d225b9d3a35ef800b556e20067452c7b225b9d3a35ef80066173850c24bd4&quot;,\r\n                &quot;md5&quot;: &quot;63044d747d7e5b0c59436&quot;\r\n              },\r\n              &quot;contentType&quot;: &quot;application/x-rpm&quot;,\r\n              &quot;lastModified&quot;: &quot;2023-10-18T12:59:48.331+00:00&quot;,\r\n              &quot;lastDownloaded&quot;: &quot;2023-10-26T09:34:14.859+00:00&quot;,\r\n              &quot;uploader&quot;: &quot;user&quot;,\r\n              &quot;uploaderIp&quot;: &quot;10.30.55.12&quot;,\r\n              &quot;fileSize&quot;: 1273649726,\r\n              &quot;blobCreated&quot;: null\r\n            }\r\n          ]\r\n        }\r\n      ],\r\n      &quot;continuationToken&quot;: null\r\n    }\r\n  ]\r\n  ",
        "link": "https://stackoverflow.com/questions/77366770/how-to-sort-json-based-on-date-with-jq",
        "title": "How to sort json based on date with jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698322634,
                "post_id": 77366859,
                "comment_id": 136392433,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1698322585,
                "last_edit_date": 1698322585,
                "creation_date": 1698322439,
                "answer_id": 77366900,
                "question_id": 77366859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `--stream` option to produce a stream of path-value arrays. Filter for those where a value is present, `join` the path (the `first` item), and add the value (the `last` item). I used `@json` for the encoding (quotes around strings) as you didn&#39;t specify otherwise.\r\n```sh\r\njq -r --stream &#39;select(has(1)) | &quot;.\\(first | join(&quot;.&quot;)) = \\(last | @json)&quot;&#39;\r\n```\r\n```\r\n.user.name = &quot;Matias&quot;\r\n.user.age = 12\r\n.role.it.developer = true\r\n.role.it.designer = false\r\n```\r\n\r\nNote: you didn&#39;t specify what should happen with array items. This will simply use their indices instead of field names.",
                "title": "How to print path and key values of JSON file with jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698388051,
                "creation_date": 1698388051,
                "answer_id": 77371920,
                "question_id": 77366859,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get all the leaf nodes, and emit the path and value for each node ([demo][1]):\r\n\r\n```\r\npaths(scalars | true) as $p | &quot;\\(&quot;.&quot; + ($p | join(&quot;.&quot;))) = \\(getpath($p) | @json)&quot;\r\n```\r\n\r\n[1]:https://jqplay.org/s/xMzRtwmwkbE",
                "title": "How to print path and key values of JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1698388051,
        "creation_date": 1698322026,
        "last_edit_date": 1698323003,
        "question_id": 77366859,
        "body_markdown": "I have a JSON with a lot of nested properties. Something like this:\r\n\r\n```\r\n{\r\n  &quot;user&quot;: {\r\n    &quot;name&quot;: &quot;Matias&quot;,\r\n    &quot;age&quot;: 12,\r\n  },\r\n  &quot;role&quot;: {\r\n    &quot;it&quot;: {\r\n      &quot;developer&quot;: true,\r\n      &quot;designer&quot;: false\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nAnd so on. I am trying to create a list of this json with each property in a single line with its &quot;path&quot; separated with dots. Something like this:\r\n\r\n```\r\n.user.name = &quot;Matias&quot;\r\n.user.age = 12\r\n.role.it.developer = true\r\n.role.it.designer = false\r\n```\r\n\r\nI know I can use &quot;..&quot; and &quot;to_entries&quot; to recursively go through the object and to convert each node to key/value, but I can not figure out how to combine them in a way where the output is exactly what I want.",
        "link": "https://stackoverflow.com/questions/77366859/how-to-print-path-and-key-values-of-json-file-with-jq",
        "title": "How to print path and key values of JSON file with jq"
    },
    {
        "tags": [
            "nested",
            "duplicates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698347712,
                "last_edit_date": 1698347712,
                "creation_date": 1698346240,
                "answer_id": 77369649,
                "question_id": 77369574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; In my example I want to delete .[0] because all three values of q1 are the same (&quot;all_answers&quot; : [ &quot;a&quot;, &quot;a&quot;, &quot;a&quot; ]). There should be at least one different &quot;answer&quot; like [ &quot;a&quot;, &quot;b&quot;, &quot;b&quot; ] for it to stay\r\n\r\nIf you want that there is at least one pair of items with different values, then check if the length of the `unique` array is greater than `1`:\r\n\r\n```sh\r\n.[] |= select(.ratings.q1.all_answers | unique | length &gt; 1)\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;ratings&quot;: {\r\n      &quot;q1&quot;: {\r\n        &quot;all_answers&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;b&quot;\r\n        ],\r\n        &quot;top_answer&quot;: &quot;a&quot;\r\n      },\r\n      &quot;q2&quot;: {\r\n        &quot;all_answers&quot;: [\r\n          &quot;no&quot;,\r\n          &quot;yes&quot;,\r\n          &quot;yes&quot;\r\n        ],\r\n        &quot;top_answer&quot;: &quot;yes&quot;\r\n      }\r\n    }\r\n  },\r\n  {\r\n    &quot;ratings&quot;: {\r\n      &quot;q1&quot;: {\r\n        &quot;all_answers&quot;: [\r\n          &quot;a&quot;,\r\n          &quot;b&quot;,\r\n          &quot;c&quot;\r\n        ],\r\n        &quot;top_answer&quot;: &quot;a&quot;\r\n      },\r\n      &quot;q2&quot;: {\r\n        &quot;all_answers&quot;: [\r\n          &quot;no&quot;,\r\n          &quot;yes&quot;,\r\n          &quot;yes&quot;\r\n        ],\r\n        &quot;top_answer&quot;: &quot;yes&quot;\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/_6MPi3gk3AX)",
                "title": "JQ: Delete JSON object with duplicates in nested array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1698347712,
        "creation_date": 1698345327,
        "question_id": 77369574,
        "body_markdown": "I have the following JSON:\r\n\r\n```\r\n[\r\n{\r\n  &quot;ratings&quot; : {\r\n    &quot;q1&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;a&quot;, &quot;a&quot;, &quot;a&quot; ],\r\n      &quot;top_answer&quot; : &quot;a&quot;\r\n    },\r\n    &quot;q2&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;no&quot;, &quot;yes&quot;, &quot;yes&quot; ],\r\n      &quot;top_answer&quot; : &quot;yes&quot;\r\n    }\r\n},\r\n{\r\n  &quot;ratings&quot; : {\r\n    &quot;q1&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;a&quot;, &quot;b&quot;, &quot;b&quot; ],\r\n      &quot;top_answer&quot; : &quot;a&quot;\r\n    },\r\n    &quot;q2&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;no&quot;, &quot;yes&quot;, &quot;yes&quot; ],\r\n      &quot;top_answer&quot; : &quot;yes&quot;\r\n    }\r\n},\r\n{\r\n  &quot;ratings&quot; : {\r\n    &quot;q1&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;a&quot;, &quot;b&quot;, &quot;c&quot; ],\r\n      &quot;top_answer&quot; : &quot;a&quot;\r\n    },\r\n    &quot;q2&quot; : {\r\n      &quot;all_answers&quot; : [ &quot;no&quot;, &quot;yes&quot;, &quot;yes&quot; ],\r\n      &quot;top_answer&quot; : &quot;yes&quot;\r\n    }\r\n},\r\n{\r\n...\r\n}\r\n]\r\n```\r\n\r\nI am attempting to create a jq script that can identify, if the array &quot;all_answers&quot; in q1 has duplicate entries and delete the entire object. In the end I want to only keep entries in the top level array .[] that have at least one divergent entry in .ratings.q1.all_answers.\r\n\r\nMy approach was to calculates the length of the array after removing duplicates and than compare it to the original length.\r\n\r\n`jq &#39;.[] |= select(.ratings.q1.all_answers | length as $len | $len &gt; ($len - (. | unique | length)))&#39;`\r\n\r\nI don&#39;t get an error executing this but it does not seem to have any effect on the json. Can someone help me with this?",
        "link": "https://stackoverflow.com/questions/77369574/jq-delete-json-object-with-duplicates-in-nested-array",
        "title": "JQ: Delete JSON object with duplicates in nested array"
    },
    {
        "tags": [
            "json",
            "jq",
            "csvtoarray"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1698379372,
                "last_edit_date": 1698379372,
                "creation_date": 1698363872,
                "answer_id": 77370806,
                "question_id": 77370739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the [`/`](https://jqlang.github.io/jq/manual/v1.7/#multiplication-division-modulo) operator, which splits the first string using the second as a separator, like so:\r\n\r\n```lang-sh\r\njq -cR &#39;./&quot;,&quot;&#39; &lt;&lt;&lt; &#39;ABC,123,XYZ,A&quot;B,{1}&#39;\r\n```\r\n\r\n```lang-json\r\n[&quot;ABC&quot;,&quot;123&quot;,&quot;XYZ&quot;,&quot;A\\&quot;B&quot;,&quot;{1}&quot;]\r\n```\r\n\r\nOr equivalently, using the [`split`](https://jqlang.github.io/jq/manual/v1.7/#split-1) function:\r\n\r\n```lang-sh\r\njq -cR &#39;split(&quot;,&quot;)&#39; &lt;&lt;&lt; &#39;ABC,123,XYZ,A&quot;B,{1}&#39;\r\n```\r\n\r\nIf you want to use a regex to help with the splitting, consider this example that trims spaces around the commas:\r\n\r\n```lang-sh\r\njq -cR &#39;[splits(&quot; *, *&quot;)]&#39; &lt;&lt;&lt; &#39;ABC, 123, XYZ, A&quot;B, {1}&#39;\r\n```\r\n",
                "title": "Can I transform a delimited string to a JSON array using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698380593,
                "creation_date": 1698380593,
                "answer_id": 77371485,
                "question_id": 77370739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you change the delimiter to a newline, you can use the `-s` option so that `jq` reads the entire input as if it were a JSON array. Notice the following examples:\r\n\r\n```\r\n&#167; echo $&#39;1\\n2\\n3&#39; | jq -s\r\n[\r\n  1,\r\n  2,\r\n  3\r\n]\r\n```\r\n\r\n```\r\n&#167; echo $&#39;1\\n2\\n3&#39; | jq -s &#39;length&#39;\r\n3\r\n```",
                "title": "Can I transform a delimited string to a JSON array using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1698384333,
        "creation_date": 1698362090,
        "last_edit_date": 1698384333,
        "question_id": 77370739,
        "body_markdown": "I&#39;m writing a script that receives a delimited list of non-jSON data `jq`.  My goal is to transform that list to a JSON array.  The actual data is delimited with commas, but I could easily translate that to delimit by spaces or newlines, if that makes the problem easier.\r\n\r\nI obviously can&#39;t pass this directly to `jq` since it&#39;s not JSON formatted data.\r\n\r\n```lang-none\r\n$ echo &quot;A,B,C&quot; | jq\r\njq: parse error: Invalid numeric literal at line 1, column 2\r\n```\r\n\r\nDoes `jq` have a way to translate delimited non-JSON data into a JSON array?\r\n\r\n# Example\r\n\r\n## Input\r\n\r\n```lang-none\r\nABC,123,XYZ,A&quot;B,{1}\r\n```\r\n\r\n## Output\r\n\r\n```lang-json\r\n[&quot;ABC&quot;, &quot;123&quot;, &quot;XYZ&quot;, &quot;A\\&quot;B&quot;, &quot;{1}&quot;]\r\n```\r\n\r\nHow can I achieve this using `jq`?",
        "link": "https://stackoverflow.com/questions/77370739/can-i-transform-a-delimited-string-to-a-json-array-using-jq",
        "title": "Can I transform a delimited string to a JSON array using jq?"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4133101,
                    "reputation": 26568,
                    "user_id": 3390419,
                    "user_type": "registered",
                    "accept_rate": 30,
                    "profile_image": "https://www.gravatar.com/avatar/895c1539b3062a1feadfad9d1d80e8e9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paolo",
                    "link": "https://stackoverflow.com/users/3390419/paolo"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1698394614,
                "post_id": 77372497,
                "comment_id": 136402541,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1698394740,
                "creation_date": 1698394740,
                "answer_id": 77372538,
                "question_id": 77372497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `paths` to find the paths with matching values, extract from it the first two items (`[&quot;auditLogs&quot;,0]` in this case), use `getpath` to retrieve that object, and extract `.logId` from there:\r\n```sh\r\njq -r &#39;getpath(paths(. == &quot;CREDENTIALS_VAULT-1212121212121&quot;)[:2]).logId&#39;\r\n```\r\n```\r\n169807591200060002\r\n```\r\n[Demo](https://jqplay.org/s/c1VCzL86bMg)\r\n\r\nIf you want objects containing only the `logId` field, use `{logId}` instead:\r\n```sh\r\njq &#39;getpath(paths(. == &quot;CREDENTIALS_VAULT-1212121212121&quot;)[:2]) | {logId}&#39;\r\n```\r\n```json\r\n{\r\n  &quot;logId&quot;: &quot;169807591200060002&quot;\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/jBDVPurmrc3)\r\n\r\nYou can also consider collecting the results in an array by wrapping `[…]` around the filter. Or use the `--arg` option to import the search key from the command line, etc.",
                "title": "jq - search a string value at any level of a json file and get the parent keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698398865,
                "last_edit_date": 1698398865,
                "creation_date": 1698395144,
                "answer_id": 77372577,
                "question_id": 77372497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use [`IN`](https://jqlang.github.io/jq/manual/#sql-style-operators) (or `any(stream; condition)`):\r\n\r\n```\r\n.auditLogs[]\r\n| select(IN(.. | .credentialId?; &quot;CREDENTIALS_VAULT-1212121212121&quot;))\r\n| .logId\r\n```\r\n\r\nor, depending on your output format requirements:\r\n\r\n```\r\n.auditLogs[]\r\n| select(IN(.. | .credentialId?; &quot;CREDENTIALS_VAULT-1212121212121&quot;))\r\n| { logId }\r\n```",
                "title": "jq - search a string value at any level of a json file and get the parent keys"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698431644,
                "last_edit_date": 1698431644,
                "creation_date": 1698431028,
                "answer_id": 77376345,
                "question_id": 77372497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ... without worrying about the key \r\n\r\n&gt; ... I don&#39;t know in advance the exact tree\r\n\r\nHere&#39;s a straightforward approach that meets both these requirements (and I&#39;d hazard is faster than using `paths` and `getpath`):\r\n```\r\n.. | objects\r\n| select(.logId)\r\n| .logId as $id\r\n| .. | objects\r\n| select(.[] == &quot;CREDENTIALS_VAULT-1212121212121&quot;)\r\n| $id\r\n```\r\n\r\nSince the string might occur several times, you might want to consider variants, for example replacing the second-last line above by:\r\n```\r\n| select(first(.[] == &quot;CREDENTIALS_VAULT-1212121212121&quot; // empty))\r\n```\r\n",
                "title": "jq - search a string value at any level of a json file and get the parent keys"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1699387059,
                "creation_date": 1699387059,
                "answer_id": 77441115,
                "question_id": 77372497,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thank you very much for your answers. I finally chose to use the first solution using the getpath() function. With this solution, we don’t care about the name of the key. Indeed in my case the pattern to search (&quot;CREDENTIALS_VAULT-1212121212121&quot;) is not necessary the value of the key &quot;credentialId&quot;. This can be another key: \r\n\r\n    $ grep &quot;CREDENTIALS_VAULT-1212121212121&quot; auditlogs2.json\r\n                      &quot;credentialId&quot;: &quot;CREDENTIALS_VAULT-1212121212121&quot;\r\n                      &quot;myotherkey&quot;: &quot;CREDENTIALS_VAULT-1212121212121&quot;\r\n    \r\n    $ cat auditlogs2.json | jq -r &#39;getpath(paths(. == &quot;CREDENTIALS_VAULT-1212121212121&quot;)[:2]) | .logId&#39;\r\n    169807591200060002\r\n    169807591200060001\r\n\r\nBoth entries were found. That is more appropriate in my case ;)\r\nBut thanks again to every one. \r\n\r\n\r\n\r\n",
                "title": "jq - search a string value at any level of a json file and get the parent keys"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1699387059,
        "creation_date": 1698394415,
        "question_id": 77372497,
        "body_markdown": "I would like to find in a JSON file a specific value (without worrying about the key) at any level of my JSON file (I don&#39;t know in advance the exact tree) and display the parent keys.\r\n\r\nI have extracted this sample :\r\n\r\n```\r\ncat /tmp/test.json | jq\r\n{\r\n  &quot;totalCount&quot;: 2,\r\n  &quot;pageSize&quot;: 1000,\r\n  &quot;auditLogs&quot;: [\r\n    {\r\n      &quot;logId&quot;: &quot;169807591200060002&quot;,\r\n      &quot;eventType&quot;: &quot;CREATE&quot;,\r\n      &quot;category&quot;: &quot;CONFIG&quot;,\r\n      &quot;entityId&quot;: &quot;HTTP_CHECK-12121212121212&quot;,\r\n      &quot;timestamp&quot;: 1698075912003,\r\n      &quot;success&quot;: true,\r\n      &quot;patch&quot;: [\r\n        {\r\n          &quot;op&quot;: &quot;replace&quot;,\r\n          &quot;path&quot;: &quot;/&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;steps&quot;: [\r\n              {\r\n                &quot;id&quot;: {\r\n                  &quot;type&quot;: &quot;HTTP_CHECK_STEP&quot;\r\n                },\r\n                &quot;requestType&quot;: &quot;OAUTH2&quot;,\r\n                &quot;destinationUrl&quot;: &quot;https://www.mywebsite.com&quot;,\r\n                &quot;httpMethod&quot;: &quot;POST&quot;,\r\n                &quot;acceptAnyCertificate&quot;: true,\r\n                &quot;followRedirects&quot;: true,\r\n                &quot;displayName&quot;: &quot;My Website&quot;,\r\n                &quot;userAgent&quot;: &quot;&quot;,\r\n                &quot;httpCheckHeaders&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;Content-Type&quot;,\r\n                    &quot;value&quot;: &quot;application/x-www-form-urlencoded&quot;\r\n                  }\r\n                ],\r\n                &quot;stepPerformanceThreshold&quot;: 0,\r\n                &quot;requestBody&quot;: null,\r\n                &quot;constraints&quot;: [\r\n                  {\r\n                    &quot;constraintType&quot;: &quot;HttpStatusesList&quot;,\r\n                    &quot;passIfFound&quot;: false,\r\n                    &quot;pattern&quot;: &quot;&gt;=400&quot;\r\n                  }\r\n                ],\r\n                &quot;preScript&quot;: &quot;&quot;,\r\n                &quot;postScript&quot;: &quot;&quot;,\r\n                &quot;attributes&quot;: {\r\n                  &quot;oAuth2RequestId&quot;: &quot;1&quot;,\r\n                  &quot;oAuth2BodyInputType&quot;: &quot;RAW&quot;,\r\n                  &quot;oAuth2addAuthDataTo&quot;: &quot;REQUEST_BODY&quot;\r\n                },\r\n                &quot;postExecutionScriptVariables&quot;: [\r\n                  &quot;{bearerToken-1}&quot;\r\n                ],\r\n                &quot;preExecutionScriptVariables&quot;: [],\r\n                &quot;certificateId&quot;: &quot;&quot;,\r\n                &quot;basicAuthId&quot;: &quot;&quot;,\r\n                &quot;certStoreId&quot;: 0,\r\n                &quot;basicAuthStoreId&quot;: 0,\r\n                &quot;authenticationConfig&quot;: {\r\n                  &quot;type&quot;: &quot;BASIC_AUTHENTICATION&quot;,\r\n                  &quot;realmName&quot;: null,\r\n                  &quot;kdcIp&quot;: null,\r\n                  &quot;credentialId&quot;: &quot;CREDENTIALS_VAULT-1212121212121&quot;\r\n                },\r\n                &quot;executionProperties&quot;: {},\r\n                &quot;shouldNotPersistSensitiveData&quot;: true\r\n              }\r\n            ],\r\n            &quot;publicLocationIds&quot;: [\r\n              124\r\n            ],\r\n            &quot;userModificationTimestamp&quot;: 1698075911987,\r\n            &quot;customProperties&quot;: [],\r\n            &quot;version&quot;: 6\r\n          },\r\n          &quot;oldValue&quot;: null\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;logId&quot;: &quot;169807591200060001&quot;,\r\n      &quot;eventType&quot;: &quot;CREATE&quot;,\r\n      &quot;category&quot;: &quot;CONFIG&quot;,\r\n      &quot;entityId&quot;: &quot;HTTP_CHECK-12121212121212&quot;,\r\n      &quot;environmentId&quot;: &quot;b416bf43-a9d2-4123-aa70-e36ff39c0ad9&quot;,\r\n      &quot;timestamp&quot;: 1698075911986,\r\n      &quot;success&quot;: true,\r\n      &quot;patch&quot;: [\r\n        {\r\n          &quot;op&quot;: &quot;replace&quot;,\r\n          &quot;path&quot;: &quot;/&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;frequency (Frequency)&quot;: 0,\r\n            &quot;locations&quot;: [\r\n              {\r\n                &quot;location (Location)&quot;: &quot;SYNTHETIC_LOCATION-000000000000007C&quot;\r\n              }\r\n            ]\r\n          },\r\n          &quot;oldValue&quot;: null\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI am able to find the string &quot;CREDENTIALS_VAULT-1212121212121&quot; with this recursive command : \r\n\r\n```\r\ncat /tmp/test.json | jq &#39;.auditLogs[] | .. | .credentialId? | select(. == &quot;CREDENTIALS_VAULT-1212121212121&quot;)&#39;                       \r\n&quot;CREDENTIALS_VAULT-1212121212121&quot;\r\n```\r\n\r\nBut I would like also to get the parent key &quot;logId&quot; at the first level. I tried to use a variable ($parent) but unfortunately I got several results instead of only one : \r\n\r\n```\r\ncat /tmp/test.json | jq &#39;.auditLogs[] as $parent | .. | .credentialId? | select(. == &quot;CREDENTIALS_VAULT-1212121212121&quot;) | $parent | {&quot;logId&quot;:.logId}&#39;\r\n{\r\n  &quot;logId&quot;: &quot;169807591200060002&quot;\r\n}\r\n{\r\n  &quot;logId&quot;: &quot;169807591200060001&quot;\r\n}\r\n```\r\n\r\nDoes anyone have an idea for this need? ",
        "link": "https://stackoverflow.com/questions/77372497/jq-search-a-string-value-at-any-level-of-a-json-file-and-get-the-parent-keys",
        "title": "jq - search a string value at any level of a json file and get the parent keys"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "export-csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1698686606,
                "post_id": 77390622,
                "comment_id": 136434081,
                "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": 1698686610,
                "post_id": 77390622,
                "comment_id": 136434084,
                "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": 1698686721,
                "post_id": 77390622,
                "comment_id": 136434105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944965,
                    "reputation": 1378,
                    "user_id": 11505813,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fdb185821fb32e77eb5f2b4f36194f51?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Somethingwhatever",
                    "link": "https://stackoverflow.com/users/11505813/somethingwhatever"
                },
                "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": 1698686780,
                "post_id": 77390622,
                "comment_id": 136434116,
                "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": 1698686855,
                "post_id": 77390622,
                "comment_id": 136434132,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15944965,
                    "reputation": 1378,
                    "user_id": 11505813,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fdb185821fb32e77eb5f2b4f36194f51?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Somethingwhatever",
                    "link": "https://stackoverflow.com/users/11505813/somethingwhatever"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698686898,
                "post_id": 77390622,
                "comment_id": 136434143,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1698697957,
                "last_edit_date": 1698697957,
                "creation_date": 1698687921,
                "answer_id": 77390811,
                "question_id": 77390622,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you state you wish to produce CSV, let me start with a filter that does just that:\r\n```\r\n[&quot;ARN&quot;, &quot;STAGE&quot;, &quot;CostCenter&quot;, &quot;Service&quot;, &quot;Domain&quot;, &quot;Team&quot;] as $columns\r\n| $columns, \r\n  (.[]\r\n   | .ResourceARN as $ARN\r\n   |  .Tags | from_entries\r\n   | [$ARN, .[ $columns[1:][]]] )\r\n| @csv\r\n```\r\n\r\nYour illustrative output seems to correspond more closely to TSV, and you indicate you want missing fields to be represented by `&quot;&quot;`, so we could tweak the above accordingly:\r\n```\r\n[&quot;ARN&quot;, &quot;STAGE&quot;, &quot;CostCenter&quot;, &quot;Service&quot;, &quot;Domain&quot;, &quot;Team&quot;] as $columns\r\n| &quot;\\&quot;\\&quot;&quot; as $q\r\n| $columns, \r\n  (.[]\r\n   | .ResourceARN as $ARN\r\n   |  .Tags | from_entries\r\n   | [$ARN, (.[ $columns[1:][]] | (. // $q ) ) ] )\r\n| @tsv\r\n\r\n```\r\n\r\n(The trick here is using `STREAM | (. // $q)` instead of `STREAM // $q`.)\r\n\r\nWith your sample input, this produces:\r\n```\r\nARN\tSTAGE\tCostCenter\tService\tDomain\tTeam\r\narn\tst\t&quot;&quot;\t&quot;&quot;\t&quot;&quot;\t&quot;&quot;\r\narn\tst\t&quot;&quot;\t&quot;&quot;\t&quot;&quot;\t&quot;&quot;\r\narn\tec\tDevelopment\tMP\t&quot;&quot;\tVNP\r\n```\r\n\r\nYou might wish to consider other variants, e.g. using `join(&quot;,&quot;)` instead of `@csv` or `@tsv`.\r\n\r\n\r\n",
                "title": "bash compile output into a csv using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1698720339,
        "creation_date": 1698685905,
        "last_edit_date": 1698720339,
        "question_id": 77390622,
        "body_markdown": "I am writing a bash script to create a csv from a sample inconsistent json data but running into a bunch of issues : \r\n\r\nMy json data looks like this : \r\n\r\n    json_data=&#39;[\r\n      {\r\n        &quot;ResourceARN&quot;: &quot;arn&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;STAGE&quot;,\r\n            &quot;Value&quot;: &quot;st&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;ResourceARN&quot;: &quot;arn&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;STAGE&quot;,\r\n            &quot;Value&quot;: &quot;st&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;ResourceARN&quot;: &quot;arn&quot;,\r\n        &quot;Tags&quot;: [\r\n          {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:stack-name&quot;,\r\n            &quot;Value&quot;: &quot;aud&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;CostCenter&quot;,\r\n            &quot;Value&quot;: &quot;Development&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:stack-id&quot;,\r\n            &quot;Value&quot;: &quot;arn&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;STAGE&quot;,\r\n            &quot;Value&quot;: &quot;ec&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;Environment&quot;,\r\n            &quot;Value&quot;: &quot;development&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;Region&quot;,\r\n            &quot;Value&quot;: &quot;us-west-2&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;Service&quot;,\r\n            &quot;Value&quot;: &quot;MP&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;aws:cloudformation:logical-id&quot;,\r\n            &quot;Value&quot;: &quot;ApiGatewayRestApi&quot;\r\n          },\r\n          {\r\n            &quot;Key&quot;: &quot;Team&quot;,\r\n            &quot;Value&quot;: &quot;VNP&quot;\r\n          }\r\n        ]\r\n      } and so on\r\n    ]&#39;\r\n\r\n\r\nI am trying to create a csv with the following column names : ARN, Stage, CostCenter, Service, Domain, Team and the values should be what is found in the key value pairs of the Tags array and whatever key value pairs do not exist then just leave the column as blank. \r\n\r\n\r\nMy code looks like this : \r\n\r\n    # Define the columns\r\n    columns=(&quot;ARN&quot; &quot;STAGE&quot; &quot;CostCenter&quot; &quot;Service&quot; &quot;Domain&quot; &quot;Team&quot;)\r\n    \r\n    # Create CSV header\r\n    header=$(IFS=&#39;,&#39;; echo &quot;${columns[*]}&quot;)\r\n    \r\n    # Function to get value for a specific key in the Tags array\r\n    get_value() {\r\n      key=&quot;$1&quot;\r\n      tags=&quot;$2&quot;\r\n      value=$(echo &quot;$tags&quot; | jq -r --arg key &quot;$key&quot; &#39;.[] | select(.Key == $key) | .Value&#39;)\r\n      if [ &quot;$value&quot; == &quot;null&quot; ]; then\r\n        echo &quot;&quot;\r\n      else\r\n        echo &quot;$value&quot;\r\n      fi\r\n    }\r\n    \r\n    # Create the CSV data\r\n    csv_data=&quot;&quot;\r\n    for item in &quot;${json_data[@]}&quot;; do\r\n      resource_arn=$(echo &quot;$item&quot; | jq -r &#39;.ResourceARN&#39;)\r\n      row=&quot;$resource_arn&quot;\r\n      for col in &quot;${columns[@]}&quot;; do\r\n        value=$(get_value &quot;$col&quot; &quot;$(echo &quot;$item&quot; | jq -c &#39;.Tags&#39;)&quot;)\r\n        row=&quot;$row,$value&quot;\r\n      done\r\n      csv_data=&quot;$csv_data$row\\n&quot;\r\n    done\r\n    \r\n    # Output the CSV to a file\r\n    echo -e &quot;$header\\n$csv_data&quot; &gt; output.csv\r\n    \r\n    echo &quot;CSV data has been written to output.csv&quot;\r\n\r\n\r\nBut i keep running into \r\n\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;ResourceARN&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n    jq: error (at &lt;stdin&gt;:57): Cannot index array with string &quot;Tags&quot;\r\n\r\n\r\nBasically the final CSV should look like \r\n\r\n    ARN STAGE CostCenter Service Domain Team\r\n    arn st.   &quot;&quot;          &quot;&quot;      &quot;&quot;     &quot;&quot;\r\n    arn st    &quot;&quot;          &quot;&quot;      &quot;&quot;     &quot;&quot; \r\n    arn ec    Development MP.     &quot;&quot;     VNP\r\n    ....\r\n\r\nCan someone please point out what i&#39;m doing wrong or if there is a simple way of doing it? i would imagine `jq` would simply leave the values blank and output the ones having values? Thank you.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77390622/bash-compile-output-into-a-csv-using-jq",
        "title": "bash compile output into a csv using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698755165,
                "post_id": 77395822,
                "comment_id": 136443057,
                "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": 1698755442,
                "post_id": 77395822,
                "comment_id": 136443106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "reply_to_user": {
                    "account_id": 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": 1698756014,
                "post_id": 77395822,
                "comment_id": 136443206,
                "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"
                },
                "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": 1698756043,
                "post_id": 77395822,
                "comment_id": 136443209,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698756175,
                "last_edit_date": 1698756175,
                "creation_date": 1698755182,
                "answer_id": 77395868,
                "question_id": 77395822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t iterate the elements of the array with `.[]` but [`map`](https://jqlang.github.io/jq/manual/#map-map_values) them to a new array, then `add` them to a single object:\r\n\r\n```\r\nmap(select(.entity_id|startswith(&quot;sensor.current.&quot;)) | { (.entity_id) : .state})\r\n| add\r\n```\r\n\r\nAlternatively, [`reduce`](https://jqlang.github.io/jq/manual/#reduce) to your final object:\r\n\r\n```\r\nreduce (.[] | select(.entity_id|startswith(&quot;sensor.current.&quot;)))\r\nas $x ({}; .[$x.entity_id] = $x.state)\r\n```\r\n\r\nThe third option is using [`from_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) to construct an object from an array of key-value-pairs:\r\n\r\n```\r\nmap(select(.entity_id|startswith(&quot;sensor.current.&quot;)) | { key: .entity_id, value: .state})\r\n| from_entries\r\n```",
                "title": "crunch series of hashes into single hash"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698755395,
                "creation_date": 1698755395,
                "answer_id": 77395896,
                "question_id": 77395822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input is large, you may want to use `reduce` to iteratively build up your output object:\r\n```sh\r\n… | reduce (.[] | select(.entity_id | test(&quot;sensor.current.&quot;))) as $item ({};\r\n      .[$item.entity_id] = $item.state\r\n    )\r\n```\r\nNote that `test` works with regular expressions, so the `.` in `&quot;sensor.current.&quot;` means any character. You might want to use `contains` or `startswith` instead.",
                "title": "crunch series of hashes into single hash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1698842751,
                "last_edit_date": 1698842751,
                "creation_date": 1698761019,
                "answer_id": 77396609,
                "question_id": 77395822,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works for me in eating large Json blocks \r\n\r\n```\r\njq &#39;map(select(.entity_id|startswith(&quot;sensor.current&quot;)) | { (.entity_id) : .state})| add&#39; foo.json\r\n```\r\n\r\nand many thanks to @knittl and @pmf\r\n",
                "title": "crunch series of hashes into single hash"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1698842751,
        "creation_date": 1698754682,
        "question_id": 77395822,
        "body_markdown": "I am processing a large json structure which is in foo.json\r\n\r\nat the completion of this filter\r\n`jq &#39;.[] | select(.entity_id|test(&quot;sensor.current.&quot;)) | { (.entity_id) : .state}   &#39; foo.json`\r\n having reduced the list of components with a select() I get:\r\n\r\n```\r\n{\r\n  &quot;sensor.current_consumption&quot;: &quot;1.4&quot;\r\n}\r\n{\r\n  &quot;sensor.current_power&quot;: &quot;194.6&quot;\r\n}\r\n{\r\n  &quot;sensor.current_mains_voltage&quot;: &quot;239.9&quot;\r\n}\r\n```\r\n\r\nWhat I want is\r\n`{ &quot;sensor.current_consumption&quot;: &quot;1.4&quot;, &quot;sensor.current_power&quot;: &quot;194.6&quot;, &quot;sensor.current_mains_voltage&quot;: &quot;239.9&quot; }`\r\n\r\n\r\nI have tried to read up on jq&#39;s  map() and add() but cannot make much sense. Similar questions have been asked before and looking at answers e.g. [here](https://stackoverflow.com/questions/52547428/combining-outputs-into-single-hash-dictionary-jq) I tried\r\n\r\n```\r\njq &#39;.[] | select(.entity_id|test(&quot;sensor.current.&quot;)) | map({ (.entity_id) : .state}) | add   &#39; foo.json\r\njq: error (at foo.json:0): Cannot index string with string &quot;entity_id&quot;\r\n```\r\n\r\nand\r\n\r\n```\r\njq &#39;.[] | select(.entity_id|test(&quot;sensor.current.&quot;)) | map({ (.entity_id) : .state}) | add   &#39; foo.json\r\nrrent.&quot;)) | map({ (.entity_id) : .state}) | add   &#39; foo.foo\r\n\r\n```\r\n\r\n\r\nAny help is welcome\r\n",
        "link": "https://stackoverflow.com/questions/77395822/crunch-series-of-hashes-into-single-hash",
        "title": "crunch series of hashes into single hash"
    },
    {
        "tags": [
            "jq",
            "eval"
        ],
        "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": 1698798041,
                "post_id": 77399537,
                "comment_id": 136450502,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19386872,
                    "reputation": 1,
                    "user_id": 14176421,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/VeIhL.jpg?s=256",
                    "display_name": "Pitya Bhai",
                    "link": "https://stackoverflow.com/users/14176421/pitya-bhai"
                },
                "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": 1698899226,
                "post_id": 77399537,
                "comment_id": 136463740,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698824219,
                "creation_date": 1698824219,
                "answer_id": 77401021,
                "question_id": 77399537,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @pmf pointed out, jq does not provide an &quot;eval&quot; function, so if you really wanted to evaluate jq expressions, you&#39;d have to write your own, which is probably not what you want.\r\n\r\nHowever, there is a reasonable alternative. Since you are evidently willing to include some kind of expression to be evaluated in your JSON, you could piggy-back off jq&#39;s support for array-paths, and write a simple evaluator. For example,\r\nif you were willing to write your JSON template as:\r\n```\r\n{\r\n  &quot;name&quot;: [[&quot;firstname&quot;], &quot; Smith&quot;],\r\n  &quot;firstname&quot;: &quot;John&quot;\r\n}\r\n```\r\nthen this little bit of infrastructure:\r\n```\r\ndef ispath:\r\n  type == &quot;array&quot; and all(.[]; type | IN(&quot;string&quot;,&quot;number&quot;) );\r\n  \r\n# eval . in the context of $context\r\ndef eval($context):\r\n  . as $x\r\n  | if type == &quot;string&quot; then .\r\n    elif ispath then $context | getpath($x)\r\n    elif type == &quot;array&quot;\r\n    then map( eval($context) ) | add\r\n    elif type == &quot;object&quot;\r\n    then map_values(eval($context))\r\n    else tostring\r\n    end;\r\n```\r\nwould allow you to achieve essentially what you want by:  \r\n```\r\n{\r\n  &quot;name&quot;: [[&quot;firstname&quot;], &quot; Smith&quot;],\r\n  &quot;firstname&quot;: &quot;John&quot;\r\n}\r\n| eval(.)\r\n\r\n```\r\n",
                "title": "JQ run dynamic command from inside the object"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1698907898,
        "creation_date": 1698794241,
        "last_edit_date": 1698907898,
        "question_id": 77399537,
        "body_markdown": "In JQ is it possible to execute the command from same object? \r\n\r\nTake and example below\r\n\r\n```\r\n{\r\n&quot;cmd&quot;: &quot;.name += \\&quot; Smith\\&quot; | .name&quot;,\r\n&quot;name&quot;: &quot;John&quot;\r\n}\r\n```\r\n\r\nIf you see i have name and cmd as two keys. If you run the text from cmd&#39;s value in [JQPlay][1]. You will see below object `&quot;John Smith&quot;`\r\n\r\nIs it possible to do it using single JQ query ?\r\n\r\n\r\n  [1]: https://jqplay.org/s/0U_vMF-fTCJ",
        "link": "https://stackoverflow.com/questions/77399537/jq-run-dynamic-command-from-inside-the-object",
        "title": "JQ run dynamic command from inside the object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2383143,
                    "reputation": 41,
                    "user_id": 2084718,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/48bffa7a560a60bad828d06c6c015379?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "bongo",
                    "link": "https://stackoverflow.com/users/2084718/bongo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1698830068,
                "post_id": 77401140,
                "comment_id": 136453554,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1698828292,
                "creation_date": 1698828292,
                "answer_id": 77401340,
                "question_id": 77401140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Either store values in variables for reference before descending deeper into the structure:\r\n```sh\r\n. as {$id} | .activities[] | .cities[] as $city\r\n| [$id, .time, $city, .type] | @tsv\r\n```\r\n[Demo](https://jqplay.org/s/8rpu-v9t-WK)\r\n\r\nOr add the final pieces together while iterating over the parts separately:\r\n```sh\r\n[.id] + (.activities[] | [.time] + (.cities[] | [.]) + [.type]) | @tsv\r\n```\r\n[Demo](https://jqplay.org/s/aC34_rbrW88)\r\n\r\nOutput:\r\n```csv\r\n1\t1659800397\tlondon\t1\r\n1\t1659800397\tparis\t1\r\n1\t1659800411\trome\t2\r\n```\r\n",
                "title": "flatten json object using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698853374,
                "last_edit_date": 1698853374,
                "creation_date": 1698830184,
                "answer_id": 77401505,
                "question_id": 77401140,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I found the solution myself; however, I think it could be useful to others:\r\n\r\n    jq -r &#39;.id as $id | .activities[] | &quot;\\($id);\\(.time);\\(.type);\\(.cities[])&quot;&#39; input.json\r\n\r\nHere&#39;s how the code works:\r\n\r\n`.id as $id` extracts the &quot;id&quot; field and assigns it to the variable, `$id`.\r\n`.activities[]` iterates over each object in the &quot;activities&quot; array.\r\n`&quot;...\\($id);\\(.time);\\(.type);\\(.cities[])&quot;` constructs the desired output format with the extracted values, using the variables and fields we defined.",
                "title": "flatten json object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1698853374,
        "creation_date": 1698825938,
        "last_edit_date": 1698828248,
        "question_id": 77401140,
        "body_markdown": "I have the following json object:\r\n```\r\n{\r\n    &quot;id&quot;:1,\r\n    &quot;activities&quot;:[\r\n       {&quot;time&quot;:1659800397,&quot;cities&quot;:[&quot;london&quot;,&quot;paris&quot;],&quot;type&quot;:1},\r\n       {&quot;time&quot;:1659800411,&quot;cities&quot;:[&quot;rome&quot;],          &quot;type&quot;:2}\r\n     ]\r\n}\r\n```\r\n\r\nI would like to flatten it to the following tab separated structure, perhaps using jq\r\n\r\n| id | time       | cities | type |\r\n| -- | ---------- | ------ | ---- |\r\n| 1  | 1659800397 | london |    1 |\r\n| 1  | 1659800397 | paris  |    1 |\r\n| 1  | 1659800411 | rome   |    2 |\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77401140/flatten-json-object-using-jq",
        "title": "flatten json object using jq"
    },
    {
        "tags": [
            "json",
            "powershell",
            "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": 1698870789,
                "post_id": 77405440,
                "comment_id": 136461101,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6594368,
                    "reputation": 159,
                    "user_id": 5094649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/634e8f3067d4d24e18ab5c24ec07f5c6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "July Elizabeth",
                    "link": "https://stackoverflow.com/users/5094649/july-elizabeth"
                },
                "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": 1698871477,
                "post_id": 77405440,
                "comment_id": 136461218,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1698872410,
                "creation_date": 1698872410,
                "answer_id": 77405579,
                "question_id": 77405440,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $jsonObject=gc pw.txt | ConvertFrom-JSON\r\n    $jsonObject.powershell.&quot;is a task&quot;.automation[0].management[0].microsoft.shell.associated.scripting.component.windows.powershell",
                "title": "PowerShell: dealing with JSON using its native shorter command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1698872410,
        "creation_date": 1698870686,
        "last_edit_date": 1698871926,
        "question_id": 77405440,
        "body_markdown": "I usually use JQ to handle JSON.\r\n\r\n    PS C:\\&gt; gc pw.txt\r\n    {\r\n        &quot;PowerShell&quot;: {\r\n            &quot;is a task&quot;: {\r\n                &quot;automation&quot;: [\r\n                    {\r\n                        &quot;and&quot;: &quot;configuration&quot;,\r\n                        &quot;management&quot;: [\r\n                            {\r\n                                &quot;program&quot;: &quot;from&quot;,\r\n                                &quot;microsoft&quot;: {\r\n                                    &quot;consisting of&quot;: &quot;a command-line&quot;,\r\n                                    &quot;shell&quot;: {\r\n                                        &quot;and&quot;: &quot;the&quot;,\r\n                                        &quot;associated&quot;: {\r\n                                            &quot;scripting&quot;: {\r\n                                                &quot;language.&quot;: &quot;initially a windows&quot;,\r\n                                                &quot;component&quot;: {\r\n                                                    &quot;only&quot;: &quot;known as&quot;,\r\n                                                    &quot;windows&quot;: {\r\n                                                        &quot;powershell&quot;: &quot;7.3.9-win-x64.msi&quot;,\r\n                                                        &quot;it was made&quot;: &quot;open-source&quot;\r\n                                                    }\r\n                                                }\r\n                                            }\r\n                                        }\r\n                                    }\r\n                                }\r\n                            }\r\n                        ]\r\n                    },\r\n                    {\r\n                        &quot;the former&quot;: &quot;is built on the .NET Framework&quot;,\r\n                        &quot;the latter on&quot;: &quot;.NET (previously .NET Core).&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    } \r\n\r\nThe following method works well in PowerShell to get the value `7.3.9-win-x64.msi` from the JSON above:\r\n\r\n    PS C:\\&gt; gc pw.txt | jq -r &#39;.[] | .[] | .[] | .[].management | .[0].microsoft | .shell.associated.scripting.component.windows.powershell&#39;\r\n\r\nSo, now how do I get the same value, without using JQ, but using the built-in utility in PowerShell itself (as much as possible with shorter commands) ?.",
        "link": "https://stackoverflow.com/questions/77405440/powershell-dealing-with-json-using-its-native-shorter-command",
        "title": "PowerShell: dealing with JSON using its native shorter command?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1698897031,
                "post_id": 77406373,
                "comment_id": 136463582,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1698910199,
                "last_edit_date": 1698910199,
                "creation_date": 1698895700,
                "answer_id": 77406767,
                "question_id": 77406373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you’re willing to take the risk, you could go with s.t. like:\r\n```lang-none\r\n.. | objects | .powershell // empty\r\n```\r\nOr if you know s.t. distinctive about the string of interest, e.g. that it ends with &quot;.msi&quot;:\r\n```lang-none\r\n.. | strings | select(endswith(&quot;.msi&quot;))\r\n```\r\n\r\n\r\n\r\n",
                "title": "JQ: What is the shorter syntax to get the value"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1698896325,
                "creation_date": 1698896325,
                "answer_id": 77406788,
                "question_id": 77406373,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the full path must be specified along the lines of your attempt, you could slightly shorten it by skipping the explicit pipes:\r\n\r\n    .[][][][].management[0].microsoft.shell.associated.scripting.component.windows.powershell\r\n\r\n",
                "title": "JQ: What is the shorter syntax to get the value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1698910333,
        "creation_date": 1698886160,
        "last_edit_date": 1698910333,
        "question_id": 77406373,
        "body_markdown": "I used the following long command to get a JSON value `7.3.9-win-x64.msi` that I included below.\r\n\r\n```sh\r\n$ cat json.txt  | jq -r &#39;.[] | .[] | .[] | .[].management | .[0].microsoft | .shell.associated.scripting.component.windows.powershell&#39;\r\n```\r\n\r\nFor JSON code it is:\r\n\r\n```json\r\n{\r\n  &quot;PowerShell&quot;: {\r\n    &quot;is a task&quot;: {\r\n      &quot;automation&quot;: [\r\n        {\r\n          &quot;and&quot;: &quot;configuration&quot;,\r\n          &quot;management&quot;: [\r\n            {\r\n              &quot;program&quot;: &quot;from&quot;,\r\n              &quot;microsoft&quot;: {\r\n                &quot;consisting of&quot;: &quot;a command-line&quot;,\r\n                &quot;shell&quot;: {\r\n                  &quot;and&quot;: &quot;the&quot;,\r\n                  &quot;associated&quot;: {\r\n                    &quot;scripting&quot;: {\r\n                      &quot;language.&quot;: &quot;initially a windows&quot;,\r\n                      &quot;component&quot;: {\r\n                        &quot;only&quot;: &quot;known as&quot;,\r\n                        &quot;windows&quot;: {\r\n                          &quot;powershell&quot;: &quot;7.3.9-win-x64.msi&quot;,\r\n                          &quot;it was made&quot;: &quot;open-source&quot;\r\n                        }\r\n                      }\r\n                    }\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;the former&quot;: &quot;is built on the .NET Framework&quot;,\r\n          &quot;the latter on&quot;: &quot;.NET (previously .NET Core).&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI failed when I tried to apply several methods that I got from several articles on the internet to get the same value in a shorter way. So is there a more shortest command to do it?.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/77406373/jq-what-is-the-shorter-syntax-to-get-the-value",
        "title": "JQ: What is the shorter syntax to get the value"
    },
    {
        "tags": [
            "json",
            "sh",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1698925901,
                "post_id": 77408894,
                "comment_id": 136467591,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1698921889,
                "last_edit_date": 1698921889,
                "creation_date": 1698921875,
                "answer_id": 77408935,
                "question_id": 77408894,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`cat temp.json | jq --arg MESSAGE &quot;$MESSAGE&quot; &#39;any(.message[];startswith($MESSAGE))&#39;`\r\n\r\ni think you passed the argument wrongly, this should help to do the trick\r\n\r\nthis will return true or false depends on whether the string is found or not",
                "title": "Parsing json which contains string with spaces using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1698951981,
        "creation_date": 1698921510,
        "last_edit_date": 1698951981,
        "question_id": 77408894,
        "body_markdown": "I have a json as :\r\n\r\n    {&quot;message&quot;:[&quot;Another open merge request already exists for this source branch: !5193&quot;]}\r\n\r\nI want to you use jq in a shell script and check whether this string is there or not .\r\n\r\nThe string i want to search is `Another open merge request already exists for this source branch`\r\n\r\nI am trying it via command :\r\n\r\n    cat temp.json| jq --arg MESSAGE &quot;$MESSAGE&quot; | select(.message == Another open merge request already exists for this source branch)\r\n\r\nWhen attempting to run the jq command, it has this error:\r\n\r\n    jq: error: syntax error, unexpected $end\r\n\r\nAny suggestions where its going wrong\r\n",
        "link": "https://stackoverflow.com/questions/77408894/parsing-json-which-contains-string-with-spaces-using-jq",
        "title": "Parsing json which contains string with spaces using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1698991382,
                "last_edit_date": 1698991382,
                "creation_date": 1698988466,
                "answer_id": 77414327,
                "question_id": 77414104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The succinct solution is the one you disallow:\r\n\r\n\r\n    jq -Rn &#39;[inputs]&#39;\r\n\r\n Next best without using `split` would be:\r\n\r\n    jq -R . list | jq -s .\r\n\r\nDepending on which version of jq you use, you might also be able to use a variant such as:\r\n\r\n     cat list | jq -R | jq -s",
                "title": "Why my simple list to array transform isn&#39;t working in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1698988972,
                "creation_date": 1698988972,
                "answer_id": 77414350,
                "question_id": 77414104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe the problem comes in with `jq` trying to parse the input as JSON on some level (even though -R is being passed)\r\n\r\nIf the input can be quoted, `jq` does output it correctly with a simple filter, i.e\r\n```\r\nawk &#39;{print &quot;\\&quot;&quot;$0&quot;\\&quot;&quot;}&#39; list  | jq -s &#39;.&#39;\r\n```\r\nor\r\n```\r\ncat list | jq -R &#39;.&#39; | jq -s &#39;.&#39;\r\n```\r\nboth work given the original input.\r\n\r\nThe following works, provided you can quote the inputs e.g\r\n```\r\n&quot;me&quot;\r\n&quot;you&quot;\r\n&quot;them&quot;\r\n```\r\n```\r\ncat list2 | jq -s &#39;.&#39;\r\n```\r\nreturns:\r\n```\r\n[\r\n  &quot;me&quot;,\r\n  &quot;you&quot;,\r\n  &quot;them&quot;\r\n]\r\n```",
                "title": "Why my simple list to array transform isn&#39;t working in jq?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1699006174,
                "last_edit_date": 1699006174,
                "creation_date": 1699005278,
                "answer_id": 77415698,
                "question_id": 77414104,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer you arrived at is valid, but this is an explanation of why it works and why the other attempts did not:\r\n\r\n### Why does `cat list | jq -R &#39;[.]&#39;` not work?\r\n\r\nBecause `jq` isn&#39;t running the filter once, but once for **each line** of input. In other words, the `.` is only ever one of the 3 inputs by itself; so `[.]` turns that single element into an array, and then having run 3 times, you have 3 arrays.\r\n\r\nYou are expecting `-R` to quote each string, and each string gets quoted separately because `jq` is reading each line and running the filter on it (the default unless you provide the `-s`), but then on which run of the filter would we create the array? Therefore, the 3 arrays.\r\n\r\n### Why does `cat list | jq -sR &#39; ... &#39;` work?\r\n\r\nBecause now, we told `jq` to treat the entire input across multiple lines as one string. So, the `-R` quotes the entire input making it a valid JSON type (a string), which you then split to produce an array and remove the extraneous empty element.\r\n\r\n### Why does `cat list | jq -s &#39;.&#39;` work if the file has only numbers?\r\n\r\nThis might be surprising, but consider either of these two commands that produce the numbers separated by newlines and spaces respectively:\r\n\r\n```bash\r\n&#167; seq 1 3 | jq -s &#39;.&#39;\r\n&#167; echo 1 2 3 | jq -s &#39;.&#39;\r\n```\r\n\r\nBoth will produce this output:\r\n\r\n```json\r\n[\r\n  1,\r\n  2,\r\n  3\r\n]\r\n```\r\n\r\nThe reason this works is because each `1`, `2`, and `3` are each valid JSON, and `jq` can put them in an array to be passed to the filter. \r\n\r\nAnd now consider this (it will work the same way when each element is on its own line, but each element must be a valid JSON by itself) and notice the array around results:\r\n\r\n```\r\n&#167; echo &#39;1 2 3 [1, 2,3] &quot;man&quot; { &quot;a&quot; : 1, &quot;b&quot; : 2 }&#39;  | jq -s &#39;.&#39;\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  [\r\n    1,\r\n    2,\r\n    3\r\n  ],\r\n  &quot;man&quot;,\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: 2\r\n  }\r\n]\r\n```\r\n\r\nAnd now notice the line below where it has an issue on (i.e., after encountering an unquoted `d`). Also, notice that `false` and `true` were just fine as they are valid boolean constants in JSON. So, we can infer that when it encounters an unquoted token, the parser assumes that it is reading a number, hence the error message about &quot;invalid numeric literal&quot;:\r\n \r\n```bash\r\n&#167; cat -n list\r\n     1\t[1, 2, 3] \r\n     2\t&quot;a&quot; \r\n     3\tfalse\r\n     4\t&quot;b&quot; \r\n     5\ttrue\r\n     6\t&quot;c&quot;\r\n     7\td\r\n     8\t&quot;e&quot;\r\n\r\n&#167; cat list | jq -s &#39;.&#39;\r\nparse error: Invalid numeric literal at line 8, column 0\r\n```\r\n\r\n### Why does `cat list | jq -R | jq -s &#39;.&#39;` work?\r\n\r\nRunning the `jq -R` quotes the strings, and so we are basically doing: \r\n\r\n```\r\n&#167; cat list \r\n&quot;me&quot; \r\n&quot;you&quot; \r\n&quot;them&quot;\r\n\r\n&#167; cat list | jq -s &#39;.&#39;\r\n[\r\n  &quot;me&quot;,\r\n  &quot;you&quot;,\r\n  &quot;them&quot;\r\n]\r\n\r\n```",
                "title": "Why my simple list to array transform isn&#39;t working in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1699006174,
        "creation_date": 1698983581,
        "last_edit_date": 1698985944,
        "question_id": 77414104,
        "body_markdown": "I&#39;m having an hard time trying to grok jq for good. \r\nI want to change the result from list to array. Now this question was already addressed on these SO questions that say to just put brackets arount the query:\r\n\r\nhttps://stackoverflow.com/questions/49302617/output-the-results-of-select-operation-in-an-array-jq\r\n\r\nhttps://stackoverflow.com/questions/63801953/jq-how-to-turn-output-of-array-selector-back-into-an-array\r\n\r\nWhat I want is basically the same but it&#39;s not working. I have a file with three lines: \r\n\r\n    me \r\n    you\r\n    them\r\n\r\nnow with this command line: `cat list | jq -R &#39;.&#39;` The result is:\r\n\r\n    &quot;me&quot;\r\n    &quot;you&quot;\r\n    &quot;them&quot;\r\n\r\nok now I want to convert to array, so as in the questions I should only put some brackets in the identity filter. If I do this (`cat list | jq -R &#39;[.]&#39;`) I get:\r\n\r\n    [\r\n      &quot;me&quot;\r\n    ]\r\n    [\r\n      &quot;you&quot;\r\n    ]\r\n    [\r\n      &quot;them&quot;\r\n    ]\r\n\r\n??? WHYYYY ? If I try `cat list | jq -R &#39;.[]&#39;` the result is:\r\n\r\n    jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;me&quot;)\r\n    jq: error (at &lt;stdin&gt;:2): Cannot iterate over string (&quot;you&quot;)\r\n    jq: error (at &lt;stdin&gt;:3): Cannot iterate over string (&quot;them&quot;)\r\n\r\nhow do I get \r\n\r\n    [\r\n        &quot;me&quot;,\r\n        &quot;you&quot;,\r\n        &quot;them&quot;\r\n    ]\r\n\r\n? I don&#39;t want to use `inputs` function. I want to be able to use in the simple `cat whatever | jq &#39;whatever&#39;` format.\r\nThe worst thing is that it works for a complex query on a big JSON but not for that simple case. What am I doing wrong ? \r\n\r\n\r\n**Edit**\r\n\r\nI found a way to do it, but I don&#39;t consider this an answer because I really think there should be a better way, please enlighten me on how I could do this better.\r\n\r\n    cat list | jq -sR &#39;split(&quot;\\n&quot;) | map(select(length &gt; 0))&#39;\r\n\r\nthen I finally got the desired \r\n\r\n    [\r\n        &quot;me&quot;,\r\n        &quot;you&quot;,\r\n        &quot;them&quot;\r\n    ]\r\n\r\nwithout map I got another (empty) string in the array due to the last \\n\r\n\r\nUgly as hell and I still don&#39;t know why I got the results I mentioned above. To me `cat list | jq -R &#39;[.]&#39;)` should have worked.\r\n",
        "link": "https://stackoverflow.com/questions/77414104/why-my-simple-list-to-array-transform-isnt-working-in-jq",
        "title": "Why my simple list to array transform isn&#39;t working in jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699020552,
                "post_id": 77417285,
                "comment_id": 136481896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699026110,
                "post_id": 77417285,
                "comment_id": 136483274,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1699021157,
                "creation_date": 1699021157,
                "answer_id": 77417392,
                "question_id": 77417285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming, the first jq instance (`jq &#39;.rows[]&#39;`) produced the stream shown as example, you can combine both into one by using a pipe within the filter.\r\n\r\nHere&#39;s one way using `keys_unsorted` (which is like `keys` but does not sort them), but going two levels deep:\r\n```sh\r\n.rows[]\r\n| keys_unsorted[] as $host | .[$host]\r\n| keys_unsorted[] as $pkg | .[$pkg]\r\n| [\r\n    $host, $pkg,\r\n    .arch, .epoch, (.installdate | tonumber | todate), .release, .version\r\n  ]\r\n| join(&quot;, &quot;) # or @csv\r\n```\r\n[Demo](https://jqplay.org/s/EuxMm8JyPO2)\r\n\r\nOutput:\r\n```\r\nhost1, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5, 1.02.170\r\nhost2, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T10:50:31Z, 6.0.5.el7_9.5, 1.02.170\r\n```",
                "title": "For a JSON having details from packages on a VM, convert it to CSV retaining two parent levels"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699021301,
                "creation_date": 1699021301,
                "answer_id": 77417410,
                "question_id": 77417285,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries`:\r\n\r\n```bash\r\n$ jq -r &#39;to_entries[] | &quot;\\(.key), \\(.value|keys[]), \\(.value[].arch), \\(.value[].epoch), \\(.value[].installdate | tonumber | todate), \\(.value[].release), \\(.value[].version)&quot;&#39; file\r\nhost1, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5, 1.02.170\r\nhost2, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T10:50:31Z, 6.0.5.el7_9.5, 1.02.170\r\n```",
                "title": "For a JSON having details from packages on a VM, convert it to CSV retaining two parent levels"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1699034647,
        "creation_date": 1699020380,
        "last_edit_date": 1699034647,
        "question_id": 77417285,
        "body_markdown": "Given the following JSON, convert it into CSV\r\n```\r\n{\r\n  &quot;host1&quot;: {\r\n    &quot;packages.device-mapper-event-libs&quot;: {\r\n      &quot;epoch&quot;: &quot;7&quot;,\r\n      &quot;version&quot;: &quot;1.02.170&quot;,\r\n      &quot;release&quot;: &quot;6.0.5.el7_9.5&quot;,\r\n      &quot;installdate&quot;: &quot;1691227100&quot;,\r\n      &quot;arch&quot;: &quot;x86_64&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;host2&quot;: {\r\n    &quot;packages.device-mapper-event-libs&quot;: {\r\n      &quot;epoch&quot;: &quot;7&quot;,\r\n      &quot;version&quot;: &quot;1.02.170&quot;,\r\n      &quot;release&quot;: &quot;6.0.5.el7_9.5&quot;,\r\n      &quot;installdate&quot;: &quot;1691232631&quot;,\r\n      &quot;arch&quot;: &quot;x86_64&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nWhat I have tried / got\r\n```\r\njq &#39;.rows[]&#39; | jq -r &#39;keys[] as $k | &quot;\\($k), \\(.[$k][] | .arch), \\(.[$k][] | .epoch), \\(.[$k][] | .installdate | (tonumber|todate)), \\(.[$k][] | .release),\\(.[$k][] | .version)&quot;&#39;\r\n```\r\n\r\nThis produces\r\n```\r\nhost1, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5,1.02.170\r\nhost2, x86_64, 7, 2023-08-05T10:50:31Z, 6.0.5.el7_9.5,1.02.170\r\n```\r\n\r\nBut, this is missing the 2nd level - package name.\r\n\r\nExpected output\r\n```\r\nhost1, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5,1.02.170\r\nhost2, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T10:50:31Z, 6.0.5.el7_9.5,1.02.170\r\n```",
        "link": "https://stackoverflow.com/questions/77417285/for-a-json-having-details-from-packages-on-a-vm-convert-it-to-csv-retaining-two",
        "title": "For a JSON having details from packages on a VM, convert it to CSV retaining two parent levels"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699078083,
                "creation_date": 1699078083,
                "answer_id": 77420940,
                "question_id": 77420750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you might do it.\r\n```lang-jq\r\nto_entries[]\r\n| .key as $host\r\n| .value\r\n| to_entries[]\r\n| [$host, .key,\r\n   (.value\r\n    | if has(&quot;versions&quot;) then .versions|sort_by(.installdate)|last end \r\n    | .arch, .epoch, .installdate, .version, .release\r\n   )\r\n  ]\r\n| @csv\r\n```\r\nExample output:\r\n```lang-csv\r\n&quot;host1&quot;,&quot;packages.kernel&quot;,&quot;x86_64&quot;,&quot;0&quot;,&quot;1698822019&quot;,&quot;3.10.0&quot;,&quot;1160.102.1.0.1.el7&quot;\r\n&quot;host1&quot;,&quot;packages.yum&quot;,&quot;noarch&quot;,&quot;0&quot;,&quot;1698822027&quot;,&quot;3.4.3&quot;,&quot;168.0.5.el7&quot;\r\n&quot;host2&quot;,&quot;packages.kernel&quot;,&quot;x86_64&quot;,&quot;0&quot;,&quot;1698820106&quot;,&quot;3.10.0&quot;,&quot;1160.102.1.0.1.el7&quot;\r\n&quot;host2&quot;,&quot;packages.yum&quot;,&quot;noarch&quot;,&quot;0&quot;,&quot;1698820115&quot;,&quot;3.4.3&quot;,&quot;168.0.5.el7&quot;\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/JErXemThVwx &quot;Click me!&quot;).",
                "title": "For a JSON having details from packages, with multiple versions, on a VM, convert it to CSV retaining two parent levels"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1699087368,
                "creation_date": 1699087368,
                "answer_id": 77421320,
                "question_id": 77420750,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Adapting the answer from the previous question:\r\n\r\n&gt; I need to choose the element from versions that has the most recent, or highest, installdate.\r\n\r\nYou can use `max_by` for that.\r\n\r\n&gt; For packages that don&#39;t have multiple versions, the one details are picked as is - there are no versions.\r\n\r\nFor that, you can use the error suppression operator `?` in combination wit the alternative operator `//`.\r\n\r\n```sh\r\nkeys_unsorted[] as $host | .[$host]\r\n| keys_unsorted[] as $pkg | .[$pkg]\r\n| (.versions | max_by(.installdate))? // .\r\n| [\r\n    $host, $pkg,\r\n    .arch, .epoch, (.installdate | tonumber | todate), .version, .release\r\n  ]\r\n| join(&quot;, &quot;) # or @csv\r\n```\r\n```\r\nhost1, packages.kernel, x86_64, 0, 2023-11-01T07:00:19Z, 3.10.0, 1160.102.1.0.1.el7\r\nhost1, packages.yum, noarch, 0, 2023-11-01T07:00:27Z, 3.4.3, 168.0.5.el7\r\nhost2, packages.kernel, x86_64, 0, 2023-11-01T06:28:26Z, 3.10.0, 1160.102.1.0.1.el7\r\nhost2, packages.yum, noarch, 0, 2023-11-01T06:28:35Z, 3.4.3, 168.0.5.el7\r\n```\r\n[Demo](https://jqplay.org/s/HGAMFkCbBGF)",
                "title": "For a JSON having details from packages, with multiple versions, on a VM, convert it to CSV retaining two parent levels"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1699087368,
        "creation_date": 1699072247,
        "question_id": 77420750,
        "body_markdown": "Given the following JSON which has details of packages, convert it into CSV. In case of multiple versions, pick latest - based in **installdate**\r\n\r\nSo, the JSON consists of details of each package. Some packages can have multiple versions. These *multiple* versions are held in a nested JSON element `versions`. Each version has a *installdate*. The details in the main part are not necessarily related to the *latest* version.\r\n\r\nI am interested in getting the details of each package&#39;s *latest* version. This implies, for **kernel** package, I need to choose the element from `versions` that has the most recent, or highest, *installdate*. For packages that don&#39;t have multiple versions, the one details are picked as is - there are no versions.\r\n\r\n```\r\n{\r\n  &quot;host1&quot;: {\r\n    &quot;packages.kernel&quot;: {\r\n      &quot;epoch&quot;: &quot;0&quot;,\r\n      &quot;version&quot;: &quot;3.10.0&quot;,\r\n      &quot;release&quot;: &quot;1160.102.1.0.1.el7&quot;,\r\n      &quot;installdate&quot;: &quot;1698822019&quot;,\r\n      &quot;arch&quot;: &quot;x86_64&quot;,\r\n      &quot;versions&quot;: [\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.66.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1654792248&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        },\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.49.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1640181036&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        },\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.102.1.0.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1698822019&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;packages.yum&quot;: {\r\n      &quot;epoch&quot;: &quot;0&quot;,\r\n      &quot;version&quot;: &quot;3.4.3&quot;,\r\n      &quot;release&quot;: &quot;168.0.5.el7&quot;,\r\n      &quot;installdate&quot;: &quot;1698822027&quot;,\r\n      &quot;arch&quot;: &quot;noarch&quot;\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;host2&quot;: {\r\n    &quot;packages.kernel&quot;: {\r\n      &quot;epoch&quot;: &quot;0&quot;,\r\n      &quot;version&quot;: &quot;3.10.0&quot;,\r\n      &quot;release&quot;: &quot;1160.49.1.el7&quot;,\r\n      &quot;installdate&quot;: &quot;1640181036&quot;,\r\n      &quot;arch&quot;: &quot;x86_64&quot;,\r\n      &quot;versions&quot;: [\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.102.1.0.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1698820106&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        },\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.66.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1654792238&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        },\r\n        {\r\n          &quot;epoch&quot;: &quot;0&quot;,\r\n          &quot;version&quot;: &quot;3.10.0&quot;,\r\n          &quot;release&quot;: &quot;1160.49.1.el7&quot;,\r\n          &quot;installdate&quot;: &quot;1640181036&quot;,\r\n          &quot;arch&quot;: &quot;x86_64&quot;\r\n        }\r\n      ]\r\n    },\r\n    &quot;packages.yum&quot;: {\r\n      &quot;epoch&quot;: &quot;0&quot;,\r\n      &quot;version&quot;: &quot;3.4.3&quot;,\r\n      &quot;release&quot;: &quot;168.0.5.el7&quot;,\r\n      &quot;installdate&quot;: &quot;1698820115&quot;,\r\n      &quot;arch&quot;: &quot;noarch&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nExpected output\r\n```\r\nhost1, packages.kernel, x86_64, 0, 1698822019, 3.10.0, 1160.102.1.0.1.el7\r\nhost1, packages.yum, noarch, 0, 1698822027, 3.4.3, 168.0.5.el7\r\nhost2, packages.kernel, x86_64, 0, 1698820106, 3.10.0, 1160.102.1.0.1.el7\r\nhost2, packages.yum, noarch, 0, 1698820115, 3.4.3, 168.0.5.el7\r\n```\r\n\r\n**NOTE**: A similar question was asked earlier by myself - https://stackoverflow.com/q/77417285/6320605",
        "link": "https://stackoverflow.com/questions/77420750/for-a-json-having-details-from-packages-with-multiple-versions-on-a-vm-conver",
        "title": "For a JSON having details from packages, with multiple versions, on a VM, convert it to CSV retaining two parent levels"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1699117763,
                "creation_date": 1699117763,
                "answer_id": 77423049,
                "question_id": 77423031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not entirely clear, what determines on which level you want to collect (e.g. you are using `.result.info` literally), and which fields to collect into (or why `.id` doesn&#39;t get an empty array), but this might help you along your path:\r\n\r\nWith `..` you can recursively scan the document tree, `strings` filters for strings, and `[…]` collects the results into an array. Also, I&#39;ve used `map_values` to replace the values of all fields in the object. Feel free to change this to just the fields you need. You may, for instance, remove empty arrays or change one-item array to the one string itself.\r\n\r\n```sh\r\n.result.info | map_values([.. | strings])\r\n```\r\n```json\r\n{\r\n  &quot;id&quot;: [],\r\n  &quot;name&quot;: [\r\n    &quot;foobar&quot;\r\n  ],\r\n  &quot;route&quot;: [\r\n    &quot;name-1&quot;,\r\n    &quot;name-2&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/WFs-Le8M_Sg)",
                "title": "Using jq to turn array of objects in to a flat array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1699118795,
                "creation_date": 1699118795,
                "answer_id": 77423110,
                "question_id": 77423031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way you could do it that&#39;s pretty close to your attempt.\r\n```lang-jq\r\n.result.info\r\n| {name} + {route: .route|map(.nodename)}\r\n```\r\nExample output:\r\n```lang-json\r\n{\r\n  &quot;name&quot;: &quot;foobar&quot;,\r\n  &quot;route&quot;: [\r\n    &quot;name-1&quot;,\r\n    &quot;name-2&quot;\r\n  ]\r\n}\r\n```\r\nTry it on [jqplay.org](https://jqplay.org/s/w-Z6Y1tpJdp &quot;Click me!&quot;).",
                "title": "Using jq to turn array of objects in to a flat array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699129586,
                "creation_date": 1699129586,
                "answer_id": 77423698,
                "question_id": 77423031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s another variation that is the same as your attempt, plus one step to modify `route`:\r\n\r\n```none\r\n.result.info\r\n| .route |= map(.nodename)\r\n| {name, route}\r\n```",
                "title": "Using jq to turn array of objects in to a flat array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1699131423,
        "creation_date": 1699117492,
        "last_edit_date": 1699131423,
        "question_id": 77423031,
        "body_markdown": "Using jq, I&#39;d like to to flatten a (nested) array of objects to an array of strings.\r\n\r\ne.g. given the input\r\n\r\n``` lang-json\r\n{\r\n  &quot;message-id&quot;: 1,\r\n  &quot;result&quot;: {\r\n    &quot;info&quot;: {\r\n      &quot;id&quot;: 1,\r\n      &quot;name&quot;: &quot;foobar&quot;,\r\n      &quot;route&quot;: [\r\n        {\r\n          &quot;nodeid&quot;: 1,\r\n          &quot;nodename&quot;: &quot;name-1&quot;\r\n        },\r\n        {\r\n          &quot;nodeid&quot;: 2,\r\n          &quot;nodename&quot;: &quot;name-2&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d like to turn it in to \r\n``` lang-json\r\n{\r\n  &quot;name&quot;: &quot;foobar&quot;,\r\n  &quot;route&quot;: [\r\n    &quot;name-1&quot;,\r\n    &quot;name-2&quot;\r\n  ]\r\n}\r\n```\r\n\r\nBut am struggling with flattening the `route` node - getting no further than \r\n\r\n     .result.info | { name: .name, route: .route }\r\n\r\nwhich essentially leaves the route node unchanged. This is probably straightforward, but nonetheless currently eluding me.",
        "link": "https://stackoverflow.com/questions/77423031/using-jq-to-turn-array-of-objects-in-to-a-flat-array",
        "title": "Using jq to turn array of objects in to a flat array"
    },
    {
        "tags": [
            "json",
            "jq",
            "kubectl",
            "jsonpath"
        ],
        "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": 3,
                "creation_date": 1699182024,
                "post_id": 77424571,
                "comment_id": 136496911,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1699184555,
                "post_id": 77424571,
                "comment_id": 136497140,
                "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": 1699203219,
                "post_id": 77424571,
                "comment_id": 136499177,
                "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": 1,
                "creation_date": 1699242154,
                "post_id": 77424571,
                "comment_id": 136502515,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1704284277,
        "creation_date": 1699153331,
        "last_edit_date": 1704284277,
        "question_id": 77424571,
        "body_markdown": "I have a lot of outputs from kubectl get XXXX -ojsonpath and I am using jq to parse and making things easy to read.  I am trying to find a way to parse and expand annoations if its an json object. \r\n\r\nCurrently I am writing out the annotations as (looped on the number of array)\r\n\r\n```\r\njq -r &#39;.items[&#39;${i}&#39;].metadata.annotations | (to_entries[] | &quot;\\(.key)=\\(.value)&quot;) | select(length &gt;0)&#39;\r\n```\r\n\r\n\r\nAnd I can see that sometimes some annotation is just a value and at other times its json.  I want to be able to expand out the json annotations to make it more readable\r\n\r\nexpand out the json. for example some of the annotations look like\r\n```\r\ntest.bob.k8s.elastic.co/token=622fb4bd-e5f9-46e5-a73b-80b9d0fad43a\r\nkubectl.kubernetes.io/last-applied-configuration={&quot;apiVersion&quot;:&quot;agent.k8s.elastic.co/v1alpha1&quot;,&quot;kind&quot;:&quot;Agent&quot;,&quot;metadata&quot;:{&quot;annotations&quot;:{},&quot;name&quot;:&quot;test-agent&quot;,&quot;namespace&quot;:&quot;default&quot;},&quot;spec&quot;:{&quot;daemonSet&quot;:{&quot;podTemplate&quot;:{&quot;spec&quot;:{&quot;automountServiceAccountToken&quot;:true,&quot;containers&quot;:[{&quot;command&quot;:[&quot;bash&quot;,&quot;-c&quot;,&quot;#!/usr/bin/env bash\\nset -e\\nif [[ -f /mnt/test-internal/test-association/default/bob/certs/ca.crt ]]; then\\n  cp /mnt/test-internal/test-association/default/bob/certs/ca.crt /usr/local/share/ca-certificates\\n  update-ca-certificates\\nfi\\n/usr/bin/tini -- /usr/local/bin/docker-entrypoint -e\\n&quot;],&quot;name&quot;:&quot;agent&quot;}],&quot;securityContext&quot;:{&quot;runAsUser&quot;:0},&quot;serviceAccountName&quot;:&quot;test-agent&quot;}}},&quot;testServerRef&quot;:{&quot;name&quot;:&quot;test-server&quot;},&quot;testRef&quot;:{&quot;name&quot;:&quot;bob&quot;},&quot;mode&quot;:&quot;test&quot;,&quot;version&quot;:&quot;1.10.2&quot;}}\r\n```\r\n\r\nI want to expand out kubectl.kubernetes.io/last-applied-configuration and other annotations that are json\r\n",
        "link": "https://stackoverflow.com/questions/77424571/jq-parsing-from-kubectl-ojsonpath-output-for-annotations-that-are-json",
        "title": "jq parsing from kubectl -ojsonpath output for annotations that are json"
    },
    {
        "tags": [
            "json",
            "syntax",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699350810,
                "last_edit_date": 1699350810,
                "creation_date": 1699349423,
                "answer_id": 77437037,
                "question_id": 77436995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ```\r\n&gt; jq &#39;.lemma, .phonetic, .pos, .intransitive, .root.radicals, .glosses.[].gloss&#39;`\r\n&gt; ```\r\n&gt; throws an error in Ubuntu but not at jqplay.org\r\n\r\nYour Ubuntu machine is probably not using jq 1.7, which is the version currently running on [jqplay.org](https://jqplay.org/). This version introduced a new syntax, which you are using with `.glosses.[]`. From the [release info](https://github.com/jqlang/jq/releases):\r\n\r\n&gt; Allow dot for chained value iterator `.[]`, `.[]?` [@wader](https://github.com/wader) [#2650](https://github.com/jqlang/jq/pull/2650)\r\n&gt; ```sh\r\n&gt; $ jq -n &#39;{&quot;a&quot;: [123]} | .a[]&#39;\r\n&gt; 123\r\n&gt; # now this also works\r\n&gt; $ jq -n &#39;{&quot;a&quot;: [123]} | .a.[]&#39;\r\n&gt; 123\r\n&gt; ```\r\n\r\nThus, change your approach to use `.glosses[]` instead:\r\n\r\n```sh\r\njq &#39;.lemma, .phonetic, .pos, .intransitive, .root.radicals, .glosses[].gloss&#39;\r\n```\r\n",
                "title": "Convert .json to .csv"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1699350036,
                "last_edit_date": 1699350036,
                "creation_date": 1699349692,
                "answer_id": 77437070,
                "question_id": 77436995,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To obtain the desired csv output:\r\n\r\n```bash\r\n$ jq -r &#39;&quot;\\(._id[]), \\(.lemma), \\(.phonetic), \\(.pos), \\(.intransitive), \\(.root.radicals), \\&quot;\\([.glosses[].gloss] | join(&quot;,&quot;))\\&quot;&quot;&#39; file\r\n5200a366e36f237975000783, badbad, bɐdbɐt, VERB, true, b-d-b-d, &quot;to fornicate,to cough a lot&quot;",
                "title": "Convert .json to .csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1699579763,
        "creation_date": 1699349150,
        "last_edit_date": 1699579763,
        "question_id": 77436995,
        "body_markdown": "jq version jq-1.6 on Ubuntu 22.04.2 LTE\r\n\r\nLooking to convert large .json file to .csv\r\n\r\njson example:\r\n\r\n```\r\n{&quot;_id&quot;:{&quot;$oid&quot;:&quot;5200a366e36f237975000783&quot;},&quot;derived_form&quot;:{&quot;$numberInt&quot;:&quot;1&quot;},&quot;intransitive&quot;:true,&quot;lemma&quot;:&quot;badbad&quot;,&quot;phonetic&quot;:&quot;bɐdbɐt&quot;,&quot;pos&quot;:&quot;VERB&quot;,&quot;root&quot;:{&quot;radicals&quot;:&quot;b-d-b-d&quot;},&quot;sources&quot;:[&quot;Spagnol2011&quot;,&quot;Falzon2013&quot;],&quot;glosses&quot;:[{&quot;gloss&quot;:&quot;to fornicate&quot;,&quot;examples&quot;:[]},{&quot;gloss&quot;:&quot;to cough a lot&quot;,&quot;examples&quot;:[]}],&quot;norm_freq&quot;:{&quot;$numberDouble&quot;:&quot;0.0&quot;}}\r\n```\r\nHow do I convert to .csv:\r\n\r\n```5200a366e36f237975000783, badbad, bɐdbɐt, VERB, true, b-d-b-d, &quot;to fornicate, to cough a lot&quot;```\r\n\r\n```\r\njq &#39;.lemma, .phonetic, .pos, .intransitive, .root.radicals, .glosses.[].gloss&#39;\r\n```\r\nthrows an error in Ubuntu but not at jqplay.org",
        "link": "https://stackoverflow.com/questions/77436995/convert-json-to-csv",
        "title": "Convert .json to .csv"
    },
    {
        "tags": [
            "jenkins",
            "curl",
            "jq",
            "gitlab-ci-runner"
        ],
        "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": 1699353295,
                "post_id": 77437463,
                "comment_id": 136518102,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29501267,
                    "reputation": 21,
                    "user_id": 22608227,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/ACg8ocI4kj_Vo8DB0QJDY3rV0rV27l9j4D3KRsJFrOrsrsrH=k-s256",
                    "display_name": "Rayan Denver",
                    "link": "https://stackoverflow.com/users/22608227/rayan-denver"
                },
                "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": 1699355537,
                "post_id": 77437463,
                "comment_id": 136518576,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1703066672,
                "creation_date": 1703066672,
                "answer_id": 77690681,
                "question_id": 77437463,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you have your response from api in JSON format, the easiest way is to parse the response, and get value of `status` key. For this, you will need to install Pipeline Utility Steps plugin to Jenkins.\r\n\r\n \r\n\r\n    stage(&#39;Get Pipeline Status&#39;) {\r\n        steps {\r\n            script {\r\n                // Run a curl command to get pipeline details from GitLab\r\n                def pipelineResponse = sh(\r\n                    script: &quot;curl --insecure --header &#39;PRIVATE-TOKEN: my-token&#39; https://mygitlab.domain/api/v4/projects/229/pipelines/latest&quot;,\r\n                    returnStatus: true)\r\n\r\n                def jsonResponse = readJSON text: pipelineResponse\r\n                def status = jsonResponse[&#39;status&#39;]\r\n    \r\n                if (status == &#39;success&#39;) {\r\n                    echo &quot;Pipeline succeeded&quot;\r\n                } else {\r\n                    echo &quot;Pipeline did not succeed&quot;\r\n                }\r\n            }\r\n        }\r\n    }",
                "title": "Get a gitlab-ci pipeline execution status with curl in jenkins pipeline stage"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1703066672,
        "creation_date": 1699353069,
        "last_edit_date": 1699355468,
        "question_id": 77437463,
        "body_markdown": "In my jenkins pipeline, I have a stage that should trigger a gitlab ci pipeline with curl, it works well. Now I want to send a second curl command to ask gitlab api for the status of last pipeline (Iam looking for status: success) to move to next jenkins pipeline stage\r\n\r\nthis is my curl command:\r\n\r\n```\r\nstage(&#39;Get Pipeline Status&#39;) {\r\n\tsteps {\r\n\t\tscript {\r\n\t\t\t// Run a curl command to get pipeline details from GitLab\r\n\t\t\tdef pipelineStatus = sh(\r\n\t\t\t\tscript: &quot;curl --insecure --header &#39;PRIVATE-TOKEN: my-token&#39; https://mygitlab.domain/api/v4/projects/229/pipelines/latest&quot;,\r\n\t\t\t\treturnStatus: true)//.trim()                                      \r\n\r\n\t\t\tdef status = sh(script: &quot;&quot;&quot;\r\n\t\t\t\techo &quot;&#39;$pipelineStatus&#39; | jq -r &#39;.status&#39;&quot;, returnStatus: true)//.trim()\r\n\t\t\t\r\n\t\t\tif (status == &#39;success&#39;) {\r\n\t\t\t\techo &quot;Pipeline succeeded&quot;\r\n\t\t\t} else {\r\n\t\t\t\techo &quot;Pipeline did not succeed&quot;\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n}\r\n```\r\nwhen use .trim() I get this error (so I comment it):\r\n\r\n```\r\nAlso:   org.jenkinsci.plugins.workflow.actions.ErrorAction$ErrorId: 69e61b29-b180-44e9-a18f-b06b1a84f99a\r\n10:36:18  hudson.remoting.ProxyException: groovy.lang.MissingMethodException: No signature of method: java.lang.Integer.trim() is applicable for argument types: () values: []\r\n10:36:18  Possible solutions: wait(), grep(), wait(long), print(java.lang.Object), print(java.io.PrintWriter), div(java.lang.Number)\r\n```\r\nI can retreive the output result from gitlab with my curl command like:\r\n\r\n```\r\n{&quot;id&quot;:1664,&quot;iid&quot;:19,&quot;project_id&quot;:229,&quot;sha&quot;:&quot;9e70fd49d14e86ccd6091addf394ded51d22ab50&quot;,&quot;ref&quot;:&quot;main&quot;,&quot;status&quot;:&quot;success&quot;,&quot;source&quot;:&quot;trigger&quot;,&quot;created_at&quot;:&quot;2023-11-06T15:41:36.238Z&quot;,&quot;updated_at&quot;:&quot;2023-11-06T15:41:38.854Z&quot;,&quot;web_url&quot;:&quot;https://mygitlab.domain/test-ci/-/pipelines/1664&quot;,&quot;before_sha&quot;:&quot;0000000000000000000000000000000000000000&quot;,&quot;tag&quot;:false,&quot;yaml_errors&quot;:null,&quot;user&quot;:{&quot;id&quot;:98,&quot;username&quot;:&quot;907802&quot;,&quot;name&quot;:&quot;myname&quot;,&quot;state&quot;:&quot;active&quot;,&quot;locked&quot;:false,&quot;avatar_url&quot;:&quot;https://mygitlab.domain/uploads/-/system/user/avatar/98/avatar.png&quot;,&quot;web_url&quot;:&quot;https://mygitlab.domain/907802&quot;},&quot;started_at&quot;:&quot;2023-11-06T15:41:37.695Z&quot;,&quot;finished_at&quot;:&quot;2023-11-06T15:41:38.841Z&quot;,&quot;committed_at&quot;:null,&quot;duration&quot;:1,&quot;queued_duration&quot;:1,&quot;coverage&quot;:null,&quot;detailed_status&quot;:{&quot;icon&quot;:&quot;status_success&quot;,&quot;text&quot;:&quot;Passed&quot;,&quot;label&quot;:&quot;passed&quot;,&quot;group&quot;:&quot;success&quot;,&quot;tooltip&quot;:&quot;passed&quot;,&quot;has_details&quot;:false,&quot;details_path&quot;:&quot;/907802/test-ci/-/pipelines/1664&quot;,&quot;illustration&quot;:null,&quot;favicon&quot;:&quot;/assets/ci_favicons/favicon_status_success-8451333011eee8ce9f2ab25dc487fe24a8758c694827a582f17f42b0a90446a2.png&quot;},&quot;name&quot;:null}\r\n```\r\nBut I want to get just &quot;status&quot;:&quot;success&quot; part to make a test, if status=success then I execute the next jenkins pipeline stage. but what I made with &quot;jq&quot; don&#39;t work and I think that the &quot;echo &quot;$pipelineStatus&#39;&quot; is equal to &quot;0&quot; !\r\n\r\nthis is the error:\r\n\r\n```\r\n10:36:18  [Pipeline] sh\r\n10:36:18  + echo 0\r\n10:36:18  + jq -r status\r\n10:36:18  jq: error: status/0 is not defined at &lt;top-level&gt;, line 1:\r\n10:36:18  status\r\n10:36:18  jq: 1 compile error\r\n```\r\nHow can I do it correctly, I take all working solutions , the goal is to have a report for my first curl command to know that my gitlab ci pipeline is executed correctly to move to next stage.\r\nThank you very much in advance\r\n",
        "link": "https://stackoverflow.com/questions/77437463/get-a-gitlab-ci-pipeline-execution-status-with-curl-in-jenkins-pipeline-stage",
        "title": "Get a gitlab-ci pipeline execution status with curl in jenkins pipeline stage"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8422116,
                    "reputation": 81,
                    "user_id": 6320605,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OuxoA.jpg?s=256",
                    "display_name": "Jojo Thomas",
                    "link": "https://stackoverflow.com/users/6320605/jojo-thomas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699363422,
                "post_id": 77438555,
                "comment_id": 136520019,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1699365734,
                "last_edit_date": 1699365734,
                "creation_date": 1699364686,
                "answer_id": 77438721,
                "question_id": 77438555,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could slurp the input file (using the `--slurp` (or `-s`) flag) to get an array of stream items, to then partition that into two-item long subarrays using `_nwise`:\r\n```sh\r\n_nwise(2) | . as [$name] | last | to_entries[] as {$key, $value}\r\n| [$name, $key, $value.version, $value.publisher, $value.installdate]\r\n| join(&quot;, &quot;)  # or @csv\r\n```\r\n[Demo](https://jqplay.org/s/1y_V6grjq0w)\r\n\r\nHowever, given that\r\n\r\n&gt; The JSON output is coming from a Chef knife search output knife search node &#39;os:windows&#39; -F json | jq &#39;.rows[]&#39; | jq &#39;.name, .automatic.packages&#39;\r\n\r\nit seems more reasonable to not de-structure the items in the first place. Your jq filter suggests the following (original) structure:\r\n\r\n```json\r\n{\r\n  &quot;rows&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;host1&quot;,\r\n      &quot;automatic&quot;: {\r\n        &quot;packages&quot;: {\r\n          &quot;PuTTY release 0.77 (64-bit)&quot;: {…},\r\n          &quot;Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005&quot;: {…}\r\n        }\r\n      }\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;host2&quot;,\r\n      &quot;automatic&quot;: {\r\n        &quot;packages&quot;: {\r\n          &quot;Notepad++ (64-bit x64)&quot;: {…},\r\n          &quot;Oracle Windows VirtIO Drivers&quot;: {…},\r\n          &quot;ManageEngine UEMS - Agent&quot;: {…}\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nFrom here you only need the same iteration as with the previous solutions:\r\n```sh\r\n.rows[] | . as {$name} | .automatic.packages\r\n| keys_unsorted[] as $pkg | .[$pkg]\r\n| [$name, $pkg, .version, .publisher, .installdate]\r\n| join(&quot;, &quot;)  # or @csv\r\n```\r\n```\r\nhost1, PuTTY release 0.77 (64-bit), 0.77.0.0, Simon Tatham, 20220916\r\nhost1, Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005, 12.0.21005, Microsoft Corporation, 20210816\r\nhost2, Notepad++ (64-bit x64), 8.4.2, Notepad++, 20230517\r\nhost2, Oracle Windows VirtIO Drivers, 1.1.3, Oracle Corporation, 20200316\r\nhost2, ManageEngine UEMS - Agent, 11.2.2315.5.W, ZohoCorp, 20230601\r\n```\r\n[Demo](https://jqplay.org/s/A0T4UNvDsrP)",
                "title": "For a JSON having details from packages on a Windows VM, convert it to CSV retaining two parent levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1699365734,
        "creation_date": 1699363379,
        "question_id": 77438555,
        "body_markdown": "Given the following JSON which has details of packages - with the host name available separately, convert it into CSV.\r\n\r\n\r\n```\r\n&quot;host1&quot;\r\n{\r\n  &quot;PuTTY release 0.77 (64-bit)&quot;: {\r\n    &quot;version&quot;: &quot;0.77.0.0&quot;,\r\n    &quot;publisher&quot;: &quot;Simon Tatham&quot;,\r\n    &quot;installdate&quot;: &quot;20220916&quot;\r\n  },\r\n  &quot;Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005&quot;: {\r\n    &quot;version&quot;: &quot;12.0.21005&quot;,\r\n    &quot;publisher&quot;: &quot;Microsoft Corporation&quot;,\r\n    &quot;installdate&quot;: &quot;20210816&quot;\r\n  }\r\n}\r\n&quot;host2&quot;\r\n{\r\n  &quot;Notepad++ (64-bit x64)&quot;: {\r\n    &quot;version&quot;: &quot;8.4.2&quot;,\r\n    &quot;publisher&quot;: &quot;Notepad++&quot;,\r\n    &quot;installdate&quot;: &quot;20230517&quot;\r\n  },\r\n  &quot;Oracle Windows VirtIO Drivers&quot;: {\r\n    &quot;version&quot;: &quot;1.1.3&quot;,\r\n    &quot;publisher&quot;: &quot;Oracle Corporation&quot;,\r\n    &quot;installdate&quot;: &quot;20200316&quot;\r\n  },\r\n  &quot;ManageEngine UEMS - Agent&quot;: {\r\n    &quot;version&quot;: &quot;11.2.2315.5.W&quot;,\r\n    &quot;publisher&quot;: &quot;ZohoCorp&quot;,\r\n    &quot;installdate&quot;: &quot;20230601&quot;\r\n  }\r\n}\r\n```\r\n\r\nExpected output\r\n```\r\nhost1, PuTTY release 0.77 (64-bit), 0.77.0.0, Simon Tatham, 20220916\r\nhost1, Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005, 12.0.21005, Microsoft Corporation, 20210816\r\nhost2, Notepad++ (64-bit x64), 8.4.2, Notepad++, 20230517\r\nhost2, Oracle Windows VirtIO Drivers, 1.1.3, Oracle Corporation, 20200316\r\nhost2, ManageEngine UEMS - Agent, 11.2.2315.5.W, ZohoCorp,20230601\r\n```\r\n\r\nNOTE: A similar question was asked earlier by myself - [For a JSON having details from packages on a VM, convert it to CSV retaining two parent levels][1]\r\n\r\n\r\n  [1]: https://stackoverflow.com/q/77417285/6320605",
        "link": "https://stackoverflow.com/questions/77438555/for-a-json-having-details-from-packages-on-a-windows-vm-convert-it-to-csv-retai",
        "title": "For a JSON having details from packages on a Windows VM, convert it to CSV retaining two parent levels"
    },
    {
        "tags": [
            "jq",
            "flatpak",
            "flatpak-builder"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699372001,
                "last_edit_date": 1699372001,
                "creation_date": 1699365139,
                "answer_id": 77438781,
                "question_id": 77438599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The issue lay with ./configure not having been provided with the following option `./configure --with-oniguruma=builtin --prefix=/app --libdir=/app/lib`. The corrected json is\r\n\r\n```json\r\n{\r\n        &quot;app-id&quot;:&quot;com.github.MaxBrandtner.Test&quot;,\r\n        &quot;runtime&quot;:&quot;org.gnome.Platform&quot;,\r\n        &quot;runtime-version&quot;:&quot;44&quot;,\r\n        &quot;sdk&quot;:&quot;org.gnome.Sdk&quot;,\r\n        &quot;command&quot;:&quot;Test&quot;,\r\n        &quot;modules&quot;:[\r\n                {\r\n                        &quot;name&quot;:&quot;Test&quot;,\r\n                        &quot;buildsystem&quot;:&quot;meson&quot;,\r\n                        &quot;sources&quot;:[\r\n                                {\r\n                                &quot;type&quot;:&quot;dir&quot;,\r\n                                &quot;path&quot;:&quot;.&quot;\r\n                                }\r\n                        ]\r\n                },\r\n                {\r\n                        &quot;name&quot;:&quot;jq&quot;,\r\n                        &quot;buildsystem&quot;:&quot;simple&quot;,\r\n                        &quot;sources&quot;:[\r\n                                {\r\n                                        &quot;type&quot;:&quot;git&quot;,\r\n                                        &quot;url&quot;:&quot;https://github.com/jqlang/jq&quot;\r\n                                }\r\n                        ],\r\n                        &quot;build-commands&quot;:[\r\n                                &quot;git submodule update --init&quot;,\r\n                                &quot;autoreconf -i&quot;,\r\n                                &quot;./configure --with-oniguruma=builtin --prefix=/app --libdir=/app/lib&quot;,\r\n                                &quot;make -j8&quot;,\r\n                                &quot;make check&quot;,\r\n                                &quot;make install&quot;\r\n                        ]\r\n                }\r\n\r\n        ]\r\n}\r\n```",
                "title": "add libjq as a module in flatpak"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1699372001,
        "creation_date": 1699363658,
        "last_edit_date": 1699363822,
        "question_id": 77438599,
        "body_markdown": "I initially created a simple flatpak manifest , but then the following error occured: `PrayerApp: error while loading shared libraries: libjq.so.1: cannot open shared object file: No such file or directory` \r\n\r\nI then tried to add jq as a module, like this:\r\n```json\r\n{\r\n  &quot;app-id&quot;: &quot;com.github.MaxBrandtner.Test&quot;,\r\n  &quot;runtime&quot;: &quot;org.gnome.Platform&quot;,\r\n  &quot;runtime-version&quot;: &quot;44&quot;,\r\n  &quot;sdk&quot;: &quot;org.gnome.Sdk&quot;,\r\n  &quot;command&quot;: &quot;Test&quot;,\r\n  &quot;modules&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Test&quot;,\r\n      &quot;buildsystem&quot;: &quot;meson&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;dir&quot;,\r\n          &quot;path&quot;: &quot;.&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;jq&quot;,\r\n      &quot;buildsystem&quot;: &quot;simple&quot;,\r\n      &quot;sources&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;git&quot;,\r\n          &quot;url&quot;: &quot;https://github.com/jqlang/jq&quot;\r\n        }\r\n      ],\r\n      &quot;build-commands&quot;: [\r\n        &quot;git submodule update --init&quot;,\r\n        &quot;autoreconf -i&quot;,\r\n        &quot;./configure --with-oniguruma=builtin&quot;,\r\n        &quot;make -j8&quot;,\r\n        &quot;make check&quot;,\r\n        &quot;make install&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNormally you would call `sudo make install`, but since sudo isn&#39;t an available command in the flatpak-build environment I tried `make install` instead.\r\n\r\nBut the following flatpak manifest failed with the following error:\r\n```python\r\nmake[4]: Entering directory &#39;/run/build/jq/modules/oniguruma/src&#39;\r\n /usr/bin/mkdir -p &#39;/usr/local/lib&#39;\r\n/usr/bin/mkdir: cannot create directory ‘/usr/local’: Read-only file system\r\nmake[4]: *** [Makefile:478: install-libLTLIBRARIES] Error 1\r\nmake[4]: Leaving directory &#39;/run/build/jq/modules/oniguruma/src&#39;\r\nmake[3]: *** [Makefile:722: install-am] Error 2\r\nmake[3]: Leaving directory &#39;/run/build/jq/modules/oniguruma/src&#39;\r\nmake[2]: *** [Makefile:499: install-recursive] Error 1\r\nmake[2]: Leaving directory &#39;/run/build/jq/modules/oniguruma&#39;\r\nmake[1]: *** [Makefile:1189: install-recursive] Error 1\r\nmake[1]: Leaving directory &#39;/run/build/jq&#39;\r\nmake: *** [Makefile:1710: install] Error 2\r\nError: module jq: Child process exited with code 2\r\n```\r\n\r\nHow can I configure the manifest file correctly. (Note I don&#39;t know if I need to do the same to for libcurl)? I know I still need to add the wayland and x11 socket as well as give networking permissions. (I am using -ljq as a linker option instead of using the libjq pkgconfig, because the package config has been added in version 1.7 and many systems are still on jq 1.6)(The program is written in c and a libadwaita app).\r\n",
        "link": "https://stackoverflow.com/questions/77438599/add-libjq-as-a-module-in-flatpak",
        "title": "add libjq as a module in flatpak"
    },
    {
        "tags": [
            "json",
            "docker",
            "docker-compose",
            "yaml",
            "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": 2,
                "creation_date": 1699443837,
                "post_id": 77440643,
                "comment_id": 136531378,
                "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": 1699514504,
                "post_id": 77440643,
                "comment_id": 136542096,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1699442113,
        "creation_date": 1699381888,
        "last_edit_date": 1699442113,
        "question_id": 77440643,
        "body_markdown": "Here is my docker-compose beginning. \r\n\r\n```\r\nservices:\r\n  theses-api-diffusion:\r\n    container_name: theses-api-diffusion\r\n    environment:\r\n      CHASSEAUXLIVRES_KEY: ?key=3a072b56267e9c3ba4b6f3ff66f7\r\n      CHASSEAUXLIVRES_URL: http://www.chasse-aux-livres.fr/api/v1/price/\r\n      JAVA_OPTS: -Doracle.jdbc.timezoneAsRegion=false -Duser.timezone=CEST\r\n      SERVER_PORT: &quot;8992&quot;\r\n      SPRING_DATASOURCE_PASSWORD: PORTAIL\r\n      SPRING_DATASOURCE_URL: jdbc:oracle:thin:@//orpins-p-scan.v110.abes.fr:1521/THESES\r\n      SPRING_DATASOURCE_USERNAME: PORTAIL\r\n      TEL_HOSTSWORD: api.archives-ouvertes.fr\r\n      TEL_PASSWORD: dedt@sa\r\n      TEL_USERID: star_abes\r\n      THESES_PATH_LOCAL: /starstock/\r\n  theses-api-recherche:\r\n...\r\n```\r\nI&#39;d like to convert environment variables containing the word **KEY** or **PASSWORD** to a secret for each docker service, and move the **environment** to **env_file** like following:\r\n\r\n```\r\nservices:\r\n  theses-api-diffusion:\r\n    cpus: 10\r\n    container_name: theses-api-diffusion\r\n    env_file: theses-api-diffusion.env\r\n    secrets:\r\n      - CHASSEAUXLIVRES_KEY\r\n      - TEL_PASSWORD\r\n      - SPRING_DATASOURCE_PASSWORD\r\nsecrets:\r\n  CHASSEAUXLIVRES_KEY:\r\n    file: CHASSEAUXLIVRES_KEY.txt\r\n  TEL_PASSWORD:\r\n    file: TEL_PASSWORD.txt\r\n  SPRING_DATASOURCE_PASSWORD:\r\n    file: SPRING_DATASOURCE_PASSWORD.txt\r\n```\r\nI tried to manipulate json object with jq, and I managed to generate &#39;&#39;.txt&#39;&#39; files and to insert secrets object.\r\n```\r\nsecrets:\r\n  CHASSEAUXLIVRES_KEY:\r\n    file: SPRING_DATASOURCE_PASSWORD.txt\r\n  TEL_PASSWORD:\r\n    file: TEL_PASSWORD.txt\r\n  SPRING_DATASOURCE_PASSWORD:\r\n    file: SPRING_DATASOURCE_PASSWORD.txt\r\n```\r\nBut I failed to create the secrets for each service:\r\n```\r\n    secrets:\r\n      - CHASSEAUXLIVRES_KEY\r\n      - TEL_PASSWORD\r\n      - SPRING_DATASOURCE_PASSWORD\r\n```\r\nI could use bash commands but I do want to do such a thing with manipulating json using **jq** \r\nThank you for helping.",
        "link": "https://stackoverflow.com/questions/77440643/converting-some-docker-compose-environment-variables-to-secrets-with-jq",
        "title": "Converting some docker-compose environment variables to secrets with jq"
    },
    {
        "tags": [
            "json",
            "dockerfile",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1699444864,
                "post_id": 77445297,
                "comment_id": 136531524,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699445163,
                "post_id": 77445297,
                "comment_id": 136531578,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699521507,
                "post_id": 77445297,
                "comment_id": 136543328,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1699514465,
                "creation_date": 1699514465,
                "answer_id": 77451182,
                "question_id": 77445297,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easiest is with a POSIX shell and a variable:\r\n\r\n```\r\njq --arg rand &quot;$(openssl rand -base64 12)&quot; &#39;.things[0].field_2 = $rand&#39;\r\n```\r\n\r\nYour original code did not work because single quotes prevent command substitution.",
                "title": "Change JSON field value in Dockerfile"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1699514465,
        "creation_date": 1699444404,
        "last_edit_date": 1699460578,
        "question_id": 77445297,
        "body_markdown": "I have a &quot;config.json&quot; file that i use inside a Dockerfile to set some specific parameter.\r\n\r\nI need to replace the value of a field of this file with a random string.\r\nSuppose the file structure is something like the code shown below and the field value to replace is the one of &quot;field_2&quot;\r\n\r\n    { \r\n      ...\r\n      &quot;things&quot;:[{\r\n        &quot;field_1&quot;:&quot;val_1&quot;,\r\n        &quot;field_2&quot;:&quot;val_2&quot;\r\n       }],\r\n       ...\r\n    }\r\n\r\nI&#39;ve tryed with &quot;jq&quot; but it didn&#39;t seem to work, I&#39;ll provide my code below:\r\n\r\n    \r\n    # Copy File\r\n    COPY /config.json /app/config.json\r\n    \r\n    # Install jq\r\n    RUN apk add jq\r\n\r\n    # Use jq to update the value in config.json\r\n    RUN jq &#39;.things[0].field_2= &quot;$(openssl rand -base64 12)&quot;&#39; /app/config.json &gt; /app/new_config.json \r\n    RUN mv /app/new_config.json /app/config.json\r\n\r\n\r\nCould you please help me with this issue?\r\nThanks in advance!\r\n\r\nFabio\r\n",
        "link": "https://stackoverflow.com/questions/77445297/change-json-field-value-in-dockerfile",
        "title": "Change JSON field value in Dockerfile"
    },
    {
        "tags": [
            "json",
            "jq",
            "export-to-csv"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699451313,
                "last_edit_date": 1699451313,
                "creation_date": 1699447801,
                "answer_id": 77445680,
                "question_id": 77445623,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This will help you get the desired CSV format:\r\n```\r\njq -r &#39;.[] | &quot;\\(.id),\\(.details.prod),\\(.details.etype),\\(.accounts[].bankName)&quot;&#39;\r\n```\r\nyou can build further on it to get all desired values..\r\n\r\nNote: For a valid CSV though, you might need to add double-quotes around some values, like strings\r\n\r\nto parse multiple JSON entries, they are expected to be in an array:\r\n```json\r\n[\r\n{\r\n    &quot;id&quot;: &quot;id123&quot;,\r\n    &quot;details&quot;: {\r\n        &quot;prod&quot;: &quot;prod123&quot;,\r\n        &quot;etype&quot;: &quot;type1&quot;\r\n    },\r\n    &quot;accounts&quot;: [\r\n        {\r\n.....\r\n        }\r\n     ]\r\n},\r\n{\r\n    &quot;id&quot;: &quot;id124&quot;,\r\n    &quot;details&quot;: {\r\n        &quot;prod&quot;: &quot;prod124&quot;,\r\n        &quot;etype&quot;: &quot;type1&quot;\r\n    },\r\n    &quot;accounts&quot;: [\r\n        {\r\n.....\r\n        }\r\n     ]\r\n}\r\n]",
                "title": "Parse multilevel json into a csv using jq tool in unix"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699482520,
                "creation_date": 1699482520,
                "answer_id": 77449359,
                "question_id": 77445623,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can save the outer data values in variables and get down progressively to the leaf nodes :\r\n\r\n```\r\njq -r &#39;&quot;id,prod,etype,bankName,accountType,openingBalance,fromDate,toDate,dateTime,description,amount,bal,type,accountid&quot;,\r\n    ( . as {$id,$accountid}\r\n    | .details as {$prod, $etype}\r\n    | .accounts[]\r\n    | . as { $bankName,$accountType,$openingBalance,$fromDate,$toDate }\r\n    | .transactions[]\r\n    | [$id,$prod,$etype,$bankName,$accountType,$openingBalance,$fromDate,$toDate,.dateTime,.description,.amount,.bal? // .balanceAfterTransaction,.type,$accountid]\r\n    | join(&quot;,&quot;))&#39; input.json\r\n```",
                "title": "Parse multilevel json into a csv using jq tool in unix"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699488611,
                "creation_date": 1699488611,
                "answer_id": 77449690,
                "question_id": 77445623,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution uses jq&#39;s `@csv` filter for robustness, and avoids redundancy by using arrays of key names\r\nthat can also be used for generating the header row.  The fiddle with .bal uses jq&#39;s `//=` assignment operator in a way that avoids interfering with the main thrust of the program.\r\n```\r\n[&quot;id&quot;,&quot;prod&quot;,&quot;etype&quot;] as $idHdrs\r\n| [&quot;bankName&quot;, &quot;accountType&quot;, &quot;openingBalance&quot;, &quot;fromDate&quot;, &quot;toDate&quot;] as $accountHdrs\r\n| [&quot;dateTime&quot;, &quot;description&quot;, &quot;amount&quot;, &quot;bal&quot;, &quot;type&quot;] as $txHdrs\r\n| $idHdrs + $accountHdrs + $txHdrs + [&quot;accountid&quot;],   # the header row\r\n  ( . as {$id,$accountid}\r\n    | .details as {$prod, $etype}\r\n    | .accounts[]\r\n    | [.[$accountHdrs[]]] as $accounts\r\n    | .transactions[]\r\n    | .bal //= .balanceAfterTransaction  # fiddle\r\n    | [.[$txHdrs[]]] as $transactions\r\n    | [$id,$prod,$etype] + $accounts + $transactions + [$accountid] )\r\n| @csv\r\n```\r\n\r\nOutput:\r\n```\r\n&quot;id&quot;,&quot;prod&quot;,&quot;etype&quot;,&quot;bankName&quot;,&quot;accountType&quot;,&quot;openingBalance&quot;,&quot;fromDate&quot;,&quot;toDate&quot;,&quot;dateTime&quot;,&quot;description&quot;,&quot;amount&quot;,&quot;bal&quot;,&quot;type&quot;,&quot;accountid&quot;\r\n&quot;id123&quot;,&quot;prod123&quot;,&quot;type1&quot;,&quot;bank123&quot;,&quot;account123&quot;,&quot;bal123&quot;,&quot;2023-01-01&quot;,&quot;2023-01-01&quot;,&quot;2020-12-01&quot;,&quot;a very long string&quot;,-599,8154.83,&quot;Debit&quot;,&quot;sample123&quot;\r\n&quot;id123&quot;,&quot;prod123&quot;,&quot;type1&quot;,&quot;bank123&quot;,&quot;account123&quot;,&quot;bal123&quot;,&quot;2023-01-01&quot;,&quot;2023-01-01&quot;,&quot;2020-12-01&quot;,&quot;a very long string; a very long string&quot;,-4000,4154.83,&quot;Debit&quot;,&quot;sample123&quot;\r\n```",
                "title": "Parse multilevel json into a csv using jq tool in unix"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1730020899,
        "creation_date": 1699447327,
        "last_edit_date": 1699497276,
        "question_id": 77445623,
        "body_markdown": "I have a multilevel json like so:\r\n\r\n```\r\n{\r\n    &quot;id&quot;: &quot;id123&quot;,\r\n    &quot;details&quot;: {\r\n        &quot;prod&quot;: &quot;prod123&quot;,\r\n        &quot;etype&quot;: &quot;type1&quot;\r\n    },\r\n    &quot;accounts&quot;: [\r\n        {\r\n            &quot;bankName&quot;: &quot;bank123&quot;,\r\n            &quot;accountType&quot;: &quot;account123&quot;,\r\n            &quot;openingBalance&quot;: &quot;bal123&quot;,\r\n            &quot;fromDate&quot;: &quot;2023-01-01&quot;,\r\n            &quot;toDate&quot;: &quot;2023-01-01&quot;,\r\n            &quot;missingMonths&quot;: [],\r\n            &quot;transactions&quot;: [\r\n                {\r\n                    &quot;dateTime&quot;: &quot;2020-12-01&quot;,\r\n                    &quot;description&quot;: &quot;a very long string&quot;,\r\n                    &quot;amount&quot;: -599.0,\r\n                    &quot;bal&quot;: 8154.83,\r\n                    &quot;type&quot;: &quot;Debit&quot;\r\n                },\r\n                {\r\n                    &quot;dateTime&quot;: &quot;2020-12-01&quot;,\r\n                    &quot;description&quot;: &quot;a very long string; a very long string&quot;,\r\n                    &quot;amount&quot;: -4000.0,\r\n                    &quot;balanceAfterTransaction&quot;: 4154.83,\r\n                    &quot;type&quot;: &quot;Debit&quot;\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    &quot;accountid&quot;: &quot;sample123&quot;\r\n}\r\n```\r\nI want to parse it to a csv in the following format:\r\n\r\n```\r\nid,prod,etype,bankName,accountType,openingBalance,fromDate,toDate,dateTime,description,amount,bal,type,accountid\r\nid123,prod123,type1,bank123,account123,bal123,2023-01-01,2023-01-01,2020-12-01,a very long string,-599.0,8154.83,Debit,sample123\r\nid123,prod123,type1,bank123,account123,bal123,2023-01-01,2023-01-01,2020-12-01,a very long string; a very long string,-4000.0,4157.83,Debit,sample123\r\n```\r\n\r\nParse the transactions into a proper csv and repeat the common info for each transaction.\r\n\r\nI have gotten only so far yet:\r\n\r\n```jq --raw-output &#39;[ .id, .details[], .accounts[].transactions[] ]&#39;```",
        "link": "https://stackoverflow.com/questions/77445623/parse-multilevel-json-into-a-csv-using-jq-tool-in-unix",
        "title": "Parse multilevel json into a csv using jq tool in unix"
    },
    {
        "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": 1699725281,
                "post_id": 77466018,
                "comment_id": 136568645,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8693720,
                    "reputation": 13,
                    "user_id": 18041675,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJxJ7WTYrqsdFmGbRVljgxIDLMxRhM-5I_hNc9EV=k-s256",
                    "display_name": "Chenulu Peri",
                    "link": "https://stackoverflow.com/users/18041675/chenulu-peri"
                },
                "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": 1699726741,
                "post_id": 77466018,
                "comment_id": 136568836,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699726970,
                "creation_date": 1699726970,
                "answer_id": 77466305,
                "question_id": 77466018,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Regarding Q1:\r\n\r\nYou&#39;re using `| join(&quot;,&quot;)` in the wrong place. It expects an array but by being inside the array constructor, you provide it with the array&#39;s values, i.e. strings (hence the error message `Cannot iterate over string (&quot;Test A&quot;)`). Move it outside the array constructor, and it&#39;ll work:\r\n```sh\r\n… | [.description, .planned_start, .planned_end] | join(&quot;,&quot;)\r\n```\r\n\r\n---\r\n\r\nRegarding Q2:\r\n\r\n&gt; I want to add my own labels to the output and proper JSON objects compacted into each line\r\n\r\nInstead of constructing an array of values, construct an object and name your fields as you see fit. Then, use the `-c` flag to output each object on izs own line:\r\n\r\n```sh\r\n… | jq -c &#39;.[] | select(IN(.priority; &quot;low&quot;, &quot;high&quot;, &quot;moderate&quot;))\r\n| {Description: .description, Start: .planned_start, End: .planned_end}&#39;\r\n```\r\nNote: I have also simplified your `select` condition from multiple `or`s to a single `IN` using a stream of values. If you&#39;re on jq &lt; 1.6, use `select(any(.priority = (&quot;low&quot;, &quot;high&quot;, &quot;moderate&quot;); .))` instead.\r\n",
                "title": "JOIN error &amp; Prepend custom description with JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1699735927,
                "creation_date": 1699735927,
                "answer_id": 77466798,
                "question_id": 77466018,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get your desired output, you&#39;d just iterate through the list of objects and output the properties you want.\r\n\r\nSince the input appears to be streamed in, you _don&#39;t_ want to use `.[]` at the start to expand, you&#39;re iterating over the values of the objects at that point. You&#39;d only need that if your input is an array. This is likely the cause for the error you see in Q1.\r\n\r\nTo start, pick out the properties you want to output. Since you want to give them a different &quot;header&quot;, you can map it out to an object. Then you can use `to_entries/0` to convert the object to key/value pairs and map each pair to how you wanted to present it. Since you want the keys and values quoted strings, you could use `tojson` to have them quoted. With the array of strings you want to output, you  could then join that array.\r\n\r\n```\r\n$ command | jq -r &#39;\r\nselect(.priority == (&quot;low&quot;, &quot;high&quot;, &quot;moderate&quot;))\r\n  | { Description: .description, Start: .planned_start, End: .planned_end }\r\n  | to_entries\r\n  | map(&quot;\\(.key|tojson): \\(.value|tojson)&quot;)\r\n  | join(&quot;, &quot;)\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/UEN1dQJONhn)",
                "title": "JOIN error &amp; Prepend custom description with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1699735927,
        "creation_date": 1699722040,
        "last_edit_date": 1699735107,
        "question_id": 77466018,
        "body_markdown": "The command I run produces the JSON output other fields\r\n\r\n```\r\n{\r\n  &quot;description&quot;: &quot;Test A&quot;,\r\n  &quot;planned_start&quot;: &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;planned_end&quot;: &quot;2023-11-20T08:00:00Z&quot;,\r\n  &quot;priority&quot;: &quot;low&quot;,\r\n  ....\r\n}\r\n{\r\n  &quot;description&quot;: &quot;Test B&quot;,\r\n  &quot;planned_start&quot;: &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;planned_end&quot;: &quot;2023-11-20T06:00:00Z&quot;,\r\n  &quot;priority&quot;: &quot;medium&quot;,\r\n  ....\r\n}\r\n{\r\n  &quot;description&quot;: &quot;Test C&quot;,\r\n  &quot;planned_start&quot;: &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;planned_end&quot;: &quot;2023-11-20T06:00:00Z&quot;,\r\n  &quot;priority&quot;: &quot;high&quot;,\r\n  ....\r\n}\r\n```\r\n\r\n\r\n\r\nI have run the following command to select the fields I want. Trying to find how get the following output.\r\n\r\n```\r\ncommand | jq -r &#39;.[] | select (\r\n  (.priority == &quot;low&quot;) or (.priority == &quot;high&quot;) or (.priority == &quot;moderate&quot;)\r\n)\r\n| [.description, .planned_start, .planned_end]&#39;\r\n```\r\n\r\nwhich produces\r\n```\r\n[\r\n &quot;Test A&quot;,\r\n  &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;2023-11-20T06:00:00Z&quot;,\r\n]\r\n[\r\n  &quot;Test B&quot;,\r\n  &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;2023-11-20T06:00:00Z&quot;,\r\n]\r\n[\r\n  &quot;Test C&quot;,\r\n  &quot;2023-11-13T06:00:00Z&quot;,\r\n  &quot;2023-11-20T06:00:00Z&quot;,\r\n]\r\n```\r\n\r\n\r\nIf I add the join,\r\n\r\n```\r\ncommand | jq -r &#39;.[] | select (\r\n  (.priority == &quot;low&quot;) or (.priority == &quot;high&quot;) or (.priority == &quot;moderate&quot;)\r\n)\r\n| [.description, .planned_start, .planned_end | join(&quot;,&quot;)]&#39;\r\n```\r\n\r\n\r\nI am getting an error\r\n&gt; Cannot iterate over string (&quot;Test A&quot;)\r\n\r\nQ1: How to fix the error  \r\nQ2: How do I prepend my own header to each value to get the following output\r\n\r\n```\r\n&quot;Description&quot;: &quot;Test A&quot;, &quot;Start&quot;: &quot;2023-11-13T06:00:00Z&quot;, &quot;End&quot;: &quot;2023-11-20T08:00:00Z&quot;\r\n&quot;Description&quot;: &quot;Test B&quot;, &quot;Start&quot;: &quot;2023-11-13T06:00:00Z&quot;, &quot;End&quot;: &quot;2023-11-20T06:00:00Z&quot;\r\n&quot;Description&quot;: &quot;Test C&quot;, &quot;Start&quot;: &quot;2023-11-13T06:00:00Z&quot;, &quot;End&quot;: &quot;2023-11-20T06:00:00Z&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/77466018/join-error-prepend-custom-description-with-jq",
        "title": "JOIN error &amp; Prepend custom description with JQ"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699871010,
                "last_edit_date": 1699871010,
                "creation_date": 1699870666,
                "answer_id": 77473144,
                "question_id": 77473122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could iterate over all second-level items using `.[][]`, and collect them into an array using the array constructor `[…]`:\r\n```sh\r\njq -c &#39;{fruits: [.[][]]}&#39;\r\n```\r\n```json\r\n{&quot;fruits&quot;:[{&quot;name&quot;:&quot;banana&quot;},{&quot;name&quot;:&quot;apple&quot;},{&quot;name&quot;:&quot;tomato&quot;},{&quot;name&quot;:&quot;onion&quot;}]}\r\n```\r\n[Demo](https://jqplay.org/s/TCd6IdGiPfW)\r\n\r\nIf you don&#39;t know the field name, you could, for instance, use `keys_unsorted[0]` to fetch the name of the first key (first in this representation order): `{(keys_unsorted[0]): [.[][]]}` [Demo](https://jqplay.org/s/-Rva_LgpxKd)",
                "title": "Merge two arrays from a JSON file using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699871493,
                "creation_date": 1699871493,
                "answer_id": 77473212,
                "question_id": 77473122,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Several alternatives:\r\n\r\n```\r\n.fruits += .vegetables | del(.vegetables)\r\n```\r\n\r\n```\r\n{ fruits: (.fruits + .vegetables) }\r\n```\r\n\r\n```\r\n{ fruits: map(.[]) }\r\n```",
                "title": "Merge two arrays from a JSON file using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1699873554,
        "creation_date": 1699870442,
        "last_edit_date": 1699873554,
        "question_id": 77473122,
        "body_markdown": "I have a JSON file with the following code:\r\n\r\n```json\r\n{\r\n  &quot;fruits&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;banana&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;apple&quot;\r\n    }\r\n  ],\r\n  &quot;vegetables&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;tomato&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;onion&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI want to merge the second array items to the first one using the `jq` command.\r\n\r\nIf I do the following \r\n```\r\njq -c &lt; file.json\r\n```\r\nI receive\r\n```json\r\n{&quot;fruits&quot;:[{&quot;name&quot;:&quot;banana&quot;},{&quot;name&quot;:&quot;apple&quot;}],&quot;vegtabels&quot;:[{&quot;name&quot;:&quot;tomato&quot;},{&quot;name&quot;:&quot;onion&quot;}]}\r\n```\r\n\r\nI want to receive \r\n```json\r\n{&quot;fruits&quot;:[{&quot;name&quot;:&quot;banana&quot;},{&quot;name&quot;:&quot;apple&quot;},{&quot;name&quot;:&quot;tomato&quot;},{&quot;name&quot;:&quot;onion&quot;}]}\r\n```\r\n\r\nHow can I achieve that?\r\nCan I control the merge by the array name? If I will have more arrays on that object?",
        "link": "https://stackoverflow.com/questions/77473122/merge-two-arrays-from-a-json-file-using-jq",
        "title": "Merge two arrays from a JSON file using jq"
    },
    {
        "tags": [
            "docker",
            "continuous-integration",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1699880690,
                "creation_date": 1699880690,
                "answer_id": 77474109,
                "question_id": 77474072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So filter NGINX_VERSION  from the array and remove it.\r\n\r\n    .[].Config.Env |\r\n    select(startswith(&quot;NGINX_VERSION=&quot;)) |\r\n    sub(&quot;^NGINX_VERSION=&quot;; &quot;&quot;)",
                "title": "Access array list item by name using jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1699881213,
                "creation_date": 1699881213,
                "answer_id": 77474166,
                "question_id": 77474072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the task given, I&#39;d also go with `startswith` as described in [KamilCuk&#39;s answer](https://stackoverflow.com/a/77474109/2158479). But if you need to access multiple values, you might want to consider creating a lookup object using `INDEX`:\r\n```sh\r\nINDEX(.[:index(&quot;=&quot;)]) as $ix   # stores {&quot;PATH&quot;: … , &quot;NGINX_VERSION&quot;: … , …}\r\n```\r\nand then access the values by field name (truncate by the `index` position of the first `=` character):\r\n```sh\r\n| $ix[&quot;NGINX_VERSION&quot;]         # yields &quot;NGINX_VERSION=1.25.3&quot;\r\n| .[index(&quot;=&quot;)+1:]             # yields &quot;1.25.3\r\n```\r\n[Demo](https://jqplay.org/s/fn5gOiiOj8W)",
                "title": "Access array list item by name using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1699949530,
                "last_edit_date": 1699949530,
                "creation_date": 1699921795,
                "answer_id": 77477567,
                "question_id": 77474072,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a useful function for converting an array of strings of the form `key&lt;DELIM&gt;value` to a JSON obejct:\r\n```\r\n# input: an array of strings of the form: key + delim + value\r\n# It is assumed that delim is string with a single character that \r\n# is not special in the context of regular expressions.\r\ndef toObject(delim): \r\n  map( capture(&quot;(?&lt;key&gt;[^&quot; + delim + &quot;]*)&quot; + delim + &quot;(?&lt;value&gt;.*)&quot; )) | from_entries;\r\n```\r\n\r\nA solution to the stated problem can then be written as:\r\n```\r\ntoObject(&quot;=&quot;) | .NGINX_VERSION\r\n```\r\n",
                "title": "Access array list item by name using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1699949530,
        "creation_date": 1699880414,
        "question_id": 77474072,
        "body_markdown": "Consider the following json data, sourced from from Docker image `nginx:1.25-bookworm`:\r\n\r\n```\r\n# docker pull nginx:1.25-bookworm\r\n# docker image inspect 81be38025439 | jq &#39;.[].Config.Env&#39;\r\n[\r\n  &quot;PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin&quot;,\r\n  &quot;NGINX_VERSION=1.25.3&quot;,\r\n  &quot;NJS_VERSION=0.8.2&quot;,\r\n  &quot;PKG_RELEASE=1~bookworm&quot;\r\n]\r\n#\r\n```\r\n\r\nI would like to be able to access &#39;1.25.3&#39; from this list to tag the image in a build step of a CI-CD pipeline. \r\n\r\nI am close to my goal with the following:\r\n\r\n```\r\n# docker image inspect 0743972990c7 | jq -r &#39;.[].Config.Env[1]&#39;\r\nNGINX_VERSION=1.23.4\r\n```\r\n\r\nBut would like to know how to access the item &#39;NGINX_VERSION&#39; by name instead of relying on the assumption that it will be the second environment variable. ",
        "link": "https://stackoverflow.com/questions/77474072/access-array-list-item-by-name-using-jq",
        "title": "Access array list item by name using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "nested",
            "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": 1699920332,
                "post_id": 77477468,
                "comment_id": 136589019,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 18320926,
                    "reputation": 21,
                    "user_id": 13341708,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4a9527c2fccdb743936d52d013ea4897?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dbradish-gmail",
                    "link": "https://stackoverflow.com/users/13341708/dbradish-gmail"
                },
                "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": 1699925254,
                "post_id": 77477468,
                "comment_id": 136589434,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699939302,
                "post_id": 77477468,
                "comment_id": 136590541,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1699939615,
                "post_id": 77477468,
                "comment_id": 136590567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1699940295,
        "creation_date": 1699919340,
        "last_edit_date": 1699940295,
        "question_id": 77477468,
        "body_markdown": "I have a simple JSON file used to store environment information.  \r\n\r\n```json\r\n{\r\n  &quot;environments&quot;: {\r\n    &quot;dev&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;1&quot;,\r\n        &quot;vm-IP&quot;: &quot;ww.www.ww.ww&quot;,\r\n        &quot;sql-name&quot;: &quot;vmname1.eastus.cloudapp.azure.com&quot;,\r\n        &quot;status&quot;: &quot;inactive&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;vm-IP&quot;: &quot;xx.xxx.xx.xx&quot;,\r\n        &quot;sql-name&quot;: &quot;vmname2.eastus.cloudapp.azure.com&quot;,\r\n        &quot;status&quot;: &quot;active&quot;\r\n      }\r\n    ],\r\n    &quot;stg&quot;: {\r\n      &quot;id&quot;: &quot;3&quot;,\r\n      &quot;vm-IP&quot;: &quot;yy.yyy.yy.yy&quot;,\r\n      &quot;sql-name&quot;: &quot;vmname3.eastus.cloudapp.azure.com&quot;\r\n    },\r\n    &quot;prod&quot;: {\r\n      &quot;id&quot;: &quot;4&quot;,\r\n      &quot;vm-IP&quot;: &quot;zz.zzz.zz.zz&quot;,\r\n      &quot;sql-name&quot;: &quot;vmname4.eastus.cloudapp.azure.com&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nUsing a Bash environment, I am trying to read the IP addresses. Here is my successful script for &quot;stg&quot;:\r\n\r\n```\r\n# This script works as expected b/c &quot;stg&quot; is not an array\r\n# See STG objects\r\nvarFileName=myJsonFile.json\r\njq &#39;.environments.stg&#39; $varFileName\r\n\r\n# Get the IP of stg\r\nstgIP=$(jq -r &#39;.environments.stg.&quot;vm-IP&quot;&#39; $varFileName)\r\necho $stgIP\r\n```\r\n\r\nI would like to get the environments.dev.&quot;vm-IP&quot; that is active. Here are my unsuccessful scripts for &quot;dev&quot;.\r\n\r\n```\r\n# These scripts do not work\r\n\r\n# Get the IP of dev 2\r\ndevIP=$(jq -r &#39;.environments.dev[].&quot;vm-IP&quot; | select(.status == &quot;active&quot;)&#39; $varFileName)\r\nerror: Cannot index string with string &quot;status&quot;\r\n\r\n# this also does not work\r\ndevIP=$(jq -r &#39;.environments.dev[].&quot;vm-IP&quot; | \r\nselect(.environments.dev[].status == &quot;active&quot;)&#39; $varFileName)\r\nerror: Cannot index string with string &quot;environments&quot;\r\n```\r\n\r\nPlease provide assistance with `jq` filtering.\r\n\r\n**Related SO questions**\r\n- https://stackoverflow.com/questions/74911183/parsing-nested-json-keys-with-jq\r\n- https://stackoverflow.com/questions/50978470/filter-a-nested-json-by-a-key-value-using-jq\r\n- https://stackoverflow.com/questions/73081424/using-jq-to-parse-nested-json-arrays\r\n- https://stackoverflow.com/questions/66101660/use-jq-to-interpret-nested-json-in-json\r\n- https://stackoverflow.com/questions/4651437/how-do-i-set-a-variable-to-the-output-of-a-command-in-bash (this ID is about setting variables and does not use `jq` at all)\r\n- https://stackoverflow.com/questions/51494389/escape-field-name-in-jq-that-contains-and (this ID is about setting variables with a very simplistic JSON example.  The focus of this new question is about using `jq` to read nested JSON.)",
        "link": "https://stackoverflow.com/questions/77477468/how-do-i-use-jq-to-read-nested-json-array-and-return-single-value-to-variable",
        "title": "How do I use jq to read nested JSON array and return single value to variable?"
    },
    {
        "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": 2,
                "creation_date": 1699976440,
                "post_id": 77481826,
                "comment_id": 136596642,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1699977018,
                "last_edit_date": 1699977018,
                "creation_date": 1699976160,
                "answer_id": 77481931,
                "question_id": 77481826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `to_entries` once more (acting on the array) in which case you get numbers as indices in the `.key` field. Do your filtering with `select`, then increment the result `.key`, and fetch that item by direct indexing `.[n]`:\r\n```sh\r\nto_entries | .[\r\n  to_entries[] | select(.value.value == &quot;value3&quot;).key + 1\r\n] | .key, .value\r\n```\r\n```\r\nentry4\r\nvalue4\r\n```\r\n[Demo](https://jqplay.org/s/wtjIUuHGjUc)\r\n\r\nNote that the entries in JSON objects semantically don&#39;t have an order, i.e. any other ordering would be considered the same object. `to_entries` merely returns the items in representation order, which is what you wanted to query, just be aware that this piece of information, strictly speaking, is not part of the data conveyed by the JSON input.\r\n\r\n---\r\nEdit:\r\n\r\n&gt; My goal is to retrieve the key values pairs for entry3 and entry4\r\n\r\nIn this case, you could slide through the array returned by `to_entries` with a window of two overlapping items, e.g. using `while(. != []; .[1:])[:2]`. Then, `select` as before but from the `first` item in that window, and eventually output the data from the `first` and `last` item:\r\n\r\n```sh\r\nto_entries | while(. != []; .[1:])[:2]\r\n| select(first.value == &quot;value3&quot;)\r\n| first.key, first.value, last.key, last.value\r\n```\r\n```\r\nentry3\r\nvalue3\r\nentry4\r\nvalue4\r\n```\r\n[Demo](https://jqplay.org/s/YwQN-7hgxWd)",
                "title": "How to retrieve the next key value pair in a json file with jq when I know the previous one"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1700005344,
                "creation_date": 1700005344,
                "answer_id": 77484449,
                "question_id": 77481826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward approach:\r\n```\r\nto_entries\r\n| range(0;length-1) as $n\r\n| select( .[$n].key == &quot;entry3&quot; )\r\n| .[$n:$n+2][]\r\n| [.key, .value]\r\n```\r\n\r\nThis produces\r\n```\r\n[&quot;entry3&quot;,&quot;value3&quot;]\r\n[&quot;entry4&quot;,&quot;value4&quot;]\r\n```\r\n\r\nTweak to taste.\r\n",
                "title": "How to retrieve the next key value pair in a json file with jq when I know the previous one"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1700206246,
        "creation_date": 1699975283,
        "last_edit_date": 1700206246,
        "question_id": 77481826,
        "body_markdown": "I have the following JSON file:\r\n```js\r\n{\r\n   &quot;entry1&quot;:&quot;&quot;,\r\n   &quot;entry2&quot;:&quot;&quot;,\r\n   &quot;entry3&quot;:&quot;value3&quot;,\r\n   &quot;entry4&quot;:&quot;value4&quot;,\r\n   &quot;entry5&quot;:&quot;&quot;,\r\n   &quot;entry6&quot;:&quot; &quot;,\r\n   &quot;entry7&quot;:&quot;&quot;,\r\n   &quot;entry8&quot;:&quot;false&quot;\r\n}\r\n```\r\nI know the key value pair of the entry3 but not the next one (entry4 and value).\r\nHow can I access them?\r\n\r\nFor now, I&#39;m stuck on the below command:\r\n```sh\r\njq -r &#39;to_entries[] | select(.value == &quot;value3&quot;) | .key, .value&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/77481826/how-to-retrieve-the-next-key-value-pair-in-a-json-file-with-jq-when-i-know-the-p",
        "title": "How to retrieve the next key value pair in a json file with jq when I know the previous one"
    },
    {
        "tags": [
            "json",
            "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": 1,
                "creation_date": 1700036411,
                "post_id": 77486124,
                "comment_id": 136604287,
                "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": 1700042520,
                "post_id": 77486124,
                "comment_id": 136605304,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 27817126,
                    "reputation": 109,
                    "user_id": 21238282,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6fad59ddaba5918a3c2b8f9508a697d2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "gotothesky",
                    "link": "https://stackoverflow.com/users/21238282/gotothesky"
                },
                "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": 1700093441,
                "post_id": 77486124,
                "comment_id": 136613812,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700036312,
                "creation_date": 1700036312,
                "answer_id": 77486135,
                "question_id": 77486124,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is a stream of objects which you can address directly. Just iterate over the items of the `.Events` array, and extract the `.EventId`:\r\n```sh\r\njq -r &#39;.Events[].EventId&#39; test.json\r\n```\r\n```\r\nC7061BAC-AFDC-4513-B24B-AA5F13A16123\r\nC7061BAC-AFDC-4513-B24B-AA5F13A16123\r\n```\r\n[Demo](https://jqplay.org/s/4yiYsx6Uc3K)",
                "title": "Can I just extract and output EventId from json file using jq in bash?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1700037335,
                "creation_date": 1700037335,
                "answer_id": 77486209,
                "question_id": 77486124,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to adjust the jq expression to extract only &quot;EventId&quot; from the JSON file. Since your JSON structure includes an array under &quot;Events,&quot; you should use the following command:\r\n\r\n```bash\r\ncat test.json | jq -c &#39;.Events[] | .EventId&#39;\r\n```\r\n\r\nThis command will iterate through each element in the &quot;Events&quot; array and extract the &quot;EventId&quot; from each element. The output will be a list of &quot;EventId&quot; values.",
                "title": "Can I just extract and output EventId from json file using jq in bash?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1700037335,
        "creation_date": 1700036144,
        "question_id": 77486124,
        "body_markdown": "My json file is as follows. This is a sample file.\r\n```\r\n{\r\n    &quot;DocumentIncarnation&quot;:  1,\r\n    &quot;Events&quot;:  [\r\n               ]\r\n}\r\n\r\n{\r\n    &quot;DocumentIncarnation&quot;:  2,\r\n    &quot;Events&quot;:  [\r\n                   {\r\n                       &quot;EventId&quot;:  &quot;C7061BAC-AFDC-4513-B24B-AA5F13A16123&quot;,\r\n                       &quot;EventStatus&quot;:  &quot;Scheduled&quot;,\r\n                       &quot;EventType&quot;:  &quot;Freeze&quot;,\r\n                       &quot;ResourceType&quot;:  &quot;VirtualMachine&quot;,\r\n                       &quot;Resources&quot;:  [\r\n                                         &quot;WestNO_0&quot;,\r\n                                         &quot;WestNO_1&quot;\r\n                                     ],\r\n                       &quot;NotBefore&quot;:  &quot;Mon, 11 Apr 2022 22:26:58 GMT&quot;,\r\n                       &quot;Description&quot;:  &quot;Virtual machine is being paused because of a memory-preserving Live Migration operation.&quot;,\r\n                       &quot;EventSource&quot;:  &quot;Platform&quot;,\r\n                       &quot;DurationInSeconds&quot;:  5\r\n                   }\r\n               ]\r\n}\r\n\r\n{\r\n    &quot;DocumentIncarnation&quot;:  3,\r\n    &quot;Events&quot;:  [\r\n                   {\r\n                       &quot;EventId&quot;:  &quot;C7061BAC-AFDC-4513-B24B-AA5F13A16123&quot;,\r\n                       &quot;EventStatus&quot;:  &quot;Started&quot;,\r\n                       &quot;EventType&quot;:  &quot;Freeze&quot;,\r\n                       &quot;ResourceType&quot;:  &quot;VirtualMachine&quot;,\r\n                       &quot;Resources&quot;:  [\r\n                                         &quot;WestNO_0&quot;,\r\n                                         &quot;WestNO_1&quot;\r\n                                     ],\r\n                       &quot;NotBefore&quot;:  &quot;&quot;,\r\n                       &quot;Description&quot;:  &quot;Virtual machine is being paused because of a memory-preserving Live Migration operation.&quot;,\r\n                       &quot;EventSource&quot;:  &quot;Platform&quot;,\r\n                       &quot;DurationInSeconds&quot;:  5\r\n                   }\r\n               ]\r\n}\r\n\r\n{\r\n    &quot;DocumentIncarnation&quot;:  4,\r\n    &quot;Events&quot;:  [\r\n               ]\r\n}\r\n```\r\n\r\nI want to output only EventId in the json file above.\r\nWhat I tried is as follows, but I failed.\r\n\r\n```\r\ncat test.json | jq -c &#39;.[] | [.EventId]&#39;\r\njq: error (at &lt;stdin&gt;:5): Cannot index number with string &quot;EventId&quot;\r\njq: error (at &lt;stdin&gt;:25): Cannot index number with string &quot;EventId&quot;\r\njq: error (at &lt;stdin&gt;:45): Cannot index number with string &quot;EventId&quot;\r\njq: error (at &lt;stdin&gt;:51): Cannot index number with string &quot;EventId&quot;\r\n```\r\n\r\nI am deeply grateful to anyone who helps me. I&#39;d appreciate it if you could help me grow one step further.\r\n",
        "link": "https://stackoverflow.com/questions/77486124/can-i-just-extract-and-output-eventid-from-json-file-using-jq-in-bash",
        "title": "Can I just extract and output EventId from json file using jq in bash?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700040232,
                "post_id": 77486468,
                "comment_id": 136604903,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17704139,
                    "reputation": 33,
                    "user_id": 12853164,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-FrRLqaohSio/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcGYHpu5zKF-_whIREqXLYKOYkoHA/s256-rj/photo.jpg",
                    "display_name": "grobian 666",
                    "link": "https://stackoverflow.com/users/12853164/grobian-666"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700040625,
                "post_id": 77486468,
                "comment_id": 136604964,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17704139,
                    "reputation": 33,
                    "user_id": 12853164,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-FrRLqaohSio/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcGYHpu5zKF-_whIREqXLYKOYkoHA/s256-rj/photo.jpg",
                    "display_name": "grobian 666",
                    "link": "https://stackoverflow.com/users/12853164/grobian-666"
                },
                "reply_to_user": {
                    "account_id": 1684984,
                    "reputation": 32085,
                    "user_id": 1548468,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0745dce203d52699e63a575b3103ad70?s=256&d=identicon&r=PG",
                    "display_name": "Botje",
                    "link": "https://stackoverflow.com/users/1548468/botje"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700040785,
                "post_id": 77486468,
                "comment_id": 136604988,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700058482,
                "last_edit_date": 1700058482,
                "creation_date": 1700040543,
                "answer_id": 77486533,
                "question_id": 77486468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your shell is interpreting the double quotes and passing bare strings to `jq`.\r\n\r\nThe correct way to define your input is to add an extra level of quoting to make the double quotes part of the value:\r\n\r\n```sh\r\nf=&#39;&quot;teststring&quot;&#39;\r\njq -n --argjson a &quot;${f}&quot; &#39;{&quot;test&quot;:$a}&#39;\r\n```\r\n\r\nAs shown, you also need to quotes around the use of `$f` in case it contains whitespace.",
                "title": "jq argjson does not work with string from variable"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700058482,
        "creation_date": 1700039973,
        "question_id": 77486468,
        "body_markdown": "I am trying to create a json with jq\r\n```\r\nf=1\r\njq -n --argjson a ${f} &#39;{&quot;test&quot;:$a}&#39;\r\n```\r\nor \r\n\r\n```\r\nf=&quot;1&quot;\r\njq -n --argjson a ${f} &#39;{&quot;test&quot;:$a}&#39;\r\n```\r\nor \r\n\r\n```\r\njq -n --argjson a &quot;teststring&quot; &#39;{&quot;test&quot;:$a}&#39;\r\n```\r\n\r\n\r\nwork fine\r\n\r\nbut \r\n\r\n```\r\nf=&quot;teststring&quot;\r\njq -n --argjson a ${f} &#39;{&quot;test&quot;:$a}&#39;\r\n``` \r\n\r\nyields\r\njq: invalid JSON text passed to --argjson\r\n\r\nWhat am I doing wrong?\r\n\r\nCheers\r\nGordon ",
        "link": "https://stackoverflow.com/questions/77486468/jq-argjson-does-not-work-with-string-from-variable",
        "title": "jq argjson does not work with string from variable"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "gitlab",
            "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": 1700063464,
                "post_id": 77489086,
                "comment_id": 136609254,
                "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": 1700063483,
                "post_id": 77489086,
                "comment_id": 136609257,
                "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": 1700063635,
                "post_id": 77489086,
                "comment_id": 136609286,
                "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": 1700063752,
                "post_id": 77489086,
                "comment_id": 136609313,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15507754,
                    "reputation": 61,
                    "user_id": 11187422,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c128d34a611f101beed02bfa19f1acc0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "rosaLux161",
                    "link": "https://stackoverflow.com/users/11187422/rosalux161"
                },
                "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": 1700065728,
                "post_id": 77489086,
                "comment_id": 136609711,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1450087,
                    "reputation": 12022,
                    "user_id": 1409374,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/97d424fe924f2139812a4a6de1ef6b79?s=256&d=identicon&r=PG",
                    "display_name": "rickhg12hs",
                    "link": "https://stackoverflow.com/users/1409374/rickhg12hs"
                },
                "reply_to_user": {
                    "account_id": 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": 1700077456,
                "post_id": 77489086,
                "comment_id": 136611787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "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": 1700077787,
                "post_id": 77489086,
                "comment_id": 136611834,
                "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": 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": 1,
                "creation_date": 1700089505,
                "post_id": 77489086,
                "comment_id": 136613471,
                "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": 1700089829,
                "post_id": 77489086,
                "comment_id": 136613499,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1700068582,
                "last_edit_date": 1700068582,
                "creation_date": 1700065157,
                "answer_id": 77489349,
                "question_id": 77489086,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When testing the return status of a command, you don&#39;t use the bracket test but the command directly (*1).\r\n\r\nHere is how you could perform your test:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\n# Testing data\r\ntriggerPayload=&#39;\r\n{\r\n  &quot;changes&quot;: {\r\n    &quot;title&quot;: {\r\n      &quot;previous&quot;: &quot;test&quot;,\r\n      &quot;current&quot;: &quot;test&quot;\r\n    }\r\n  },\r\n  &quot;object_attributes&quot;: {\r\n    &quot;detailed_merge_status&quot;: &quot;mergeable&quot;\r\n  }\r\n}\r\n&#39;\r\n\r\n# shellcheck disable=SC2016 # Does not expand shell expressions\r\njqFilter=&#39;\r\n$j | (\r\n  .changes.title.previous and\r\n  .changes.title.current and\r\n  .object_attributes.detailed_merge_status == &quot;mergeable&quot;\r\n)&#39;\r\n\r\nif jq --exit-status --null-input --argjson j &quot;$triggerPayload&quot; &quot;$jqFilter&quot; &gt;/dev/null; then\r\n    echo &#39;Do something&#39;\r\nfi\r\n```\r\n\r\n---\r\n\r\n**Notes:**\r\n\r\n1. The `[` or `[[` is actually a shell command, that takes testing arguments where the last one must be `]` or `]]` respectively.\r\n\r\n",
                "title": "Checking for presence of keys in GitLab-CI with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700069020,
        "creation_date": 1700063052,
        "last_edit_date": 1700069020,
        "question_id": 77489086,
        "body_markdown": "I am trying to analyze a variable in the GitLab-CI to see if there are two keys and if a value has a certain value. \r\n\r\nMy current one looks like this:\r\n\r\n\r\n```sh\r\nif [[ $(echo $TRIGGER_PAYLOAD | jq -e &#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39;) ]]; then\r\n    echo &#39;Do something&#39;\r\nfi\r\n```\r\n\r\n\r\n\r\nI have already tried many things, including select(), but now I don&#39;t know what to do.\r\n\r\n--------\r\n\r\nI just created an minimal example for this:\r\n\r\n```sh\r\nset -x\r\npayload=&quot;{\\&quot;object_attributes\\&quot;: {\\&quot;detailed_merge_status\\&quot;: \\&quot;draft_status\\&quot;},\\&quot;changes\\&quot;: {}}&quot;\r\necho $(echo $payload | jq -r .)\r\n\r\nif jq -e &#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39; &lt;&lt;&lt;&quot;$payload&quot;; then\r\n    echo &quot;true&quot;\r\nelse\r\n    echo &quot;false&quot;\r\nfi\r\n```\r\n\r\nThis one works, also vice versa works:\r\n\r\n```sh\r\nset -x\r\npayload=&quot;{\\&quot;changes\\&quot;: {\\&quot;title\\&quot;: {\\&quot;previous\\&quot;: \\&quot;test\\&quot;, \\&quot;current\\&quot;: \\&quot;test\\&quot;}},\\&quot;object_attributes\\&quot;: {\\&quot;detailed_merge_status\\&quot;: \\&quot;mergeable\\&quot;}}&quot;\r\necho $(echo $payload | jq -r .)\r\n\r\nif jq -e &#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39; &lt;&lt;&lt;&quot;$payload&quot;; then\r\n    echo &quot;true&quot;\r\nelse\r\n    echo &quot;false&quot;\r\nfi\r\n```\r\n\r\nIf I now use the real payload instead of the dummy JSON, it doesn&#39;t work again. Whereas a simple query with jq on .key.key works with all values.\r\n\r\n```none\r\n$ if jq -e &#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39; &lt;&lt;&lt;&quot;$TRIGGER_PAYLOAD&quot;; then # collapsed multi-line command\r\n++ echo &#39;$ if jq -e &#39;\\&#39;&#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39;\\&#39;&#39; &lt;&lt;&lt;&quot;$TRIGGER_PAYLOAD&quot;; then # collapsed multi-line command&#39;\r\n++ jq -e &#39;.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == &quot;mergeable&quot;&#39;\r\nparse error: Invalid numeric literal at line 2, column 0\r\n++ echo false\r\nfalse\r\n```",
        "link": "https://stackoverflow.com/questions/77489086/checking-for-presence-of-keys-in-gitlab-ci-with-jq",
        "title": "Checking for presence of keys in GitLab-CI with 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": 1700074997,
                "post_id": 77490174,
                "comment_id": 136611382,
                "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": 3,
                "creation_date": 1700075017,
                "post_id": 77490174,
                "comment_id": 136611386,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10477927,
                    "reputation": 5076,
                    "user_id": 7723882,
                    "user_type": "registered",
                    "accept_rate": 85,
                    "profile_image": "https://i.sstatic.net/6aUwy.png?s=256",
                    "display_name": "Matias Barrios",
                    "link": "https://stackoverflow.com/users/7723882/matias-barrios"
                },
                "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": 1700075888,
                "post_id": 77490174,
                "comment_id": 136611532,
                "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": 1,
                "creation_date": 1700076798,
                "post_id": 77490174,
                "comment_id": 136611676,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700126858,
                "last_edit_date": 1700126858,
                "creation_date": 1700126532,
                "answer_id": 77493583,
                "question_id": 77490174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A variable that&#39;s immediately read again doesn&#39;t gain you anything. Just use the value directly:\r\n\r\n```\r\n[{ names: .products[] | .name }]\r\n| length  &gt; 200\r\n| if (.) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\nOr maybe more expressive:\r\n\r\n```\r\n[{ names: .products[] | .name }]\r\n| if (length  &gt; 200) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\nAnd since wrapping the value in an object doesn&#39;t change the output, it can be simplified to one of these two:\r\n\r\n```\r\n.products | if (length &gt; 200) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\n```\r\nif(.products | length &gt; 200) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\nYou might also be interested in the [`-e` flag](https://jqlang.github.io/jq/manual/#invoking-jq) to jq, which sets the exit code based on the result of your filters:\r\n\r\n&gt; Sets the exit status of jq to 0 if the last output value was neither `false` nor `null`, 1 if the last output value was either false or null, or 4 if no valid result was ever produced. Normally jq exits with 2 if there was any usage problem or system error, 3 if there was a jq program compile error, or 0 if the jq program ran.",
                "title": "JQ - Collect the amount of items and use the result in an IF sentence"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700126858,
        "creation_date": 1700073493,
        "question_id": 77490174,
        "body_markdown": "I have an expression in JQ that looks like this:\r\n\r\n```\r\n[{  &quot;names&quot;: .products[] | .name }]  |  length  &gt; 200 as $qty |  if ($qty) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\nI pretend to save a boolean value inside of &quot;qty&quot;. And it does. But when I add the If I get no syntax error but I get that boolean value as a result insted of &quot;ok&quot; or &quot;not ok&quot;.\r\n\r\nWhat am I doing wrong?\r\n\r\nAlso, if I do this:\r\n\r\n```\r\n ( [{  &quot;names&quot;: .products[] | .name }]  |  length  &gt; 200 ) as $qty |  if ($qty) then &quot;ok&quot; else &quot;not ok&quot; end\r\n```\r\n\r\nto improve the readability of the expression I get a syntax error telling me there is an &quot;unexpected ) symbol&quot;\r\n",
        "link": "https://stackoverflow.com/questions/77490174/jq-collect-the-amount-of-items-and-use-the-result-in-an-if-sentence",
        "title": "JQ - Collect the amount of items and use the result in an IF sentence"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1700145986,
                "creation_date": 1700145986,
                "answer_id": 77495799,
                "question_id": 77495696,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You cannot use `&#39;` for strings in cmd. You have a few options:\r\n\r\n* Dump cmd and switch to a proper shell (WSL, Git Bash; even PowerShell should work)\r\n* Use double quotes and escape the inner double quotes\r\n* Store your jq program in a file and execute the file",
                "title": "Jq select statement is not recognized as an internal or external command"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1700145986,
        "creation_date": 1700145307,
        "question_id": 77495696,
        "body_markdown": "[I am writing this command its not working](https://i.sstatic.net/CeeIg.png)\r\n\r\ni want select command to work i am trying to do filter latency but without select statment it is not working. This is the tutorial i have been following https://k6.io/docs/examples/tutorials/get-started-with-k6/analyze-results/ please take a a look and provide me solution",
        "link": "https://stackoverflow.com/questions/77495696/jq-select-statement-is-not-recognized-as-an-internal-or-external-command",
        "title": "Jq select statement is not recognized as an internal or external command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1700169261,
                "post_id": 77497862,
                "comment_id": 136624980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2466718,
                    "reputation": 799,
                    "user_id": 2149641,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Hro11.png?s=256",
                    "display_name": "jjj",
                    "link": "https://stackoverflow.com/users/2149641/jjj"
                },
                "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": 1700169349,
                "post_id": 77497862,
                "comment_id": 136624991,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700170342,
                "last_edit_date": 1700170342,
                "creation_date": 1700167142,
                "answer_id": 77497910,
                "question_id": 77497862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the [`nth`](https://jqlang.github.io/jq/manual/#first-last-nth-2) filter to extract the element matching your criterion:\r\n\r\n```\r\n.[] | select(nth(1;.records[]|select(.tag==&quot;RespStatus&quot;)).value==&quot;304&quot;)\r\n```\r\n\r\n(zero-based)\r\n\r\nAlternatively, map the array and then [access by index](https://jqlang.github.io/jq/manual/#array-index):\r\n\r\n```\r\n.[] | select(.records|map(select(.tag==&quot;RespStatus&quot;))[1].value==&quot;304&quot;)\r\n```\r\n\r\n(again zero-based; it needs to allocate a new array)",
                "title": "jq - selecting an item if the nth element of a nested dict matches"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700170342,
        "creation_date": 1700166492,
        "last_edit_date": 1700169265,
        "question_id": 77497862,
        "body_markdown": "I have line delimited JSON data like this:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 671731542,\r\n    &quot;type&quot;: &quot;BeReq&quot;,\r\n    &quot;records&quot;: [\r\n      { &quot;tag&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; },\r\n      { &quot;tag&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; },\r\n      { &quot;tag&quot;: &quot;RespStatus&quot;, &quot;value&quot;: &quot;200&quot; },\r\n      { &quot;tag&quot;: &quot;RespReason&quot;, &quot;value&quot;: &quot;OK&quot; },\r\n      { &quot;tag&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; },\r\n      { &quot;tag&quot;: &quot;RespStatus&quot;, &quot;value&quot;: &quot;304&quot; },\r\n      { &quot;tag&quot;: &quot;RespReason&quot;, &quot;value&quot;: &quot;Not Modified&quot; }\r\n    ]\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;id&quot;: 671731543,\r\n    &quot;type&quot;: &quot;BeReq&quot;,\r\n    &quot;records&quot;: [\r\n      { &quot;tag&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; },\r\n      { &quot;tag&quot;: &quot;foo&quot;, &quot;value&quot;: &quot;bar&quot; },\r\n      { &quot;tag&quot;: &quot;RespStatus&quot;, &quot;value&quot;: &quot;200&quot; },\r\n      { &quot;tag&quot;: &quot;RespReason&quot;, &quot;value&quot;: &quot;OK&quot; }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI want to be able to filter based on the nth `RespStatus` inside the `records` array. I can filter items by *any* `RespStatus` like:\r\n```\r\njq &#39;.[] | select(.records[] | .tag==&quot;RespStatus&quot; and .value==&quot;304&quot;)&#39; &lt; requests.log\r\n```\r\nbut sometimes I need to filter if only the nth `RespStatus` is `304`.",
        "link": "https://stackoverflow.com/questions/77497862/jq-selecting-an-item-if-the-nth-element-of-a-nested-dict-matches",
        "title": "jq - selecting an item if the nth element of a nested dict matches"
    },
    {
        "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": 1700205239,
                "post_id": 77499841,
                "comment_id": 136628024,
                "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": 1700206154,
                "post_id": 77499841,
                "comment_id": 136628151,
                "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": 1700207289,
                "post_id": 77499841,
                "comment_id": 136628291,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700206790,
                "last_edit_date": 1700206790,
                "creation_date": 1700205403,
                "answer_id": 77499892,
                "question_id": 77499841,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is based on the [previous approach](https://stackoverflow.com/a/77481931/2158479) which was about finding the next key-value pair in an object. In the current case, however, the question is about finding the next item in an array (which, in contrast to the previous case, has an explicit order), while the array items are objects, and the output is two values from the found object (rather than their key-value pairs). Thus, you don&#39;t need `to_entries`, and in consequence any reference to `.key` or `.value`. Just work directly on the array `.globalSecrets` and the fields of its items (`.secretName` and `.secretValue`):\r\n\r\n```sh\r\n.globalSecrets | while(. != []; .[1:])[:2]\r\n| select(first.secretValue == &quot;secretValue5&quot;)\r\n| first.secretName, first.secretValue, last.secretName, last.secretValue\r\n```\r\n```\r\nsecretName5\r\nsecretValue5\r\nsecretName6\r\nsecretValue6\r\n```\r\n[Demo](https://jqplay.org/s/9H10-d-pwRx)",
                "title": "How to retrieve the next key value pair with jq when I know the previous value only"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1700206790,
        "creation_date": 1700204678,
        "last_edit_date": 1700205014,
        "question_id": 77499841,
        "body_markdown": "I would like to retrieve the next key value pair if I know the previous value one from the JSON file like below:\r\n```js\r\n{\r\n   &quot;metadata&quot;:{\r\n      &quot;secretSchema&quot;:&quot;3.0&quot;,\r\n      &quot;tenant&quot;:&quot;MyTenantName&quot;\r\n   },\r\n   &quot;globalSecrets&quot;:[\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName1&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue1&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName2&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue2&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName3&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue3&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName4&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue4&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName5&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue5&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName6&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue6&quot;\r\n      },\r\n      {\r\n         &quot;secretName&quot;:&quot;secretName7&quot;,\r\n         &quot;secretValue&quot;:&quot;secretValue7&quot;\r\n      }\r\n   ]\r\n}\r\n```\r\nI only know the value of the **secretValue5** and would like to retrieve the \r\n **secretName5** value and the next one (**secretName6** and **secretValue6**)\r\n\r\nI tried the following command:\r\n```jq\r\n.globalSecrets[] | to_entries | while(. != []; .[1:])[:2] | select(first.value == &quot;secretValue5&quot;) | first.key, first.value, last.key, last.value\r\n```\r\nBut the result is\r\n\r\n```none\r\nsecretValue\r\nsecretValue5\r\nsecretValue\r\nsecretValue5\r\n```\r\n\r\nThe result expected is\r\n\r\n```none\r\nsecretName5\r\nsecretValue5\r\nsecretName6\r\nsecretValue6\r\n```\r\n\r\nI posted a similar question in this [post](https://stackoverflow.com/questions/77481826/how-to-retrieve-the-next-key-value-pair-in-a-json-file-with-jq-when-i-know-the-p/77495881#77495881) but with another JSON file with the above command and it&#39;s working fine, but not from the above JSON file.",
        "link": "https://stackoverflow.com/questions/77499841/how-to-retrieve-the-next-key-value-pair-with-jq-when-i-know-the-previous-value-o",
        "title": "How to retrieve the next key value pair with jq when I know the previous value only"
    },
    {
        "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": 1700217710,
                "post_id": 77500958,
                "comment_id": 136630002,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098796,
                    "reputation": 5665,
                    "user_id": 3364871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9dbdd5d8c962a03ffc19a9073ea0c0fa?s=256&d=identicon&r=PG",
                    "display_name": "Maxim Suslov",
                    "link": "https://stackoverflow.com/users/3364871/maxim-suslov"
                },
                "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": 1700218174,
                "post_id": 77500958,
                "comment_id": 136630067,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098796,
                    "reputation": 5665,
                    "user_id": 3364871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9dbdd5d8c962a03ffc19a9073ea0c0fa?s=256&d=identicon&r=PG",
                    "display_name": "Maxim Suslov",
                    "link": "https://stackoverflow.com/users/3364871/maxim-suslov"
                },
                "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": 1700218327,
                "post_id": 77500958,
                "comment_id": 136630100,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098796,
                    "reputation": 5665,
                    "user_id": 3364871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9dbdd5d8c962a03ffc19a9073ea0c0fa?s=256&d=identicon&r=PG",
                    "display_name": "Maxim Suslov",
                    "link": "https://stackoverflow.com/users/3364871/maxim-suslov"
                },
                "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": 1700218427,
                "post_id": 77500958,
                "comment_id": 136630117,
                "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": 1700220757,
                "post_id": 77500958,
                "comment_id": 136630504,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4098796,
                    "reputation": 5665,
                    "user_id": 3364871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9dbdd5d8c962a03ffc19a9073ea0c0fa?s=256&d=identicon&r=PG",
                    "display_name": "Maxim Suslov",
                    "link": "https://stackoverflow.com/users/3364871/maxim-suslov"
                },
                "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": 1700224313,
                "post_id": 77500958,
                "comment_id": 136631092,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700223745,
                "creation_date": 1700223745,
                "answer_id": 77501617,
                "question_id": 77500958,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "My solution is:\r\n\r\n```\r\n# find the MC services and put them into $mc\r\n[ .services[] | select(.criticality == &quot;MC&quot;) | .name ] as $mc | \r\n\r\n# filter links by having MC only in source and target\r\n[ .links[] | select(.from_name | IN($mc[])) | select(.to_name | IN($mc[])) ] |\r\n\r\n# group results by .from_name\r\ngroup_by(.from_name) | map({(.[0].from_name):map(.to_name)}) | add\r\n```\r\n\r\nCheck online: https://jqplay.org/s/AwFt0Ke7DLO",
                "title": "How to filter elements by values from another arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700224275,
        "creation_date": 1700217234,
        "last_edit_date": 1700224275,
        "question_id": 77500958,
        "body_markdown": "I have the following JSON data:\r\n\r\n```json\r\n{\r\n    &quot;services&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;B1&quot;,\r\n            &quot;criticality&quot;: &quot;BC&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;B2&quot;,\r\n            &quot;criticality&quot;: &quot;BC&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;M1&quot;,\r\n            &quot;criticality&quot;: &quot;MC&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;M2&quot;,\r\n            &quot;criticality&quot;: &quot;MC&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;M3&quot;,\r\n            &quot;criticality&quot;: &quot;MC&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;M4&quot;,\r\n            &quot;criticality&quot;: &quot;MC&quot;\r\n        }\r\n    ],\r\n    &quot;links&quot;: [\r\n        {\r\n            &quot;from_name&quot;: &quot;B1&quot;,\r\n            &quot;to_name&quot;: &quot;M1&quot;\r\n        },\r\n        {\r\n            &quot;from_name&quot;: &quot;M1&quot;,\r\n            &quot;to_name&quot;: &quot;M2&quot;\r\n        },\r\n        {\r\n            &quot;from_name&quot;: &quot;M2&quot;,\r\n            &quot;to_name&quot;: &quot;B2&quot;\r\n        },\r\n        {\r\n            &quot;from_name&quot;: &quot;M1&quot;,\r\n            &quot;to_name&quot;: &quot;M3&quot;\r\n        },\r\n        {\r\n            &quot;from_name&quot;: &quot;M4&quot;,\r\n            &quot;to_name&quot;: &quot;M2&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI want to find the services those have `criticality==MC` and depends from other services with `criticality==MC`.\r\n\r\nOutput may look like the following: service and its dependencies\r\n\r\n```json\r\n{\r\n  &quot;M1&quot;: [\r\n    &quot;M2&quot;,\r\n    &quot;M3&quot;\r\n  ],\r\n  &quot;M4&quot;: [\r\n    &quot;M2&quot;\r\n  ]\r\n}\r\n```\r\n\r\n(it could be an array instead of list)\r\n\r\nHow to do it?\r\n\r\n---\r\n\r\nWhen I dig into links, I lost information about services and vice versa:\r\n\r\n```python\r\n.links[] as $in | .services.[] | select(.name == $in.from_name) | select(.criticality == &quot;MC&quot;)\r\n```\r\n\r\nwill produce:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;M1&quot;,\r\n  &quot;criticality&quot;: &quot;MC&quot;\r\n}\r\n{\r\n  &quot;name&quot;: &quot;M2&quot;,\r\n  &quot;criticality&quot;: &quot;MC&quot;\r\n}\r\n```\r\n\r\nBut there is no information about `.links`.",
        "link": "https://stackoverflow.com/questions/77500958/how-to-filter-elements-by-values-from-another-arrays",
        "title": "How to filter elements by values from another arrays"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line-interface",
            "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": 1700251968,
                "post_id": 77504229,
                "comment_id": 136635910,
                "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": 1700253113,
                "post_id": 77504229,
                "comment_id": 136636116,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5359747,
                    "reputation": 1564,
                    "user_id": 4271392,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33d636996c50d545160197b3cdbfd762?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FangQ",
                    "link": "https://stackoverflow.com/users/4271392/fangq"
                },
                "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": 1700253515,
                "post_id": 77504229,
                "comment_id": 136636174,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5359747,
                    "reputation": 1564,
                    "user_id": 4271392,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/33d636996c50d545160197b3cdbfd762?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "FangQ",
                    "link": "https://stackoverflow.com/users/4271392/fangq"
                },
                "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": 1700253604,
                "post_id": 77504229,
                "comment_id": 136636188,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1700254631,
                "last_edit_date": 1700254631,
                "creation_date": 1700254094,
                "answer_id": 77504556,
                "question_id": 77504229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you mention `bash` in the comments area, you can try this script calling jq :\r\n\r\n```\r\n#!/bin/bash\r\n\r\nshopt -s globstar\r\njq -n &#39;reduce inputs as $s ({}; setpath(input_filename|split(&quot;/&quot;);$s) )&#39; */**/*.json\r\n```\r\n\r\nMy test output :\r\n\r\n```\r\n{\r\n  &quot;folder1&quot;: {\r\n    &quot;file1.json&quot;: {\r\n      &quot;a&quot;: 1,\r\n      &quot;b&quot;: [\r\n        1,\r\n        2\r\n      ]\r\n    }\r\n  },\r\n  &quot;folder2&quot;: {\r\n    &quot;folder21&quot;: {\r\n      &quot;file3.json&quot;: {\r\n        &quot;test&quot;: true\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "how to merge folder-organized .json file into a single JSON file with folder/file names as keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1700254631,
        "creation_date": 1700249984,
        "last_edit_date": 1700253872,
        "question_id": 77504229,
        "body_markdown": "I have a folder tree storing various .json files converted from a dataset. something like\r\n\r\n```\r\n/(top folder)\r\n |-- folder1/\r\n |    |- file1.json {&quot;a&quot;:1,&quot;b&quot;:[1,2]}\r\n |    |- file2.json {&quot;a&quot;:12,&quot;c&quot;:[]}\r\n |-- folder2/\r\n      |- file1.json {&quot;ta&quot;:1,&quot;tb&quot;:[1,2]}\r\n      |- file2.json {&quot;ta&quot;:12,&quot;tc&quot;:1}\r\n      |- folder21/\r\n          |- file3.json {&quot;test&quot;:true}\r\n```\r\n\r\nI hope to merge this folder as\r\n```json\r\n{\r\n   &quot;folder1&quot;: {\r\n      &quot;file1.json&quot;: {&quot;a&quot;:1,&quot;b&quot;:[1,2]},\r\n      &quot;file2.json&quot;: {&quot;a&quot;:12,&quot;c&quot;:[]}\r\n   },\r\n   &quot;folder2&quot;: {\r\n      &quot;file1.json&quot;: {&quot;ta&quot;:1,&quot;tb&quot;:[1,2]},\r\n      &quot;file2.json&quot;: {&quot;ta&quot;:12,&quot;tc&quot;:1},\r\n      &quot;folder21&quot; : {\r\n        &quot;file3.json&quot;: {&quot;test&quot;:true}\r\n      }\r\n   }\r\n}\r\n```\r\n\r\nI know this is possible to do with python/perl by writing explicit loops by 1) parsing the json file, 2) merge parsed data with the native data struct/objects using file/folder names as keys, and 3) save the merged data structures into a single JSON file. I&#39;ve [implemented one for Octave/MATLAB](https://github.com/NeuroJSON/jbids), and it works, but it is kind of slow.\r\n\r\nI am wondering if it is possible to do this efficiently using jq.\r\n\r\nI saw merging json files within the same folder is possible using the `reduce` expression, see https://stackoverflow.com/a/59769797/4271392\r\n\r\nI am wondering if jq allows to scan and iterate over sub-folders and merge through each folder. \r\n\r\nIf this is possible, I&#39;d be appreciated if someone can point me to the related examples or documentation.",
        "link": "https://stackoverflow.com/questions/77504229/how-to-merge-folder-organized-json-file-into-a-single-json-file-with-folder-fil",
        "title": "how to merge folder-organized .json file into a single JSON file with folder/file names as keys"
    },
    {
        "tags": [
            "docker",
            "docker-compose",
            "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": 1700346579,
                "post_id": 77508932,
                "comment_id": 136643962,
                "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": 1700411924,
                "post_id": 77508932,
                "comment_id": 136648426,
                "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": 1700416119,
                "post_id": 77508932,
                "comment_id": 136648880,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1700475814,
                "last_edit_date": 1700475814,
                "creation_date": 1700416012,
                "answer_id": 77511827,
                "question_id": 77508932,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [update-assignement `|=`](https://jqlang.github.io/jq/manual/#update-assignment) on all environment objects:\r\n\r\n```sh\r\ndocker-compose config --format json | jq &#39;\r\n.services[].environment |= with_entries(\r\n  .key |= (ascii_downcase | gsub(&quot;_&quot;;&quot;-&quot;))\r\n)\r\n&#39;\r\n```\r\n\r\nTo handle services without the `environment` key, [suppress errors with `?`](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator):\r\n\r\n```\r\n.services[].environment |= with_entries(\r\n  .key |= (ascii_downcase | gsub(&quot;_&quot;;&quot;-&quot;))\r\n)?\r\n```\r\n\r\nOutput:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;qualimarc-docker-prod&quot;,\r\n  &quot;services&quot;: {\r\n    &quot;qualimarc-watchtower&quot;: {\r\n      &quot;cpus&quot;: 0.5,\r\n      &quot;command&quot;: null,\r\n      &quot;container_name&quot;: &quot;qualimarc-watchtower&quot;,\r\n      &quot;entrypoint&quot;: null,\r\n      &quot;environment&quot;: {\r\n        &quot;watchtower-cleanup&quot;: &quot;true&quot;,\r\n        &quot;watchtower-debug&quot;: &quot;false&quot;,\r\n        &quot;watchtower-notifications&quot;: &quot;slack&quot;,\r\n        &quot;watchtower-notification-slack-channel&quot;: &quot;#notif-qualimarc&quot;,\r\n        &quot;watchtower-notification-slack-hook-url&quot;: &quot;https://hooks.slack.com/services/TCRRETSQ4/B03QN4MTU3B/&quot;,\r\n        &quot;watchtower-notification-slack-identifier&quot;: &quot;diplotaxis1-prod qualimarc-watchtower&quot;,\r\n        &quot;watchtower-no-startup-message&quot;: &quot;true&quot;,\r\n        &quot;watchtower-poll-interval&quot;: &quot;60&quot;,\r\n        &quot;watchtower-run-once&quot;: &quot;false&quot;,\r\n        ...\r\n```",
                "title": "how to use jq ascii_downcase to transform environment key in a docker-compose file?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1700475814,
        "creation_date": 1700346295,
        "question_id": 77508932,
        "body_markdown": "Here is the beginning of my docker-compose.yml.\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;qualimarc-docker-prod&quot;,\r\n  &quot;services&quot;: {\r\n    &quot;qualimarc-watchtower&quot;: {\r\n      &quot;cpus&quot;: 0.5,\r\n      &quot;command&quot;: null,\r\n      &quot;container_name&quot;: &quot;qualimarc-watchtower&quot;,\r\n      &quot;entrypoint&quot;: null,\r\n      &quot;environment&quot;: {\r\n        &quot;WATCHTOWER_CLEANUP&quot;: &quot;true&quot;,\r\n        &quot;WATCHTOWER_DEBUG&quot;: &quot;false&quot;,\r\n        &quot;WATCHTOWER_NOTIFICATIONS&quot;: &quot;slack&quot;,\r\n        &quot;WATCHTOWER_NOTIFICATION_SLACK_CHANNEL&quot;: &quot;#notif-qualimarc&quot;,\r\n        &quot;WATCHTOWER_NOTIFICATION_SLACK_HOOK_URL&quot;: &quot;https://hooks.slack.com/services/TCRRETSQ4/B03QN4MTU3B/&quot;,\r\n        &quot;WATCHTOWER_NOTIFICATION_SLACK_IDENTIFIER&quot;: &quot;diplotaxis1-prod qualimarc-watchtower&quot;,\r\n        &quot;WATCHTOWER_NO_STARTUP_MESSAGE&quot;: &quot;true&quot;,\r\n        &quot;WATCHTOWER_POLL_INTERVAL&quot;: &quot;60&quot;,\r\n        &quot;WATCHTOWER_RUN_ONCE&quot;: &quot;false&quot;,\r\n        &quot;WATCHTOWER_SCOPE&quot;: &quot;qualimarc-watchtower-scope&quot;,\r\n        &quot;WATCHTOWER_WARN_ON_HEAD_FAILURE&quot;: &quot;never&quot;\r\n      },\r\n      &quot;image&quot;: &quot;containrrr/watchtower:1.4.0&quot;,\r\n      &quot;labels&quot;: {\r\n        &quot;com.centurylinklabs.watchtower.scope&quot;: &quot;qualimarc-watchtower-scope&quot;\r\n      },\r\n      &quot;mem_limit&quot;: &quot;3221225472&quot;,\r\n      &quot;memswap_limit&quot;: &quot;3221225472&quot;,\r\n      &quot;networks&quot;: {\r\n        &quot;default&quot;: null\r\n      },\r\n      &quot;restart&quot;: &quot;unless-stopped&quot;,\r\n      &quot;volumes&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;bind&quot;,\r\n          &quot;source&quot;: &quot;/var/run/docker.sock&quot;,\r\n          &quot;target&quot;: &quot;/var/run/docker.sock&quot;,\r\n          &quot;bind&quot;: {\r\n            &quot;create_host_path&quot;: true\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n\r\n```\r\nI try to convert all key environment to lowercase and replacing &#39;_&#39; by &#39;_&#39; like following:\r\n```json\r\n        &quot;watchtower-cleanup&quot;: &quot;true&quot;,\r\n        &quot;watchtower-debug&quot;: &quot;false&quot;,\r\n         ....\r\n```\r\n\r\nI managed to do the transformation of the key file by doing:\r\n```bash\r\necho $(docker-compose config --format json) | jq &#39;.services|with_entries(.key|=ascii_downcase)&#39;\r\n```\r\nbut it seems to be more complicated to do the same with environment.\r\nIt should be something like\r\n```bash\r\necho $(docker-compose config --format json) | jq &#39;.services|with_entries(.value|with_entries(.key|=ascii_upcase))&#39;\r\n```\r\nbut it doesn&#39;t work. \r\n\r\nPlease note that I want to keep the environment variable value to original case.\r\n\r\nThanks for helping.\r\n",
        "link": "https://stackoverflow.com/questions/77508932/how-to-use-jq-ascii-downcase-to-transform-environment-key-in-a-docker-compose-fi",
        "title": "how to use jq ascii_downcase to transform environment key in a docker-compose file?"
    }
]