[
    {
        "tags": [
            "bash",
            "shell",
            "jenkins",
            "jq"
        ],
        "comments": [
            {
                "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"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1607066972,
                "post_id": 65139338,
                "comment_id": 115160732,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607067215,
                "post_id": 65139338,
                "comment_id": 115160797,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7546862,
                    "reputation": 1024,
                    "user_id": 5729556,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4e3f0764d5dc8b02515093fda8be54c?s=256&d=identicon&r=PG",
                    "display_name": "gayashanbc",
                    "link": "https://stackoverflow.com/users/5729556/gayashanbc"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607067421,
                "post_id": 65139338,
                "comment_id": 115160872,
                "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"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1607067940,
                "post_id": 65139338,
                "comment_id": 115161063,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7546862,
                    "reputation": 1024,
                    "user_id": 5729556,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4e3f0764d5dc8b02515093fda8be54c?s=256&d=identicon&r=PG",
                    "display_name": "gayashanbc",
                    "link": "https://stackoverflow.com/users/5729556/gayashanbc"
                },
                "reply_to_user": {
                    "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607068837,
                "post_id": 65139338,
                "comment_id": 115161365,
                "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"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607069155,
                "post_id": 65139338,
                "comment_id": 115161463,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7546862,
                    "reputation": 1024,
                    "user_id": 5729556,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c4e3f0764d5dc8b02515093fda8be54c?s=256&d=identicon&r=PG",
                    "display_name": "gayashanbc",
                    "link": "https://stackoverflow.com/users/5729556/gayashanbc"
                },
                "reply_to_user": {
                    "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"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607089079,
                "post_id": 65139338,
                "comment_id": 115169613,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1607073000,
                "creation_date": 1607073000,
                "answer_id": 65140742,
                "question_id": 65139338,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[`test/0`](https://stedolan.github.io/jq/manual/#test(val),test(regex;flags)) is for testing if a string matches a particular regular expression, which is not available in jq 1.3 (as mentioned in the comments). [`contains/1`](https://stedolan.github.io/jq/manual/v1.3/#contains) could be used in this case.\r\n\r\n```\r\ndel(.[] | select(.artifact_location | contains(&quot;foo&quot;)))\r\n```\r\n\r\nI would rather approach this as filtering out the objects, rather than deleting them. Select objects that does not contain &quot;foo&quot;.\r\n\r\n```\r\nmap(select(.artifact_location | contains(&quot;foo&quot;) | not))\r\n```",
                "title": "jq - not working as expected in Jenkins shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1607073000,
        "creation_date": 1607065936,
        "question_id": 65139338,
        "body_markdown": "I have the following JSON named as *my.json*.\r\n\r\n    [\r\n      {\r\n        &quot;action&quot;: &quot;copy&quot;,\r\n        &quot;artifact_location&quot;: &quot;one foo one&quot;\r\n      },\r\n      {\r\n        &quot;action&quot;: &quot;copy&quot;,\r\n        &quot;artifact_location&quot;: &quot;one bar one&quot;\r\n      },\r\n      {\r\n        &quot;action&quot;: &quot;remove&quot;,\r\n        &quot;artifact_location&quot;: &quot;two foo two&quot;\r\n      }\r\n    ]\r\n\r\nMy goal is to delete ***all*** the objects in the root JSON array if the ***artifact_location*** property of the a object contains the string value ***&quot;foo&quot;***.\r\n\r\nI&#39;m using [jq command line utility][1] to accomplish this task.\r\nFollowing is my *jq* command. It is working perfectly when I&#39;m running it on my local machine (*macOS and jq version is 1.6*).\r\n\r\n    jq &#39;del(.[] | select(.artifact_location | test(&quot;foo&quot;)))&#39; my.json\r\n\r\nHowever, the above commands gives the following error when I try to run it as a shell script in a Jenkins job(*Ubuntu and jq version is 1.3*).\r\n\r\n    error: test is not defined\r\n    del(.[] | select(.artifact_location | test(&quot;foo&quot;)))\r\n                                          ^^^^\r\n    1 compile error\r\n\r\nWhat am I possibly doing wrong here?\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/65139338/jq-not-working-as-expected-in-jenkins-shell-script",
        "title": "jq - not working as expected in Jenkins shell script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "append",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 50273,
                    "reputation": 6933,
                    "user_id": 149900,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/fdVBU.jpg?s=256",
                    "display_name": "pepoluan",
                    "link": "https://stackoverflow.com/users/149900/pepoluan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607093542,
                "post_id": 65144289,
                "comment_id": 115171846,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20103949,
                    "reputation": 225,
                    "user_id": 14741880,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8bc3b52abeebbc4ec4990ca9b1a4f9a5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Data",
                    "link": "https://stackoverflow.com/users/14741880/data"
                },
                "reply_to_user": {
                    "account_id": 50273,
                    "reputation": 6933,
                    "user_id": 149900,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/fdVBU.jpg?s=256",
                    "display_name": "pepoluan",
                    "link": "https://stackoverflow.com/users/149900/pepoluan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607110684,
                "post_id": 65144289,
                "comment_id": 115179085,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 50273,
                    "reputation": 6933,
                    "user_id": 149900,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/fdVBU.jpg?s=256",
                    "display_name": "pepoluan",
                    "link": "https://stackoverflow.com/users/149900/pepoluan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607311068,
                "post_id": 65144289,
                "comment_id": 115223539,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20103949,
                    "reputation": 225,
                    "user_id": 14741880,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8bc3b52abeebbc4ec4990ca9b1a4f9a5?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Data",
                    "link": "https://stackoverflow.com/users/14741880/data"
                },
                "reply_to_user": {
                    "account_id": 50273,
                    "reputation": 6933,
                    "user_id": 149900,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://i.sstatic.net/fdVBU.jpg?s=256",
                    "display_name": "pepoluan",
                    "link": "https://stackoverflow.com/users/149900/pepoluan"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607764550,
                "post_id": 65144289,
                "comment_id": 115379224,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607097625,
                "creation_date": 1607097625,
                "answer_id": 65146778,
                "question_id": 65144289,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The fact that there other keys does not invalidate the strategy you’ve used when there are no other keys.\r\n\r\n As best I can tell, your problems start with using a bash variable to store the results:\r\n\r\n    profiles=`cat profiles.json`\r\n\r\nThis by itself of course is harmless enough (at least if the file is sufficiently small), but things go downhill from there.  For example, when you write:\r\n\r\n     --arg profiles &quot;$profiles&quot; \r\n\r\nthe jq variable $profiles now holds a JSON string, which is not what you want. You could chase this rabbit down its rabbit hole by using `--argjson`, but to what end?",
                "title": "Adding/Appending objects to a nested JSON array via jq in a bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1607097625,
        "creation_date": 1607087954,
        "last_edit_date": 1607089533,
        "question_id": 65144289,
        "body_markdown": "This is a followup to my previous post.\r\n\r\nI&#39;ve been able to dynamically add and append objects on a single JSON array.\r\nHowever, I&#39;m having difficulty when attempting the same on a nested array list.\r\n\r\nAble to do this via sponge:\r\n```\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Paul&quot;,\r\n      &quot;car&quot;: &quot;Nissan&quot;,\r\n      &quot;colour&quot;: &quot;Black&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAppend:\r\n```\r\nEnter name:\r\nJoe\r\nEnter Car Model:\r\nBMW\r\nEnter Colour:\r\nBlue\r\n\r\nAdd a new entry? (y/n):  y\r\nEnter name:  \r\nPaul\r\nEnter Car Model:  \r\nNissan\r\nEnter Colour:  \r\nBlack\r\n\r\nAdd a new entry? (y/n):  n\r\n\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;car&quot;: &quot;BMW&quot;,\r\n      &quot;colour&quot;: &quot;Blue&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Paul&quot;,\r\n      &quot;car&quot;: &quot;Nissan&quot;,\r\n      &quot;colour&quot;: &quot;Black&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWhat I am attempting to do is something like this:\r\n```\r\n{\r\n  &quot;key1&quot;: &quot;One&quot;,\r\n  &quot;key2&quot;: &quot;Two&quot;,\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;car&quot;: &quot;BMW&quot;,\r\n      &quot;colour&quot;: &quot;Black&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Sarah&quot;,\r\n      &quot;car&quot;: &quot;Mercedes&quot;,\r\n      &quot;colour&quot;: &quot;Red&quot;\r\n    }\r\n  ],\r\n  &quot;key3&quot;: &quot;Three&quot;,\r\n  &quot;list2&quot;: [\r\n    &quot;list2&quot;\r\n  ],\r\n  &quot;key4&quot;: &quot;Four&quot;,\r\n  &quot;list3&quot;: [\r\n    {\r\n      &quot;key5&quot;: &quot;Five&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nBasically want to add/append objects to the nested **profiles** array.\r\n\r\nBeen utilising the following after my Q&amp;A and Loop:\r\n```\r\njq --arg name &quot;$name&quot; --arg car &quot;$car&quot; --arg colour &quot;$colour&quot; &#39; .profiles += [{ $name, $car, $colour}] &#39; profiles.json | sponge profiles.json\r\n```\r\n\r\nAnd then reading the output to a variable to be used in my final jq command:\r\n\r\n```\r\nprofiles=`cat profiles.json`\r\n```\r\n\r\nHowever, this final jq does not output correctly.\r\n```\r\njq -n --arg key1 &quot;$key1&quot; --arg key1 &quot;$key2&quot; --arg profiles &quot;$profiles&quot; --arg key3 &quot;$key3&quot; --arg key4 &quot;key4&quot; --arg key5 &quot;key5&quot; &#39;{$key1, $key2, &quot;profiles&quot;: $profiles, $key3, &quot;list2&quot;: [&quot;list2&quot;], $key4, &quot;list3&quot;: [{$key5}]}&#39; &gt; new_model.json\r\n```\r\nEven if I change to:\r\n```\r\n&quot;profiles&quot;: [.profiles],\r\n```\r\nWhich gives null:\r\n```\r\n{\r\n  &quot;key1&quot;: &quot;One&quot;,\r\n  &quot;key2&quot;: &quot;Two&quot;,\r\n  &quot;profiles&quot;: [\r\n    null\r\n  ],\r\n  &quot;key3&quot;: &quot;Three&quot;,\r\n  &quot;list2&quot;: [\r\n    &quot;list2&quot;\r\n  ],\r\n  &quot;key4&quot;: &quot;Four&quot;,\r\n  &quot;list3&quot;: [\r\n    {\r\n      &quot;key5&quot;: Five\r\n    }\r\n  ]\r\n}\r\n```\r\nConsidering the other key* values are being added dynamically and are not fixed; does anyone have any ideas on how I can add/append or input the profiles.json into the **nested** **profiles** array correctly?\r\n\r\nPreferably excluding the start and end brackets {} of the profiles.json output.\r\n```\r\n{\r\n  &quot;profiles&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Joe&quot;,\r\n      &quot;car&quot;: &quot;BMW&quot;,\r\n      &quot;colour&quot;: &quot;Black&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;Sarah&quot;,\r\n      &quot;car&quot;: &quot;Mercedes&quot;,\r\n      &quot;colour&quot;: &quot;Red&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nPossibly utilise jq and sponge (as done for the single array) after each Q&amp;A block updating file as I go along, dropping the -n flag etc?\r\nSlightly confused about the logic due to more moving parts and since the profiles array is nested within other key values which are being added dynamically as well.\r\n\r\n\r\nMany Thanks",
        "link": "https://stackoverflow.com/questions/65144289/adding-appending-objects-to-a-nested-json-array-via-jq-in-a-bash-script",
        "title": "Adding/Appending objects to a nested JSON array via jq in a bash script"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonparser"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607089604,
                "creation_date": 1607089604,
                "answer_id": 65144717,
                "question_id": 65144624,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the following JQ command to remove each `sourceUrl`;\r\n```bash\r\njq &#39;del(.. | .sourceUrl?)&#39; input.json\r\n```\r\n[`del()` docs](https://stedolan.github.io/jq/manual/#example23)\r\n\r\n&lt;hr&gt;\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;Version&quot;: &quot;1.0&quot;,\r\n    &quot;ubuntu&quot;: {\r\n      &quot;version&quot;: &quot;1.0.0&quot;,\r\n      &quot;filename&quot;: &quot;1_0_0.log&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Version&quot;: &quot;1.1&quot;,\r\n    &quot;ubuntu&quot;: {\r\n      &quot;version&quot;: &quot;1.0.1&quot;,\r\n      &quot;filename&quot;: &quot;1_0_1.log&quot;\r\n    }\r\n  },\r\n  {\r\n    &quot;Version&quot;: &quot;1.4&quot;,\r\n    &quot;ubuntu&quot;: {\r\n      &quot;version&quot;: &quot;1.0.4&quot;,\r\n      &quot;filename&quot;: &quot;1_0_4.log&quot;\r\n    },\r\n    &quot;centos&quot;: {\r\n      &quot;version&quot;: &quot;1.0.4&quot;,\r\n      &quot;filename&quot;: &quot;1_0_4.pdf&quot;\r\n    }\r\n  }\r\n]\r\n```\r\n\r\n[Try it online!](https://jqplay.org/s/O94E_hLO_Q)",
                "title": "jq to parse json and generate json output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607102145,
        "creation_date": 1607089247,
        "last_edit_date": 1607102145,
        "question_id": 65144624,
        "body_markdown": "I&#39;m working on finding a solution where I need to parse a json file (input.json) and create json file as output (output.json) after removing few lines.\r\n\r\nOnly few version will have both value (ubuntu, centos), most of the version will have either ubuntu or centos.\r\n\r\nI tried the following command;\r\n\r\n    jq &#39;.[]&#39; input.json\r\n\r\n\r\nit gives the complete list But don&#39;t know how to get values under ubuntu and centos. any guidance will be beneficial.   \r\n\r\n**input.json**\r\n\r\n    [\r\n      {\r\n        &quot;Version&quot;: &quot;1.0&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.0&quot;,\r\n          &quot;filename&quot;: &quot;1_0_0.log&quot;,\r\n          &quot;sourceUrl&quot;: &quot;https://example.com/log/1_0_0.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Version&quot;: &quot;1.1&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.1&quot;,\r\n          &quot;filename&quot;: &quot;1_0_1.log&quot;,\r\n          &quot;sourceUrl&quot;: &quot;https://example.com/log/1_0_1.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Version&quot;: &quot;1.4&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.4&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.log&quot;,\r\n          &quot;sourceUrl&quot;: &quot;https://example.com/log/1_0_4.log&quot;\r\n        },\r\n        &quot;centos&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.4&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.pdf&quot;,\r\n          &quot;sourceUrl&quot;: &quot;https://example.com/log/1_0_4.pdf&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n\r\n**output.json**\r\n\r\n    [\r\n      {\r\n        &quot;Version&quot;: &quot;1.0&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.0&quot;,\r\n          &quot;filename&quot;: &quot;1_0_0.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Version&quot;: &quot;1.1&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.1&quot;,\r\n          &quot;filename&quot;: &quot;1_0_1.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Version&quot;: &quot;1.4&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.4&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.log&quot;\r\n        },\r\n        &quot;centos&quot;: {\r\n          &quot;ver&quot;: &quot;1.0.14&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.pdf&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65144624/jq-to-parse-json-and-generate-json-output",
        "title": "jq to parse json and generate json output"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607106091,
                "last_edit_date": 1607106091,
                "creation_date": 1607105773,
                "answer_id": 65148701,
                "question_id": 65148220,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq 1.3 makes no guarantees about the ordering of keys within an object. It&#39;s really as simple as that, though `map` itself has nothing to do with the reordering you&#39;ve noticed.  \r\n\r\nBear in mind also that that version of jq is very old and should be considered obsolete.  \r\n\r\nHowever, within the confines of jq 1.3, you might be able to do whatever it is you are *really* trying to do, but any example of keys being reordered will just illustrate the previous point.",
                "title": "jq - using map function to preserve the currently sorted order of properties"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607109948,
        "creation_date": 1607103715,
        "last_edit_date": 1607109948,
        "question_id": 65148220,
        "body_markdown": "I have the following JSON named as *my.json*.\r\n\r\n    [\r\n      {\r\n        &quot;action&quot;: &quot;copy&quot;,\r\n        &quot;artifact_location&quot;: &quot;one foo one&quot;\r\n      },\r\n      {\r\n        &quot;action&quot;: &quot;copy&quot;,\r\n        &quot;artifact_location&quot;: &quot;one bar one&quot;\r\n      },\r\n      {\r\n        &quot;action&quot;: &quot;remove&quot;,\r\n        &quot;artifact_location&quot;: &quot;two foo two&quot;\r\n      }\r\n    ]\r\n\r\nI&#39;m trying to understand the usage of the *map function* in ***jq version 1.3***.\r\n\r\nLater, I intend the use this logic (i.e. *map function*) for a complex jq filter to preserve the currently sorted order of properties in each object as *--sort-keys* option is **not** available in ***jq version 1.3***.\r\n\r\nMy goal is to output the content of the *my.json* file as it as after using the map function.\r\n\r\nSo far, I have come up with the following *jq* command based on the answers [\\[1\\]][1] and [\\[2\\]][2].\r\n\r\n    jq -r &#39;map(to_entries | map({(.key): .value}))&#39; my.json\r\n\r\nWhich gives me the following output.\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;action&quot;: &quot;copy&quot;\r\n        },\r\n        {\r\n          &quot;artifact_location&quot;: &quot;one foo one&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;action&quot;: &quot;copy&quot;\r\n        },\r\n        {\r\n          &quot;artifact_location&quot;: &quot;one bar one&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;action&quot;: &quot;remove&quot;\r\n        },\r\n        {\r\n          &quot;artifact_location&quot;: &quot;two foo two&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\nIf I combine the ***add*** function as follows.\r\n\r\n    jq -r &#39;map(to_entries | map({(.key): .value}) | add )&#39; my.json\r\n\r\nIt **changes the previously sorted order** of properties similar to the output below.\r\n\r\n    [\r\n      {\r\n        &quot;artifact_location&quot;: &quot;one foo one&quot;,\r\n        &quot;action&quot;: &quot;copy&quot;\r\n      },\r\n      {\r\n        &quot;artifact_location&quot;: &quot;one bar one&quot;,\r\n        &quot;action&quot;: &quot;copy&quot;\r\n      },\r\n      {\r\n        &quot;artifact_location&quot;: &quot;two foo two&quot;,\r\n        &quot;action&quot;: &quot;remove&quot;\r\n      }\r\n    ]\r\n\r\nWhat am I missing here?\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/42324565/5729556\r\n  [2]: https://stackoverflow.com/a/24315502/5729556",
        "link": "https://stackoverflow.com/questions/65148220/jq-using-map-function-to-preserve-the-currently-sorted-order-of-properties",
        "title": "jq - using map function to preserve the currently sorted order of properties"
    },
    {
        "tags": [
            "json",
            "variables",
            "path",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4085219,
                    "reputation": 1117,
                    "user_id": 3354661,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/61eff7ba5dd58bd633b714e727ae0385?s=256&d=identicon&r=PG",
                    "display_name": "luciole75w",
                    "link": "https://stackoverflow.com/users/3354661/luciole75w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607128199,
                "post_id": 65151836,
                "comment_id": 115184286,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1607122840,
                "creation_date": 1607122840,
                "answer_id": 65151934,
                "question_id": 65151836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your question and the example you provided seems very confusing to me. The jist that I got is that you want to assign a name to a value obtained from dot notation and then use it at a later point in time.\r\n\r\nSee if this is of any help -\r\n\r\n```\r\n.people | map(select(.id = 47))[0].names.given as $ng | $ng\r\n```",
                "title": "JQ: Using variable for dot notation path"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607140034,
                "last_edit_date": 1607140034,
                "creation_date": 1607123241,
                "answer_id": 65151992,
                "question_id": 65151836,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer is no and yes: as you&#39;ve seen, once you write an expression such as `.names.given as $ng`, $ng holds the JSON values, not the path.\r\n\r\nBut jq does support `path expressions` in the form of arrays of strings and/or non-negative integers. These can be used to access values in conjunction with the built-in `getpath/1`.\r\n\r\nSo you could, for example, write something along the lines of:\r\n```\r\n[&quot;names&quot;, &quot;given&quot;] as $ng\r\n| .people[]\r\n| select(.id==47)\r\n| getpath($ng)\r\n```\r\n## Converting jq paths to JSON arrays\r\nIt&#39;s possible to convert a &quot;dot notation&quot; path into an &quot;array path&quot; using `path/1`; e.g. the assignment to $ng above could be written as:\r\n\r\n    (null | path(.names.given)) as $ng\r\n",
                "title": "JQ: Using variable for dot notation path"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1607189621,
        "creation_date": 1607122198,
        "last_edit_date": 1607189621,
        "question_id": 65151836,
        "body_markdown": "Is it possible to use a variable to hold a dot notation path? (I&#39;m probably not using the correct term.)\r\n\r\nFor example, given the following json: \r\n\r\n```\r\n{\r\n  &quot;people&quot;: [\r\n    {\r\n      &quot;names&quot;: {\r\n        &quot;given&quot;: &quot;Alice&quot;,\r\n        &quot;family&quot;: &quot;Smith&quot;\r\n      },\r\n      &quot;id&quot;: 47\r\n    },\r\n    {\r\n      &quot;id&quot;: 42\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nIs it possible to construct something like:\r\n\r\n```.names.given as $ng | .people[] | select(.id==47) | ($ng)```\r\n\r\nand output &quot;Alice&quot;?\r\n\r\nThe idea is to allow easier modification of a complex expression. I&#39;ve tried various parens and quotes with increasing literal results (&#39;.names.given&#39; and &#39;$ng&#39;)",
        "link": "https://stackoverflow.com/questions/65151836/jq-using-variable-for-dot-notation-path",
        "title": "JQ: Using variable for dot notation path"
    },
    {
        "tags": [
            "json",
            "curl",
            "jq"
        ],
        "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": 1,
                "creation_date": 1607253518,
                "post_id": 65167312,
                "comment_id": 115209168,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607256148,
                "creation_date": 1607256148,
                "answer_id": 65167809,
                "question_id": 65167312,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should achieve what you wanted :\r\n\r\n```\r\njq -r &#39;.issues[] | .key+&quot; &quot;+.fields.updated&#39;\r\n```",
                "title": "jq: retrieve values from multiple entries"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1607256148,
        "creation_date": 1607252946,
        "last_edit_date": 1607253836,
        "question_id": 65167312,
        "body_markdown": "(I have searched, but found nothing.)\r\n\r\nI have a (huge) json file I got from Jira, and I want to get from it several values from different entries, using curl via linux.\r\n\r\nFor example:\r\n```\r\n{\r\n   &quot;expand&quot;: &quot;names, schema&quot;,\r\n   &quot;startAt&quot;:0,\r\n   &quot;maxResults&quot;:1,\r\n   &quot;total&quot;:46,\r\n   &quot;issues&quot;:[\r\n      {\r\n         &quot;key&quot;:&quot;ABCD-12345&quot;,\r\n         &quot;fields&quot;:{\r\n            &quot;updated&quot;:&quot;2020-12-03T13:16:17.000+0200&quot;,\r\n            &quot;customfield_18484&quot;:null,\r\n            &quot;customfield_14687&quot;:null,\r\n            &quot;customfield_14688&quot;:null,\r\n            &quot;customfield_18800&quot;:null,\r\n            &quot;customfield_23380&quot;:&quot;&quot;,\r\n            &quot;customfield_18480&quot;:&quot;off&quot;\r\n         }\r\n      }\r\n   ]\r\n}\r\n```\r\n\r\nAnd I want to get the key (ABCD-12345) and the updated (2020-12-03T13:16:17.000+0200).\r\n\r\nEach command works separately, but I can&#39;t figure out how to combine them.\r\n\r\nMy commands:\r\n```\r\ncurl -s -g -H &quot;Content-Type: application/json&quot; &quot;&lt;link to my jira with search parameters&quot; -u &quot;&lt;user&gt;:&lt;password&gt;&quot; | jq &#39;.issues[].key&#39; | tr -d &#39;&quot;&#39;\r\n```\r\nreturns ABCD-12345\r\n```\r\ncurl -s -g -H &quot;Content-Type: application/json&quot; &quot;&lt;link to my jira with search parameters&quot; -u &quot;&lt;user&gt;:&lt;password&gt;&quot; | jq  &#39;.issues[].fields | &quot;\\(.updated)&quot;&#39; | tr -d &#39;&quot;&#39;\r\n```\r\nreturns 2020-12-06T10:08:06.000+0200\r\n\r\nI have tried several combinations, like:\r\njq &#39;.issues[].fields | &quot;\\(.updated)&quot;&#39; | jq &#39;.issues[].key&#39;\r\njq &#39;.issues[].fields | &quot;\\(.updated)&quot;, .issues[].key&#39;\r\n\r\nBut they didn&#39;t work.\r\n\r\nAny ideas?\r\nThanks!\r\n",
        "link": "https://stackoverflow.com/questions/65167312/jq-retrieve-values-from-multiple-entries",
        "title": "jq: retrieve values from multiple entries"
    },
    {
        "tags": [
            "terraform",
            "jq",
            "github-actions"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2649209,
                    "reputation": 57233,
                    "user_id": 2291321,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/fea90c708303be83a7490750e6dbe137?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ydaetskcoR",
                    "link": "https://stackoverflow.com/users/2291321/ydaetskcor"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607359792,
                "post_id": 65170927,
                "comment_id": 115241799,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608016420,
                "creation_date": 1608016420,
                "answer_id": 65301479,
                "question_id": 65170927,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `hashicorp/setup-terraform@v1` uses a wrapper to execute terraform and messes up the output when using redirection (like you do with shell pipe). There&#39;s an issue describing the problem [in their repo](https://github.com/hashicorp/setup-terraform/issues/20). \r\n\r\nDisabling the wrapper will make it work but you&#39;ll lose some functionalities to reuse stdout, stderr and exit code from the github integration.\r\n\r\n\r\n     - name: Terraform setup\r\n       uses: hashicorp/setup-terraform@v1\r\n       with:\r\n        terraform_version: 0.13.5\r\n        terraform_wrapper: false",
                "title": "Terraform output value failed formatted by jq in github actions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1608016420,
        "creation_date": 1607275471,
        "last_edit_date": 1607281394,
        "question_id": 65170927,
        "body_markdown": "What I want to achieve?\r\nStore terraform output value (ip address) as env variable in git hub actions and use it during updating network security group.\r\nWhat I have done?\r\nBased on: https://stackoverflow.com/questions/57819539/github-actions-how-to-share-a-calculated-value-between-job-steps/57989070#57989070:\r\n\r\n    - name: Setup Terraform\r\n      uses: hashicorp/setup-terraform@v1\r\n    - name: Extract gateway ip\r\n      run: |\r\n        terraform init    \r\n        echo &quot;IP_GAT=$(terraform output -json gatewayStaticIp | jq -r .)&quot; &gt;&gt; $GITHUB_ENV\r\n      working-directory: ${{ env.my_dir }}\r\n    - name: Update security group\r\n      run: |   \r\n        ip=${{ env.IP_GAT }}\r\n        az network nsg rule update -g myGroup --nsg-name myName -n myRuleName --source-address-prefix $ip\r\n\r\nApparently there is some problem with jq even it seems to be exactly like in example(https://www.terraform.io/docs/commands/output.html):\r\n\r\n    Error: write EPIPE\r\n\r\nAny ideas?\r\nThanks in advance\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65170927/terraform-output-value-failed-formatted-by-jq-in-github-actions",
        "title": "Terraform output value failed formatted by jq in github actions"
    },
    {
        "tags": [
            "json",
            "csv",
            "awk",
            "group-by",
            "jq"
        ],
        "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": 1607313245,
                "post_id": 65175826,
                "comment_id": 115223907,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1607325687,
                "last_edit_date": 1607325687,
                "creation_date": 1607318343,
                "answer_id": 65176496,
                "question_id": 65175826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq solution that assumes the CSV input is very simple (e.g., no field has embedded commas), followed by a brief explanation.  \r\n\r\nTo handle arbitrary CSV, you could use a CSV-to-TSV conversion tool in conjunction with the jq program given below with trivial modifications.\r\n \r\n## A Solution\r\nThe following jq program assumes jq is invoked with the -R option.\r\n(The -n option should not be used as the header row is read without using `input`.)\r\n\r\n```\r\n# sort-free plug-in replacement for the built-in group_by/1\r\ndef GROUP_BY(f): \r\n   reduce .[] as $x ({};\r\n     ($x|f) as $s\r\n     | ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n     | .[$t][$y] += [$x] )\r\n   | [.[][]]\r\n   ;\r\n\r\n# input: an array\r\ndef obj($keys):\r\n  . as $in | reduce range(0; $keys|length) as $i ({}; .[$keys[$i]] = $in[$i]);\r\n\r\n# input: an array to be grouped by $keyname \r\n# output: an object \r\ndef gather_by($keyname; $newkey):\r\n  ($keyname + &quot;s&quot;) as $plural\r\n  | GROUP_BY(.[$keyname])\r\n  | {($plural): map({($keyname): .[0][$keyname], \r\n                     ($newkey) : map(del(.[$keyname])) } ) }\r\n  ;\r\n\r\nsplit(&quot;,&quot;) as $headers\r\n| [inputs\r\n   | split(&quot;,&quot;)\r\n   | obj($headers)\r\n  ]\r\n| gather_by(&quot;broker&quot;; &quot;clients&quot;)\r\n| .brokers[].clients |= (gather_by(&quot;client&quot;; &quot;contracts&quot;) | .clients)\r\n| .brokers[].clients[].contracts |= (gather_by(&quot;contract_id&quot;; &quot;documents&quot;) | .contract_ids)\r\n| .brokers[].clients[].contracts[].documents |= (gather_by(&quot;task_type&quot;; &quot;doc_names&quot;)  | .task_types)\r\n| .brokers[].clients[].contracts[].documents[].doc_names |= map(.doc_names)\r\n| .brokers\r\n```\r\n## Explanation\r\n\r\nThe expected output as shown respects the ordering of the input lines, and so jq&#39;s built-in `group_by` may not be appropriate; hence `GROUP_BY` is defined above as a plug-in replacement for `group_by`.  It&#39;s a bit complicated because it is completely generic in the same way as `group_by`.\r\n\r\nThe `obj` filter converts an array into an object with keys $keys.\r\n\r\nThe `gather_by` filter groups together items in the input array as appropriate for the present problem.\r\n\r\n### `gather_by/2` example\r\nTo get a feel for what `gather_by` does, here&#39;s an example:\r\n```\r\n[ {a:1,b:1}, {a:2, b:2}, {a:1,b:0}] | gather_by(&quot;a&quot;; &quot;objects&quot;)\r\n\r\n```\r\nproduces:\r\n```\r\n{\r\n  &quot;as&quot;: [\r\n    {\r\n      &quot;a&quot;: 1,\r\n      &quot;objects&quot;: [\r\n        {\r\n          &quot;b&quot;: 1\r\n        },\r\n        {\r\n          &quot;b&quot;: 0\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;a&quot;: 2,\r\n      &quot;objects&quot;: [\r\n        {\r\n          &quot;b&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n## Output\r\n```\r\n[\r\n  {\r\n    &quot;broker&quot;: &quot;alice@company.com&quot;,\r\n    &quot;clients&quot;: [\r\n      {\r\n        &quot;client&quot;: &quot;John Doe&quot;,\r\n        &quot;contracts&quot;: [\r\n          {\r\n            &quot;contract_id&quot;: &quot;33333&quot;,\r\n            &quot;documents&quot;: [\r\n              {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;important-doc-pdf&quot;,\r\n                  &quot;paperwork-pdf&quot;\r\n                ]\r\n              },\r\n              {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;blah-pdf&quot;\r\n                ]\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;contract_id&quot;: &quot;00000&quot;,\r\n            &quot;documents&quot;: [\r\n              {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;test-pdf&quot;\r\n                ]\r\n              },\r\n              {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;test-pdf&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;client&quot;: &quot;Jane Smith&quot;,\r\n        &quot;contracts&quot;: [\r\n          {\r\n            &quot;contract_id&quot;: &quot;11111&quot;,\r\n            &quot;documents&quot;: [\r\n              {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;important-doc-pdf&quot;\r\n                ]\r\n              },\r\n              {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;paperwork-pdf&quot;,\r\n                  &quot;unimportant-pdf&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;broker&quot;: &quot;bob@company.com&quot;,\r\n    &quot;clients&quot;: [\r\n      {\r\n        &quot;client&quot;: &quot;John Doe&quot;,\r\n        &quot;contracts&quot;: [\r\n          {\r\n            &quot;contract_id&quot;: &quot;66666&quot;,\r\n            &quot;documents&quot;: [\r\n              {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;pdf-I-pdf&quot;\r\n                ]\r\n              }\r\n            ]\r\n          },\r\n          {\r\n            &quot;contract_id&quot;: &quot;77777&quot;,\r\n            &quot;documents&quot;: [\r\n              {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [\r\n                  &quot;pdf-J-pdf&quot;\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "Transforming high-redundancy CSV data into nested JSON using jq (or awk)?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607357075,
                "last_edit_date": 1607357075,
                "creation_date": 1607333194,
                "answer_id": 65179059,
                "question_id": 65175826,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq solution which uses a generic approach that makes no reference to specific header names except for the specification of certain plural forms.  \r\n\r\nThe generic approach is encapsulated in the recursively defined filter `nested_group_by($headers; $plural)`.  \r\n\r\nThe main assumptions are:\r\n\r\n1) The CVS input can be parsed by splitting on commas;\r\n2) jq is invoked with the -R command-line option.\r\n\r\n\r\n\r\n```\r\n# Emit a stream of arrays, each array being a group defined by a value of f,\r\n# which can be any jq filter that produces exactly one value for each item in `stream`.\r\ndef GROUP_BY(f): \r\n   reduce .[] as $x ({};\r\n     ($x|f) as $s\r\n     | ($s|type) as $t\r\n     | (if $t == &quot;string&quot; then $s else ($s|tojson) end) as $y\r\n     | .[$t][$y] += [$x] )\r\n   | [.[][]]\r\n   ;\r\n\r\ndef obj($headers):\r\n  . as $in | reduce range(0; $headers|length) as $i ({}; .[$headers[$i]] = $in[$i]);\r\n\r\ndef nested_group_by($array; $plural):\r\n  def plural: $plural[.] // (. + &quot;s&quot;);\r\n  if $array == [] then .\r\n  elif $array|length == 1 then GROUP_BY(.[$array[0]]) | map(map(.[])[])\r\n  else ($array[1] | plural) as $groupkey\r\n  | $array[0] as $a0\r\n  | GROUP_BY(.[$a0])\r\n  | map( { ($a0): .[0][$a0], ($groupkey): map(del( .[$a0] )) } )\r\n  | map( .[$groupkey] |= nested_group_by($array[1:]; $plural) )\r\n  end\r\n  ;\r\n\r\nsplit(&quot;,&quot;) as $headers\r\n| {contract_id: &quot;contracts&quot;,\r\n   task_type: &quot;documents&quot;,\r\n   doc_names: &quot;doc_names&quot; } as $plural\r\n| [inputs\r\n   | split(&quot;,&quot;)\r\n   | obj($headers)\r\n  ]\r\n| nested_group_by($headers; $plural)\r\n\r\n```",
                "title": "Transforming high-redundancy CSV data into nested JSON using jq (or awk)?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1607357075,
        "creation_date": 1607312414,
        "last_edit_date": 1607321212,
        "question_id": 65175826,
        "body_markdown": "Say I have the following CSV data in `input.txt`:\r\n\r\n```\r\nbroker,client,contract_id,task_type,doc_names\r\nalice@company.com,John Doe,33333,prove-employment,important-doc-pdf\r\nalice@company.com,John Doe,33333,prove-employment,paperwork-pdf\r\nalice@company.com,John Doe,33333,submit-application,blah-pdf\r\nalice@company.com,John Doe,00000,prove-employment,test-pdf\r\nalice@company.com,John Doe,00000,submit-application,test-pdf\r\nalice@company.com,Jane Smith,11111,prove-employment,important-doc-pdf\r\nalice@company.com,Jane Smith,11111,submit-application,paperwork-pdf\r\nalice@company.com,Jane Smith,11111,submit-application,unimportant-pdf\r\nbob@company.com,John Doe,66666,submit-application,pdf-I-pdf\r\nbob@company.com,John Doe,77777,submit-application,pdf-J-pdf\r\n```\r\n\r\nAnd I&#39;d like to transform it into the following JSON:\r\n\r\n```json\r\n[\r\n{&quot;broker&quot;: &quot;alice@company.com&quot;,\r\n    &quot;clients&quot;: [\r\n    {\r\n        &quot;client&quot;: &quot;John Doe&quot;,\r\n        &quot;contracts&quot;: [\r\n        {\r\n            &quot;contract_id&quot;: 33333,\r\n            &quot;documents&quot;: [\r\n            {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [&quot;important-doc-pdf&quot;, &quot;paperwork-pdf&quot;]\r\n            },\r\n            {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [&quot;blah-pdf&quot;]\r\n            }\r\n            ]\r\n        },\r\n        {\r\n            &quot;contract_id&quot;: 00000,\r\n            &quot;documents&quot;: [\r\n            {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [&quot;test-pdf&quot;]\r\n            },\r\n            {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [&quot;test-pdf&quot;]\r\n            }\r\n            ]\r\n        }\r\n        ]\r\n    },\r\n    {\r\n        &quot;client&quot;: &quot;Jane Smith&quot;,\r\n        &quot;contracts&quot;: [\r\n        {\r\n            &quot;contract_id&quot;: 11111,\r\n            &quot;documents&quot;: [\r\n            {\r\n                &quot;task_type&quot;: &quot;prove-employment&quot;,\r\n                &quot;doc_names&quot;: [&quot;important-doc-pdf&quot;]\r\n            },\r\n            {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [&quot;paperwork-pdf&quot;, &quot;unimportant-pdf&quot;]\r\n            }\r\n            ]\r\n        }\r\n        ]\r\n    }\r\n    ]\r\n},\r\n\r\n{&quot;broker&quot;: &quot;bob@company.com&quot;,\r\n    &quot;clients&quot;: [\r\n    {\r\n        &quot;client&quot;: &quot;John Doe&quot;,\r\n        &quot;contracts&quot;: [\r\n        {\r\n            &quot;contract_id&quot;: 66666,\r\n            &quot;documents&quot;: [\r\n            {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [&quot;pdf-I-pdf&quot;]\r\n            }\r\n            ]\r\n        },\r\n        {\r\n            &quot;contract_id&quot;: 77777,\r\n            &quot;documents&quot;: [\r\n            {\r\n                &quot;task_type&quot;: &quot;submit-application&quot;,\r\n                &quot;doc_names&quot;: [&quot;pdf-J-pdf&quot;]\r\n            }\r\n            ]\r\n        }\r\n        ]\r\n    }\r\n    ]\r\n}\r\n]\r\n\r\n```\r\n\r\nBased on a quick search, it seems like people recommend `jq` for this type of task. I read some of the manual and played around with it for a bit, and I&#39;m understand that it&#39;s meant to be used by composing its filters together to produce the desired output.\r\n\r\nSo far, I&#39;ve been able to transform each line of the CSV into a list of strings for example with `jq -Rs &#39;. / &quot;\\n&quot; | .[] | . / &quot;,&quot;&#39;`.\r\n\r\nBut I&#39;m having trouble with something even a bit more complex, like assigning a key to each value on a line (not even the final JSON form I&#39;m looking to get). This is what I tried: `jq -Rs &#39;[inputs | . / &quot;\\n&quot; | .[] | . / &quot;,&quot; as $line | {&quot;broker&quot;: $line[0], &quot;client&quot;: $line[1], &quot;contract_id&quot;: $line[2], &quot;task_type&quot;: $line[3], &quot;doc_name&quot;: $line[4]}]&#39;`, and it gives back `[]`.\r\n\r\nMaybe `jq` isn&#39;t the best tool for the job here? Perhaps I should be using `awk`? If all else fails, I&#39;d probably just parse this using Python.\r\n\r\nAny help is appreciated.",
        "link": "https://stackoverflow.com/questions/65175826/transforming-high-redundancy-csv-data-into-nested-json-using-jq-or-awk",
        "title": "Transforming high-redundancy CSV data into nested JSON using jq (or awk)?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19185251,
                    "reputation": 2115,
                    "user_id": 14016161,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/05881e900ae5359a2e09f35eb66458ed?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Julia",
                    "link": "https://stackoverflow.com/users/14016161/julia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607344056,
                "post_id": 65181506,
                "comment_id": 115233757,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 12086280,
                    "reputation": 136,
                    "user_id": 8835086,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-olsoAdY3Cgo/AAAAAAAAAAI/AAAAAAAAAEo/Ut4W8Z_UXpk/s256-rj/photo.jpg",
                    "display_name": "Vikas Kyatannawar",
                    "link": "https://stackoverflow.com/users/8835086/vikas-kyatannawar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607346014,
                "post_id": 65181506,
                "comment_id": 115234604,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607347196,
                "last_edit_date": 1607347196,
                "creation_date": 1607344398,
                "answer_id": 65181800,
                "question_id": 65181506,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use the `group_by()` function for this. First by `.name` and then `sort` by the `.date` field. Try running the expression below with one pipeline at a time to visualize how each function takes shape.\r\n\r\n```jq\r\n[ inputs ]        | \r\ngroup_by(.name)[] | \r\nsort_by(.date)    | \r\n[ last, first ]   | \r\n[ .[0].date, \r\n  .[1].date, \r\n  .[0].name \r\n]                 | \r\n@csv\r\n```\r\n\r\nWorking demo at [jqplay.org][1]\r\n\r\nor if the requirement is strictly look for the object with `.pos` as 20, do an explicit `select()`\r\n\r\n```jq\r\n[ inputs ]        | \r\ngroup_by(.name)[] | \r\nsort_by(.date)    | \r\nmap(select(.pos == 1 or .pos == 20)) \r\n[ .[0].date, \r\n  .[1].date // &quot;&quot;, \r\n  .[0].name \r\n]                 | \r\n@csv\r\n```\r\n\r\nThe shorthand `// &quot;&quot;` updates an empty string, in case the `.date` field is not available for lookup.\r\n\r\n  [1]: https://jqplay.org/s/qJAEx4tvDD",
                "title": "How to save data in variable for JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1607347196,
        "creation_date": 1607343042,
        "question_id": 65181506,
        "body_markdown": "JQ Play example\r\nhttps://jqplay.org/s/wPDeHoMBxS\r\n\r\n**Goal**\r\n\r\nI have multiple rows(20) of data for a unique name with different dates.\r\nI want to have a single row with the name, date of the first row, and the date of the 20th row.\r\n```json\r\n{&quot;pos&quot;:1,&quot;date&quot;:&quot;2020-12-04&quot;,&quot;name&quot;:&quot;ABC&quot;}\r\n{&quot;pos&quot;:2,&quot;date&quot;:&quot;2020-12-03&quot;,&quot;name&quot;:&quot;ABC&quot;}\r\n.\r\n.\r\n.\r\n.\r\n{&quot;pos&quot;:20,&quot;date&quot;:&quot;2020-11-04&quot;,&quot;name&quot;:&quot;ABC&quot;}\r\n```\r\n\r\nThe expected output in the given example.\r\n```\r\n&quot;\\&quot;2020-12-04\\&quot;,2020-11-04,\\&quot;ABC\\&quot;&quot;\r\n&quot;\\&quot;2020-12-04\\&quot;,2020-11-04,\\&quot;DEF\\&quot;&quot;",
        "link": "https://stackoverflow.com/questions/65181506/how-to-save-data-in-variable-for-jq",
        "title": "How to save data in variable for JQ?"
    },
    {
        "tags": [
            "json",
            "join",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1607355666,
                "creation_date": 1607355666,
                "answer_id": 65184765,
                "question_id": 65184635,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Should be pretty simple. Get both the fields into an array, join them with the required delimit character and put it in a tabular format\r\n\r\n```bash\r\njq -r &#39;.data[] | [ ( map(.a) | join(&quot;+&quot;) ), ( map(.b) | join(&quot;|&quot;) ) ] | @tsv&#39;\r\n```",
                "title": "Using jq to parse Array and map to string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1607424207,
        "creation_date": 1607355141,
        "last_edit_date": 1607424207,
        "question_id": 65184635,
        "body_markdown": "I have the following JSON Data-Structure:\r\n\r\n    {\r\n        &quot;data&quot;: [\r\n            [\r\n                {\r\n                    &quot;a&quot;: &quot;1&quot;,\r\n                    &quot;b&quot;: &quot;i&quot;\r\n                },\r\n                {\r\n                    &quot;a&quot;: &quot;2&quot;,\r\n                    &quot;b&quot;: &quot;ii&quot;\r\n                },\r\n                {\r\n                    &quot;a&quot;: &quot;3&quot;,\r\n                    &quot;b&quot;: &quot;iii&quot;\r\n                }\r\n            ],\r\n            [\r\n                 {\r\n                    &quot;a&quot;: &quot;4&quot;,\r\n                    &quot;b&quot;: &quot;iv&quot;\r\n                },\r\n                {\r\n                    &quot;a&quot;: &quot;5&quot;,\r\n                    &quot;b&quot;: &quot;v&quot;\r\n                },\r\n                {\r\n                    &quot;a&quot;: &quot;6&quot;,\r\n                    &quot;b&quot;: &quot;vi&quot;\r\n                }\r\n            ]\r\n        ]\r\n    }\r\n\r\nAnd I need to get the following output:  \r\n1+2+3 i|ii|iii   \r\n4+5+6 iv|v|vi  \r\n\r\nI tried the following without success:\r\n\r\n    $ cat data.json | jq -r &#39;.data[] | .[].a | join(&quot;+&quot;)&#39;\r\n    jq: error (at &lt;stdin&gt;:1642): Cannot iterate over string (&quot;1&quot;)\r\n\r\nAnd also this, but I don&#39;t even got an idea how to solve this:\r\n\r\n    $ cat data.json | jq -r &#39;.data[] | to_entries | .[]&#39;\r\n\r\nLooks like an endless journey for me at this time, I you can help me, I would be very happy. :-)",
        "link": "https://stackoverflow.com/questions/65184635/using-jq-to-parse-array-and-map-to-string",
        "title": "Using jq to parse Array and map to string"
    },
    {
        "tags": [
            "json",
            "csv",
            "parent-child",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607460873,
                "last_edit_date": 1607460873,
                "creation_date": 1607384803,
                "answer_id": 65191089,
                "question_id": 65190223,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following provides the basis for a complete solution to the stated problem.  Instead of\r\nproviding the redundant details about the children, it just provides their ids.  If you really need the redundancy, then simply add one more post-processing step, which is trivial to do.\r\n\r\nThe solution here is based on the construction of a dictionary of &quot;children&quot;.\r\n\r\n### Invocation\r\n\r\nAlong the lines of:\r\n\r\n    jq -R -f program.jq data.csv\r\n\r\n### Program\r\n```\r\ndef obj($headers):\r\n  . as $in\r\n  | reduce range(0; $headers|length) as $i ({}; \r\n      .[$headers[$i]] = $in[$i]);\r\n\r\nsplit(&quot;,&quot;) as $headers\r\n| [ inputs\r\n    | split(&quot;,&quot;)\r\n    | map_values(if . == &quot;NULL&quot; then null else . end)\r\n    | obj($headers) ]\r\n| (reduce .[] as $row ({};\r\n      if $row.parent_id\r\n      then .[$row.parent_id] += [$row.id]\r\n      else . end ) ) as $children\r\n| map( del(.parent_id) | .children = ($children[.id] // []) )\r\n\r\n```\r\n\r\n## Output\r\n\r\nWith the given input, the output begins as follows:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;text&quot;: &quot;engine&quot;,\r\n    &quot;children&quot;: [\r\n      &quot;2&quot;,\r\n      &quot;3&quot;\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;2&quot;,\r\n    &quot;text&quot;: &quot;exhaust&quot;,\r\n    &quot;children&quot;: []\r\n  },\r\n\r\n```\r\n\r\n\r\n",
                "title": "JQ, convert CSV (parent child format) to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607817767,
        "creation_date": 1607379140,
        "last_edit_date": 1607817767,
        "question_id": 65190223,
        "body_markdown": "I have a CSV file (parent child format). Is it possible to convert to JSON format by using JQ ?\r\n\r\n**CSV file**\r\n`&lt;pre&gt;`&lt;pre&gt;\r\n    id  parent_id   text\r\n    1   NULL        engine\r\n    2   1           exhaust\r\n    3   1           cooling\r\n    4   3           cooling fan\r\n    5   3           water pump\r\n    6   NULL        frame\r\n    7   6           wheels\r\n    8   6           brakes\r\n    9   8           brake calipers\r\n    10  6           cables\r\n`&lt;/Pre&gt;`&lt;/pre&gt;\r\n\r\n\r\n**JSON file**\r\n`&lt;Pre&gt;`&lt;pre&gt;\r\n    [\r\n      {\r\n    &quot;id&quot;: &quot;1&quot;,\r\n    &quot;text&quot;: &quot;engine&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;2&quot;,\r\n        &quot;text&quot;: &quot;exhaust&quot;,\r\n        &quot;children&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;3&quot;,\r\n        &quot;text&quot;: &quot;cooling&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;4&quot;,\r\n            &quot;text&quot;: &quot;cooling fan&quot;,\r\n            &quot;children&quot;: []\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;5&quot;,\r\n            &quot;text&quot;: &quot;water pump&quot;,\r\n            &quot;children&quot;: []\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;6&quot;,\r\n    &quot;text&quot;: &quot;frame&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;id&quot;: &quot;7&quot;,\r\n        &quot;text&quot;: &quot;wheels&quot;,\r\n        &quot;children&quot;: []\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;8&quot;,\r\n        &quot;text&quot;: &quot;brakes&quot;,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;9&quot;,\r\n            &quot;text&quot;: &quot;brake calipers&quot;,\r\n            &quot;children&quot;: []\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;10&quot;,\r\n        &quot;text&quot;: &quot;cables&quot;,\r\n        &quot;children&quot;: []\r\n      }\r\n    ]\r\n  }\r\n    ]\r\n`&lt;/Pre&gt;`&lt;/pre&gt;\r\n",
        "link": "https://stackoverflow.com/questions/65190223/jq-convert-csv-parent-child-format-to-json",
        "title": "JQ, convert CSV (parent child format) to JSON"
    },
    {
        "tags": [
            "json",
            "jq",
            "jsonparser"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607424832,
                "post_id": 65197341,
                "comment_id": 115262142,
                "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": 1607425234,
                "post_id": 65197341,
                "comment_id": 115262331,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7958992,
                    "reputation": 173,
                    "user_id": 6007353,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/54560192cb15b6e5c9135b4765d75830?s=256&d=identicon&r=PG",
                    "display_name": "mebb",
                    "link": "https://stackoverflow.com/users/6007353/mebb"
                },
                "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": 1607435460,
                "post_id": 65197341,
                "comment_id": 115266947,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607554819,
                "post_id": 65197341,
                "comment_id": 115313375,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7958992,
                    "reputation": 173,
                    "user_id": 6007353,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/54560192cb15b6e5c9135b4765d75830?s=256&d=identicon&r=PG",
                    "display_name": "mebb",
                    "link": "https://stackoverflow.com/users/6007353/mebb"
                },
                "reply_to_user": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607669234,
                "post_id": 65197341,
                "comment_id": 115349960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11430846,
                    "reputation": 14955,
                    "user_id": 8379597,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/12eJq.png?s=256",
                    "display_name": "jq170727",
                    "link": "https://stackoverflow.com/users/8379597/jq170727"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607723551,
                "post_id": 65197341,
                "comment_id": 115372063,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1607423937,
        "creation_date": 1607423937,
        "question_id": 65197341,
        "body_markdown": "i am trying to extract values for version and filename.\r\n\r\n**input.json**\r\n\r\n    [\r\n      {\r\n        &quot;Ver&quot;: &quot;1.0&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;version&quot;: &quot;1.0.0&quot;,\r\n          &quot;filename&quot;: &quot;1_0_0.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Ver&quot;: &quot;1.1&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;version&quot;: &quot;1.0.1&quot;,\r\n          &quot;filename&quot;: &quot;1_0_1.log&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;Ver&quot;: &quot;1.4&quot;,\r\n        &quot;ubuntu&quot;: {\r\n          &quot;version&quot;: &quot;1.0.4&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.log&quot;\r\n        },\r\n        &quot;centos&quot;: {\r\n          &quot;version&quot;: &quot;1.0.4&quot;,\r\n          &quot;filename&quot;: &quot;1_0_4.pdf&quot;\r\n        }\r\n      }\r\n    ]\r\n\r\nusing \r\n\r\n&gt; jq &#39;[.[].centos.version]&#39; input.json   \r\n&gt; jq &#39;[.[].ubuntu.version]&#39; input.json\r\n\r\ni want to know how this can be done using single command to extract it. something similar to   \r\n jq &#39;[.[].*.version]&#39; input.json\r\n\r\nThanks\r\n",
        "link": "https://stackoverflow.com/questions/65197341/jq-to-parse-nested-json",
        "title": "JQ to parse nested Json"
    },
    {
        "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": 3,
                "creation_date": 1607425725,
                "post_id": 65197711,
                "comment_id": 115262549,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607425805,
                "post_id": 65197711,
                "comment_id": 115262578,
                "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": 1607425817,
                "post_id": 65197711,
                "comment_id": 115262585,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20161221,
                    "reputation": 1,
                    "user_id": 14786232,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-wW6ZnOMbSgM/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnYWw3i1RC_PkNUubAK35nNOhDI1w/s96-c/s256-rj/photo.jpg",
                    "display_name": "puffel",
                    "link": "https://stackoverflow.com/users/14786232/puffel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607426206,
                "post_id": 65197711,
                "comment_id": 115262748,
                "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": 1607426460,
                "post_id": 65197711,
                "comment_id": 115262863,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20161221,
                    "reputation": 1,
                    "user_id": 14786232,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-wW6ZnOMbSgM/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnYWw3i1RC_PkNUubAK35nNOhDI1w/s96-c/s256-rj/photo.jpg",
                    "display_name": "puffel",
                    "link": "https://stackoverflow.com/users/14786232/puffel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607426612,
                "post_id": 65197711,
                "comment_id": 115262924,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20161221,
                    "reputation": 1,
                    "user_id": 14786232,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-wW6ZnOMbSgM/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnYWw3i1RC_PkNUubAK35nNOhDI1w/s96-c/s256-rj/photo.jpg",
                    "display_name": "puffel",
                    "link": "https://stackoverflow.com/users/14786232/puffel"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607428582,
                "post_id": 65197711,
                "comment_id": 115263764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607428087,
                "creation_date": 1607428087,
                "answer_id": 65198338,
                "question_id": 65197711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use an [jq if-statement](https://stackoverflow.com/questions/33572755/jq-if-then-else);\r\n\r\n```\r\njq &#39;.[] |= . + {&quot;critical&quot;: (if .file == &quot;FilePath1&quot; or .file == &quot;FilePath3&quot; then &quot;no&quot; else &quot;yes&quot; end)}&#39;\r\n```\r\n\r\n[Try it on jqPlay](https://jqplay.org/s/Ax3vVA5_-b)",
                "title": "How can I add a variable to all items of an existing JSON array?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607463482,
                "last_edit_date": 1607463482,
                "creation_date": 1607461705,
                "answer_id": 65206929,
                "question_id": 65197711,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To minimize redundancy, you could go with:\r\n\r\n    map(. + {critical: (if .file | IN(&quot;FilePath1&quot;, &quot;FilePath3&quot;) then &quot;no&quot; else &quot;yes&quot; end) })\r\n\r\nOr for brevity:\r\n\r\n    map(. + {critical: ((.file | select(IN(&quot;FilePath1&quot;, &quot;FilePath3&quot;)) | &quot;no&quot;) // &quot;yes&quot; )})",
                "title": "How can I add a variable to all items of an existing JSON array?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1607463482,
        "creation_date": 1607425393,
        "last_edit_date": 1607427149,
        "question_id": 65197711,
        "body_markdown": "I have the following JSON-array from a json-file: \r\n\r\n    [\r\n      {\r\n        &quot;key&quot;: &quot;Ley1&quot;,\r\n        &quot;file&quot;: &quot;Filepath1&quot;,\r\n        &quot;line&quot;: 10,\r\n        &quot;rule&quot;: &quot;csharpsquid:S1643&quot;,\r\n        &quot;message&quot;: &quot;Use a StringBuilder instead.&quot;,\r\n        &quot;type&quot;: &quot;CODE_SMELL&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;Key2&quot;,\r\n        &quot;file&quot;: &quot;FilePath2&quot;,\r\n        &quot;line&quot;: 12,\r\n        &quot;rule&quot;: &quot;csharpsquid:S1643&quot;,\r\n        &quot;message&quot;: &quot;Use a StringBuilder instead.&quot;,\r\n        &quot;type&quot;: &quot;CODE_SMELL&quot;\r\n      }\r\n    ]\r\n\r\nand I want to add the variable &quot;critical&quot; to all items of it using a bash-command so it looks like this:\r\n\r\n    [\r\n          {\r\n            &quot;key&quot;: &quot;Key1&quot;,\r\n            &quot;file&quot;: &quot;Filepath1&quot;,\r\n            &quot;line&quot;: 10,\r\n            &quot;rule&quot;: &quot;csharpsquid:S1643&quot;,\r\n            &quot;message&quot;: &quot;Use a StringBuilder instead.&quot;,\r\n            &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n            &quot;critical&quot;: &quot;No&quot;\r\n          },\r\n          {\r\n            &quot;key&quot;: &quot;Key2&quot;,\r\n            &quot;file&quot;: &quot;FilePath2&quot;,\r\n            &quot;line&quot;: 12,\r\n            &quot;rule&quot;: &quot;csharpsquid:S1643&quot;,\r\n            &quot;message&quot;: &quot;Use a StringBuilder instead.&quot;,\r\n            &quot;type&quot;: &quot;CODE_SMELL&quot;,\r\n            &quot;critical&quot;: &quot;Yes&quot;\r\n          }\r\n        ]\r\n\r\n\r\nUnfortunately I am a complete JSON and bash beginner and could not find a bash-command solving this problem. I tried a litte bit with jq on jq-play but it did not really lead to something so I wanted to try it here. I hope this are all information needed, so does anyone know maybe a command for this?\r\n\r\n\r\nEDIT:\r\nThis here worked, thanks!\r\n\r\n    .[] |= . + {&quot;critical&quot;: &quot;No&quot;}\r\n\r\nBut no i want to determine the value of &quot;yes&quot; or &quot;no&quot; depending on the file-value. Do you know how to edit the command so it checks the file-value in order to determine the critical-value?\r\n\r\nIt should decide like this:\r\n\r\nFilepath1, Filepath3 leads to `&quot;critical&quot; : &quot;No&quot;`\r\n\r\nand\r\n\r\nFilepath2, Filepath4, Filepath5 leads to `&quot;critical&quot; : &quot;Yes&quot;`",
        "link": "https://stackoverflow.com/questions/65197711/how-can-i-add-a-variable-to-all-items-of-an-existing-json-array",
        "title": "How can I add a variable to all items of an existing JSON array?"
    },
    {
        "tags": [
            "json",
            "null",
            "jq",
            "is-empty"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607440297,
                "last_edit_date": 1607440297,
                "creation_date": 1607433657,
                "answer_id": 65199732,
                "question_id": 65199084,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`null` is just a regular JSON value; and conceptually, it is totally different from the absence of a value, i.e, what you termed *nothing*. Take a look at these for example (`empty` is a filter that returns nothing):\r\n```\r\n$ jq -n &#39;[null] | length&#39;\r\n1\r\n$ jq -n &#39;[empty] | length&#39;\r\n0\r\n```\r\nThat `{} + null` returns `{}` back, and that `{} | . |= empty` does exactly what `del(.)` does are merely design choices.",
                "title": "Difference between `null` and `no output`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607451997,
        "creation_date": 1607431100,
        "last_edit_date": 1607451997,
        "question_id": 65199084,
        "body_markdown": "I&#39;ve encountered some difference between `null` and `nothing`, can somebody explain it? As in most languages `null` is considered/used to represent nothing.\r\n\r\nThe `select` is documented to return no output. And adding(ie. `+`) `null` to X yields X. Now consider these demonstrative examples(takes no  input):\r\n\r\n1. adding *nothing*\r\n\r\nhere we have empty object, which we update with nothing:\r\n\r\n    {} | . |= . + ({} | select (.foo == 123))\r\n\r\nwhich results in \r\n\r\n    null\r\n\r\n2. adding *null*\r\n\r\nsame template but with alternative operator to substitute *nothing* to *null*:\r\n\r\n    {} | . |= . + ({} | select (.foo == 123)//null)\r\n\r\nwhich results in\r\n\r\n    {}\r\n\r\n\r\nCan someone explain the difference `nothing` vs `null`?",
        "link": "https://stackoverflow.com/questions/65199084/difference-between-null-and-no-output",
        "title": "Difference between `null` and `no output`"
    },
    {
        "tags": [
            "json",
            "string",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1609761793,
                "last_edit_date": 1609761793,
                "creation_date": 1607442335,
                "answer_id": 65202136,
                "question_id": 65201631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are looking for [`map_values`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)).\r\n``` shell\r\n$ jq &#39;map_values(strings)&#39; file\r\n{\r\n  &quot;1&quot;: &quot;a-secret&quot;,\r\n  &quot;A&quot;: &quot;b-secret&quot;\r\n}\r\n```",
                "title": "Leave only fields with string values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609735848,
                "last_edit_date": 1609735848,
                "creation_date": 1609701401,
                "answer_id": 65553883,
                "question_id": 65201631,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As an alternate solution, especially on versions prior to `jq-1.6` you could use `with_entries` to filter on values whose type is `string`\r\n\r\n```none\r\nwith_entries(select(.value | type == &quot;string&quot;))\r\n```",
                "title": "Leave only fields with string values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1609761793,
        "creation_date": 1607440661,
        "last_edit_date": 1607451503,
        "question_id": 65201631,
        "body_markdown": "I have a JSON structure like this:\r\n```\r\n{\r\n  &quot;1&quot;: &quot;a-secret&quot;,\r\n  &quot;A&quot;: &quot;b-secret&quot;,\r\n  &quot;2&quot;: {\r\n    &quot;3&quot;: &quot;ab-secret&quot;,\r\n    &quot;4&quot;: {\r\n      &quot;5&quot;: &quot;adc-secret&quot;\r\n    },\r\n    &quot;6&quot;: {\r\n      &quot;7&quot;: &quot;abdc-secret&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI am trying to create a command (preferable one liner) to return key pairs that only have string values. So for the above it would return:\r\n```\r\n{\r\n  &quot;1&quot;: &quot;a-secret&quot;,\r\n  &quot;A&quot;: &quot;b-secret&quot;\r\n}\r\n```\r\n\r\nI have found `.[]|strings` that returns only the string values but I need both the key and value and that&#39;s where I&#39;m stumped!",
        "link": "https://stackoverflow.com/questions/65201631/leave-only-fields-with-string-values",
        "title": "Leave only fields with string values"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq",
            "git-bash"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607443736,
                "post_id": 65202170,
                "comment_id": 115271392,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14652272,
                    "reputation": 3423,
                    "user_id": 10581944,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sPueS.jpg?s=256",
                    "display_name": "wawawa",
                    "link": "https://stackoverflow.com/users/10581944/wawawa"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607445084,
                "post_id": 65202170,
                "comment_id": 115272070,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14652272,
                    "reputation": 3423,
                    "user_id": 10581944,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/sPueS.jpg?s=256",
                    "display_name": "wawawa",
                    "link": "https://stackoverflow.com/users/10581944/wawawa"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607445258,
                "post_id": 65202170,
                "comment_id": 115272159,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607451533,
                "post_id": 65202170,
                "comment_id": 115275011,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 27,
                "is_accepted": true,
                "score": 26,
                "last_activity_date": 1607498367,
                "creation_date": 1607498367,
                "answer_id": 65212238,
                "question_id": 65202170,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can [run a `jq.exe` from git bash][1].\r\n\r\nYou only need to install it in your git bash PATH:\r\n\r\n    curl -L -o /usr/bin/jq.exe https://github.com/stedolan/jq/releases/latest/download/jq-win64.exe\r\n\r\nThen jq will work with your pipe command.\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/53967916/6309",
                "title": "&quot; bash: jq: command not found&quot; after adding jq executable file to env variable (windows)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 13,
        "last_activity_date": 1705569272,
        "creation_date": 1607442469,
        "last_edit_date": 1705569272,
        "question_id": 65202170,
        "body_markdown": "I wanted to test a json file locally with command (in bash)`curl &quot;https://jsonplaceholder.typicode.com/users&quot; | jq\r\n` by following this tutorial video: https://www.youtube.com/watch?v=rrjIVepRqPI\r\n\r\nI followed each step and added the executable file in the env variable path, but not working at all, I got result:\r\n\r\n```\r\n$ curl &quot;https://jsonplaceholder.typicode.com/users&quot; | jq\r\nbash: jq: command not found\r\n\r\n  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\r\n                                 Dload  Upload   Total   Spent    Left  Speed\r\n100  4670    0  4670    0     0   8584      0 --:--:-- --:--:-- --:--:--  8584\r\ncurl: (23) Failed writing body (795 != 1369)\r\n\r\n```\r\n\r\nAm I missing anything? Why I still got error `bash: jq: command not found`??",
        "link": "https://stackoverflow.com/questions/65202170/bash-jq-command-not-found-after-adding-jq-executable-file-to-env-variable",
        "title": "&quot; bash: jq: command not found&quot; after adding jq executable file to env variable (windows)"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 26377,
                    "reputation": 363501,
                    "user_id": 68587,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7d9fd158e03cbde94f7e0b33b78222af?s=256&d=identicon&r=PG",
                    "display_name": "John Kugelman",
                    "link": "https://stackoverflow.com/users/68587/john-kugelman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1607466563,
                "post_id": 65207770,
                "comment_id": 115280990,
                "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": 1607468410,
                "post_id": 65207770,
                "comment_id": 115281509,
                "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": 1607468567,
                "post_id": 65207770,
                "comment_id": 115281551,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1607466595,
                "creation_date": 1607466595,
                "answer_id": 65207885,
                "question_id": 65207770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq &#39;.data[] |= select((.&quot;{#PARAMETER}&quot; | length) &gt; 0)&#39; file.json",
                "title": "How to remove empty array from Jq in bash script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607466595,
        "creation_date": 1607465982,
        "last_edit_date": 1607466492,
        "question_id": 65207770,
        "body_markdown": "How I can remove empty parameters from jq output without editing and removing a empty spaces from variable?\r\n\r\nMy output is, and I need remove this empty values like `{&quot;{#PARAMETER}&quot;:&quot;&quot;}`:\r\n\r\n    {&quot;data&quot;:[{&quot;{#PARAMETER}&quot;:&quot;&quot;},{&quot;{#PARAMETER}&quot;:&quot;test1&quot;},{&quot;{#PARAMETER}&quot;:&quot;test2&quot;},{&quot;{#PARAMETER}&quot;:&quot;test3&quot;},{&quot;{#PARAMETER}&quot;:&quot;test4&quot;},{&quot;{#PARAMETER}&quot;:&quot;&quot;}]}\r\n\r\nReproduce script.\r\n\r\n```\r\n#!/bin/bash\r\n\r\nTEST=&quot;\r\ntest1\r\ntest2\r\ntest3\r\ntest4\r\n&quot;\r\n\r\necho -n &quot;${TEST}&quot; | jq -R -s -c &#39;{data:  split(&quot;\\n&quot;) | map({&quot;{#PARAMETER}&quot;: (.)}) }&#39;\r\n",
        "link": "https://stackoverflow.com/questions/65207770/how-to-remove-empty-array-from-jq-in-bash-script",
        "title": "How to remove empty array from Jq in bash script"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1607498598,
                "last_edit_date": 1607498598,
                "creation_date": 1607497036,
                "answer_id": 65212007,
                "question_id": 65211894,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try `--arg ID &quot;value&quot;` in double quote like following:\r\n\r\n```bash\r\nss=&quot;mango&quot;\r\njq -n &#39;{&quot;name&quot;: {&quot;S&quot;: $ID}}&#39; --arg ID &quot;partridge in a $ss tree&quot;\r\n```\r\n\r\n---\r\n\r\noutput:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: {\r\n    &quot;S&quot;: &quot;partridge in a mango tree&quot;\r\n  }\r\n}\r\n```",
                "title": "Create json with a string variable as argument using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607498598,
        "creation_date": 1607496468,
        "last_edit_date": 1607497056,
        "question_id": 65211894,
        "body_markdown": "I&#39;m trying to create a json file using a variable somewhat like this:\r\n\r\ninput:\r\n\r\n    ss=&quot;mango&quot;\r\n    jq -n &#39;{&quot;name&quot;: {&quot;S&quot;: $ID}}&#39; --arg ID &#39;partridge in a $ss tree&#39;\r\n\r\n\r\nactual output:\r\n\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;S&quot;: &quot;partridge in a $ss tree&quot;\r\n      }\r\n    }\r\n\r\nexpected output:\r\n\r\n    {\r\n      &quot;name&quot;: {\r\n        &quot;S&quot;: &quot;partridge in a mango tree&quot;\r\n      }\r\n    }\r\n\r\nIs there a way to achieve this using `jq`?",
        "link": "https://stackoverflow.com/questions/65211894/create-json-with-a-string-variable-as-argument-using-jq",
        "title": "Create json with a string variable as argument using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607553959,
                "creation_date": 1607553959,
                "answer_id": 65226047,
                "question_id": 65225889,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a filter I think will help\r\n```\r\n.[] | select(.repoTags | any(keys[] == &quot;3.0.0&quot;)) | .id\r\n```\r\nwith your input it produces\r\n```\r\n&quot;002&quot;\r\n```\r\nIf you don&#39;t want the extra quotes in the output you can use the `-r` option.   \r\n\r\n[Try it online!](https://tio.run/##vZFND4IgGMfvfArGSbdGaCfbOvUVujkPpNRIpgbY5qrPTog22@SQW@s5MHh@/@eVy9UYnGbwARUTLNcBlqypD/SsrItWXVCyTlm@20G0wQQTFIaWYF4YkwJo7e7O3hAv0BYiQiK0mpzvfBZNUkeKOi@ZXFPR8IrNsJPEOMKJFzl8a0XFJD2KPhxp2bKPyl4lF1x3@7qttI2Ikpn4OY9HSo8V/tcF8L@G29ijZ/HxzxY//PWXI5@oUMtmJktHBhl4AQ &quot;jq – Try It Online&quot;)",
                "title": "Conditional query using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1607555535,
        "creation_date": 1607553098,
        "last_edit_date": 1607555535,
        "question_id": 65225889,
        "body_markdown": "I have the following JSON data\r\n```\r\n[\r\n\t{\r\n\t\t&quot;id&quot;: &quot;001&quot;,\r\n\t\t&quot;repoTags&quot;: {\r\n\t\t\t&quot;docker/alpine&quot;: {\r\n\t\t\t\t&quot;2.1.9&quot;: {\r\n\t\t\t\t\t&quot;vulnerable&quot;: &quot;true&quot;,\r\n\t\t\t\t\t&quot;vulnerabilityCount&quot;: 19\r\n\t\t\t\t},\r\n\t\t\t\t&quot;stable&quot;: {\r\n\t\t\t\t\t&quot;vulnerable&quot;: &quot;true&quot;,\r\n\t\t\t\t\t&quot;vulnerabilityCount&quot;: 19\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t},\r\n\t{\r\n\t\t&quot;id&quot;: &quot;002&quot;,\r\n\t\t&quot;repoTags&quot;: {\r\n\t\t\t&quot;docker/alpine&quot;: {\r\n\t\t\t\t&quot;3.0.0&quot;: {\r\n\t\t\t\t\t&quot;vulnerable&quot;: &quot;false&quot;,\r\n\t\t\t\t\t&quot;vulnerabilityCount&quot;: 0\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n]\r\n```\r\n\r\nI want to get the value of the field `id`, but only for the element which has `repoTags` = &quot;3.0.0&quot;.\r\nIs there any way to do this conditional query using jq? If not, what alternative do you propose?",
        "link": "https://stackoverflow.com/questions/65225889/conditional-query-using-jq",
        "title": "Conditional query using jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "any"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1607611078,
                "last_edit_date": 1607611078,
                "creation_date": 1607596616,
                "answer_id": 65232910,
                "question_id": 65232444,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think you&#39;re looking for [`IN/2`](https://stedolan.github.io/jq/manual/#SQL-StyleOperators). It&#39;s [implemented using `any`](https://github.com/stedolan/jq/blob/a17dd3248a666d01be75f6b16be37e80e20b0954/src/builtin.jq#L275), but is far easier to grasp.\r\n```\r\nselect(IN(.prop[]; &quot;kiwi&quot;, &quot;orange&quot;))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/bB3UfjOGs4)&lt;/sup&gt;",
                "title": "In jq, how to select objects where an array contains at least one value (intersection non-empty)"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1607631177,
                "last_edit_date": 1607631177,
                "creation_date": 1607604282,
                "answer_id": 65234775,
                "question_id": 65232444,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The stream-oriented version of the built-in function `any` can be most easily used if one bears in mind its signature:\r\n\r\n    def any(generator; condition):\r\n\r\nSo we are led to:\r\n\r\n    select( any( .prop[]; . == &quot;kiwi&quot; or . == &quot;orange&quot; ))\r\n\r\nor more succinctly:\r\n\r\n    select( any(.prop[]; IN(&quot;kiwi&quot;, &quot;orange&quot;)))\r\n\r\n## whitelist\r\n\r\nIf the values of interest are provided as a JSON array, say $whitelist, you could tweak the above by substituting `$whitelist[]` for the explicit stream of values:\r\n\r\n    select( any(.prop[]; IN($whitelist[]) ))\r\n\r\n",
                "title": "In jq, how to select objects where an array contains at least one value (intersection non-empty)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1708710869,
                "creation_date": 1708710869,
                "answer_id": 78049319,
                "question_id": 65232444,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The above answers worked for me in jq 1.7, but they failed in jq 1.6 (which is what&#39;s preinstalled on a GitHub Actions ubuntu-latest runner in February 2024, and I don&#39;t want the performance hit of installing something better during every CI run).\r\n\r\nHere&#39;s what I came up with that works correctly and consistently in both 1.6 and 1.7:\r\n\r\n```\r\ndef intersects(a; b):\r\n  any(a[] as $aElem | b | index($aElem));\r\n```\r\n\r\nUse as follows:\r\n```\r\nintersects([&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]; [&quot;c&quot;, &quot;d&quot;, &quot;e&quot;]) # true\r\n```\r\n\r\nor\r\n\r\n```\r\nintersects([&quot;a&quot;, &quot;b&quot;, &quot;c&quot;]; [&quot;d&quot;, &quot;e&quot;, &quot;f&quot;]) # false\r\n```\r\n",
                "title": "In jq, how to select objects where an array contains at least one value (intersection non-empty)"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1708710869,
        "creation_date": 1607594940,
        "question_id": 65232444,
        "body_markdown": "I have input like this:\r\n\r\n    { &quot;prop&quot;: [&quot;apple&quot;, &quot;banana&quot;] }\r\n    { &quot;prop&quot;: [&quot;kiwi&quot;, &quot;banana&quot;] }\r\n    { &quot;prop&quot;: [&quot;cherry&quot;, &quot;orange&quot;] }\r\n\r\nHow do I print objects where prop contains at least one of kiwi and orange?\r\n\r\n(The list of interesting values is longer than just 2, so I&#39;d like to leverage the `any` function somehow.)\r\n\r\nI&#39;ve tried the following\r\n\r\n    jq &#39;select(any(.prop[] | contains([&quot;kiwi&quot;, &quot;orange&quot;])))&#39; &lt; input.json\r\n\r\nand various variants of the above, but can&#39;t figure out the right expressions.",
        "link": "https://stackoverflow.com/questions/65232444/in-jq-how-to-select-objects-where-an-array-contains-at-least-one-value-interse",
        "title": "In jq, how to select objects where an array contains at least one value (intersection non-empty)"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607644505,
                "last_edit_date": 1607644505,
                "creation_date": 1607623318,
                "answer_id": 65239870,
                "question_id": 65234659,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First construct a dictionary, and then use it to perform the update:\r\n```\r\njq --argfile new 2.json &#39;\r\n ($new | INDEX(.NAME)) as $dict\r\n | .objects.ne_110m_admin_0_countries.geometries[].properties\r\n     |= (if $dict[.NAME] then . + $dict[.NAME] else . end)\r\n&#39; 1.json\r\n```\r\n\r\n## Incidentally ...\r\nThe hardest part here was determining the relevant path.  jq came to the rescue:\r\n\r\n    jq -c &#39;paths(. == &quot;Afghanistan&quot;)&#39; 1.json\r\n\r\nAnother possibility would have been to blindly update every value associated with &quot;properties&quot;:\r\n```\r\n($new | INDEX(.NAME)) as $dict\r\n| walk(if type == &quot;object&quot; and .properties\r\n       then .properties |= . + $dict[.NAME]\r\n       else . end)\r\n```\r\nThis actually produces the same result.",
                "title": "Merging two JSON files with common key values when there are other objects in the file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607644736,
        "creation_date": 1607603742,
        "last_edit_date": 1607644736,
        "question_id": 65234659,
        "body_markdown": "I have two JSON files I&#39;m trying to merge, one is here:\r\n\r\nFile 1: \r\n\r\nhttps://raw.githubusercontent.com/zcreativelabs/react-simple-maps/master/topojson-maps/world-110m.json\r\n\r\nFile 2:\r\n\r\nhttps://gist.github.com/ArchieHicklin/764812b232a6cdc157d50da40bc033a5\r\n\r\nFile 1 begins with a topology object and array and a lot of stuff that can be ignored:\r\n\r\n    {\r\n    &quot;type&quot;: &quot;Topology&quot;,\r\n    &quot;arcs&quot;: [\r\n        [\r\n            [16814, 15074],\r\n            [71, -45],\r\n            [53, 16],\r\n            [15, 54],\r\n            [55, 18],\r\n            [39, 37],\r\n            [14, 95],\r\n            [59, 24],\r\n            [11, 42],\r\n            [32, -32],\r\n            [21, -3]\r\n        ],\r\n...\r\n\r\nThen goes into an array of countries (this is the part I want to add values to):\r\n\r\n    &quot;objects&quot;: {\r\n        &quot;ne_110m_admin_0_countries&quot;: {\r\n            &quot;type&quot;: &quot;GeometryCollection&quot;,\r\n            &quot;geometries&quot;: [{\r\n                &quot;arcs&quot;: [\r\n                    [0, 1, 2, 3, 4, 5]\r\n                ],\r\n                &quot;type&quot;: &quot;Polygon&quot;,\r\n                &quot;properties&quot;: {\r\n                    &quot;NAME&quot;: &quot;Afghanistan&quot;,\r\n                    &quot;NAME_LONG&quot;: &quot;Afghanistan&quot;,\r\n                    &quot;ABBREV&quot;: &quot;Afg.&quot;,\r\n                    &quot;FORMAL_EN&quot;: &quot;Islamic State of Afghanistan&quot;,\r\n                    &quot;POP_EST&quot;: 34124811,\r\n                    &quot;POP_RANK&quot;: 15,\r\n                    &quot;GDP_MD_EST&quot;: 64080,\r\n                    &quot;POP_YEAR&quot;: 2017,\r\n                    &quot;GDP_YEAR&quot;: 2016,\r\n                    &quot;ISO_A2&quot;: &quot;AF&quot;,\r\n                    &quot;ISO_A3&quot;: &quot;AFG&quot;,\r\n                    &quot;CONTINENT&quot;: &quot;Asia&quot;,\r\n                    &quot;REGION_UN&quot;: &quot;Asia&quot;,\r\n                    &quot;SUBREGION&quot;: &quot;Southern Asia&quot;\r\n                }\r\n            },\r\n\r\nFile 2 has an array of the same countries but with additional values:\r\n\r\n    { &quot;NAME&quot;: &quot;Afghanistan&quot;, &quot;BRANDONE&quot;: &quot;Xiaomi&quot;, &quot;BRANDTWO&quot;: &quot;Apple&quot;, &quot;BRANDTHREE&quot;: &quot;Huawei&quot;, &quot;BRANDFOUR&quot;: &quot;Unknown&quot;, &quot;BRANDFIVE&quot;: &quot;Samsung&quot;, &quot;BRANDSIX&quot;: &quot;Oppo&quot; },\r\n\r\n\r\nAs you can see the common value key between File 1 and File 2 is &quot;NAME&quot;.\r\n\r\nIdeally I&#39;d like to merge the files so the original file includes the extra values from the other file eg:\r\n\r\n    &quot;objects&quot;: {\r\n    &quot;ne_110m_admin_0_countries&quot;: {\r\n        &quot;type&quot;: &quot;GeometryCollection&quot;,\r\n        &quot;geometries&quot;: [{\r\n            &quot;arcs&quot;: [\r\n                [0, 1, 2, 3, 4, 5]\r\n            ],\r\n            &quot;type&quot;: &quot;Polygon&quot;,\r\n            &quot;properties&quot;: {\r\n                &quot;NAME&quot;: &quot;Afghanistan&quot;,\r\n                &quot;NAME_LONG&quot;: &quot;Afghanistan&quot;,\r\n                &quot;ABBREV&quot;: &quot;Afg.&quot;,\r\n                &quot;FORMAL_EN&quot;: &quot;Islamic State of Afghanistan&quot;,\r\n                &quot;POP_EST&quot;: 34124811,\r\n                &quot;POP_RANK&quot;: 15,\r\n                &quot;GDP_MD_EST&quot;: 64080,\r\n                &quot;POP_YEAR&quot;: 2017,\r\n                &quot;GDP_YEAR&quot;: 2016,\r\n                &quot;ISO_A2&quot;: &quot;AF&quot;,\r\n                &quot;ISO_A3&quot;: &quot;AFG&quot;,\r\n                &quot;CONTINENT&quot;: &quot;Asia&quot;,\r\n                &quot;REGION_UN&quot;: &quot;Asia&quot;,\r\n                &quot;SUBREGION&quot;: &quot;Southern Asia&quot;,\r\n                &quot;BRANDONE&quot;: &quot;Xiaomi&quot;, \r\n                &quot;BRANDTWO&quot;: &quot;Apple&quot;, \r\n                &quot;BRANDTHREE&quot;: &quot;Huawei&quot;, \r\n                &quot;BRANDFOUR&quot;: &quot;Unknown&quot;, \r\n                &quot;BRANDFIVE&quot;: &quot;Samsung&quot;, \r\n                &quot;BRANDSIX&quot;: &quot;Oppo&quot;\r\n            }\r\n        },\r\n\r\nI&#39;ve tried lots of merge answers on here but when I merge \r\n\r\n(such as `jq -s &#39;[ .[0] + .[1] | group_by(.NAME)[] | select(length &gt; 1) | add ]&#39; clean.json world.json`)\r\n\r\nBut I always end up with an error:\r\n\r\n `jq: error (at file2.json:13575): array ([{&quot;NAME&quot;:&quot;A...) and object ({&quot;type&quot;:&quot;To...) cannot be added`\r\n\r\nDoes anyone know if what I&#39;m trying to do is achievable in jq? And why do I always get an error?\r\n\r\nThank you.",
        "link": "https://stackoverflow.com/questions/65234659/merging-two-json-files-with-common-key-values-when-there-are-other-objects-in-th",
        "title": "Merging two JSON files with common key values when there are other objects in the file"
    },
    {
        "tags": [
            "jq",
            "bson"
        ],
        "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": 1607684249,
                "post_id": 65249952,
                "comment_id": 115355536,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607701128,
                "creation_date": 1607701128,
                "answer_id": 65254282,
                "question_id": 65249952,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like your &quot;JSON&quot; is actually BSON, which can be converted to JSON using bsondump provided by MongoDB (see e.g. https://docs.mongodb.com/manual/reference/program/bsondump/).  There are other BSON-to-JSON tools you can find by googling.\r\n\r\n**If** your BSON is sufficiently small (as is the case with your sample), another possibility would be to handle it as though it is jq source code; you would of course also have to provide functions such as `ObjectId`, e.g. like so:\r\n\r\n    def ObjectId($s): &quot;ObjectID:\\($s)&quot;;\r\n    def Date($s): &quot;Date:\\($s)&quot;;\r\n\r\nUsing this approach with your BSON and query, invoking jq with the -n option yields:\r\n```\r\n[\r\n  &quot;Rahul Joshi&quot;,\r\n  &quot;Rahul&quot;\r\n]\r\n```\r\n\r\n\r\n",
                "title": "jq extract data including ObjectId"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607703582,
        "creation_date": 1607684008,
        "last_edit_date": 1607703582,
        "question_id": 65249952,
        "body_markdown": "This data i&#39;m trying to extract fields like &quot;n&quot;,&quot;fn&quot; however its weird i can&#39;t using jq\r\n\r\n    jq -r &#39;[.n, .fn] \r\n    \r\n    { &quot;_id&quot; : ObjectId( &quot;575a7c43df2e246028c9c0d2&quot; ), &quot;_class&quot; : &quot;com.go.next.cms.entity.User&quot;, &quot;n&quot; : &quot;Rahul Joshi&quot;, &quot;fn&quot; : &quot;Rahul&quot;, &quot;ln&quot; : &quot;Joshi&quot;, &quot;un&quot; : &quot;1198383883&quot;, &quot;p&quot; : &quot;av3o1fo6h236j5bu9ue8oq380jm1t7p&quot;, &quot;e&quot; : &quot;a@gmail.com&quot;, &quot;emailVerified&quot; : true, &quot;k&quot; : &quot;55394505-dd92-4b1a-b96a-a1c433662abc&quot;, &quot;o_tokens&quot; : { &quot;575a7c43df2e246028c9c0d2~iximacb~411e35964795733b&quot; : &quot;6dghooxc0bxhsj9vmw2e4bu5aav3o1fo6h236j5bu9ue8oq3w13r2jd73ku8hbjhkjesa80jm1t7pmsaarmaupndhcb1disieobpkarokhc29880suct42kppmrfqjy948ufmhifdew9depicf9y5wqchlba66nl5roww35ee0b4jqwkm04b9rb8one1u4h7dlp&quot;, &quot;575a7c43df2e246028c9c0d2~iximaad~411e35964795733b&quot; : &quot;liwscmgb9an3111y2oxu0xabu3qcrmxwjpjntof3r6ax7pmp0hx65xpyp5jm0bkogq0ddkg18gnlr5nofssge6lodlk3focpwee1tlilye4n9h01m5u9odxpkma2kovl4ilgseoijl99y680j6i57643jm8t0dqcwxm0pde7w1rngusb0voljn2xwp8vbwbdnqx&quot;, &quot;575a7c43df2e246028c9c0d2~iximatr~8577b27bf06cd78&quot; : &quot;j8vs2ymueh03hifiowfhij79sd2gcng2gd3sgb6frxs09xi443xumwe9rfvs2ps3o1ol63pib7aqhqit3eg0evjq6dawu9a3uj70cd0kf2i41bnp3n0q7ry3vblso0bb51y3ktvyq390h8192uusupe1pwui7h76fyq9a8ryo8jbspaomsl147ifp1npcpsrte2&quot;, &quot;575a7c43df2e246028c9c0d2~iximaad~8577b27bf06cd78&quot; : &quot;m8gnne9cwadtwq0s0r43p7788h43hn3f9m3g1h6hagvdm8v9x6d7mvfuyuq97rhx6axobs8p2fac5wrie3a6pyaia5aq320eeh60lggbtuu816rhfg42rg3b46x356dujeo1fyeu1cawlupst78hudmx283dtg76wdalsfhij34pjx1i8tdydpihipsjysctwio&quot; }, &quot;wc&quot; : 0, &quot;role&quot; : [ &quot;registered_user&quot; ], &quot;metaUserId&quot; : 1980469, &quot;t&quot; : &quot;ya29.GlslBaPrIStUyWrejOrmxAui7DkbLRg8wzAE1Aj73U-X7rhxFLekZWPu-z_ywUS-OWO2VVcbTIPC37XorBHg-2vvkJmpqov1uPCmR5HKHW_gbcEKU6FZApW4wJYq&quot;, &quot;rt&quot; : &quot;1/isjRuytVLOeMVAytcvNVTWp_radi88Nc40IqzXOJQGvhufKyPjE99hZyGUzbWFmd&quot;, &quot;up&quot; : &quot;https://lh5.googleusercontent.com/DpBXPPCkSk0/photo.jpg&quot;, &quot;ad&quot; : { &quot;_id&quot; : null, &quot;countryCode&quot; : &quot;in&quot;, &quot;_v&quot; : 0, &quot;_cd&quot; : Date( 1465547843305 ), &quot;_ugc&quot; : false, &quot;_inflow&quot; : false }, &quot;au&quot; : false, &quot;po&quot; : 0, &quot;friends&quot; : 0, &quot;rejectedReviews&quot; : 0, &quot;ex&quot; : false, &quot;usrc&quot; : &quot;iximaad&quot;, &quot;ld&quot; : Date( 1480425174813 ), &quot;age&quot; : 0, &quot;contactNumber&quot; : { &quot;number&quot; : &quot;931128098&quot;, &quot;prefix&quot; : &quot;91&quot;, &quot;emailId&quot; : &quot;a@gmail.com&quot; }, &quot;contactNumberVerified&quot; : true, &quot;travellers&quot; : [ { &quot;_id&quot; : ObjectId( &quot;5a366b73ba9e7f124f496060&quot; ), &quot;travellerType&quot; : &quot;Adult&quot;, &quot;title&quot; : &quot;Mr&quot;, &quot;firstName&quot; : &quot;Rahul &quot;, &quot;lastName&quot; : &quot;Joshi&quot;, &quot;editableTraveller&quot; : true, &quot;primary&quot; : false, &quot;frequentFlierNumberList&quot; : [], &quot;seniorCitizen&quot; : false, &quot;_v&quot; : 0, &quot;_cd&quot; : Date( 1513515891223 ), &quot;_ugc&quot; : false, &quot;_inflow&quot; : false }, { &quot;_id&quot; : ObjectId( &quot;5a366ba14f173f177ebda9ec&quot; ), &quot;travellerType&quot; : &quot;Adult&quot;, &quot;title&quot; : &quot;Mr&quot;, &quot;firstName&quot; : &quot;Pritash&quot;, &quot;lastName&quot; : &quot;Thakar &quot;, &quot;editableTraveller&quot; : true, &quot;primary&quot; : false, &quot;frequentFlierNumberList&quot; : [], &quot;seniorCitizen&quot; : false, &quot;_v&quot; : 0, &quot;_cd&quot; : Date( 1513515937071 ), &quot;_ugc&quot; : false, &quot;_inflow&quot; : false } ], &quot;totalRewardPoints&quot; : 0, &quot;reedemedRewardPoints&quot; : 0, &quot;activityRewardPoints&quot; : {}, &quot;activityTotalRewardPoints&quot; : {}, &quot;ltc&quot; : false, &quot;loginType&quot; : &quot;signup&quot;, &quot;otpVerified&quot; : true, &quot;verifiedNumber&quot; : &quot;9320119998&quot;, &quot;gcmId&quot; : [], &quot;prc&quot; : 0, &quot;accounts&quot; : {}, &quot;en&quot; : true, &quot;migrated&quot; : false, &quot;mailAccounts&quot; : {}, &quot;partnerUserParams&quot; : { &quot;go&quot; : { &quot;partnerUserId&quot; : &quot;118108096894957046911&quot; } }, &quot;places&quot; : {}, &quot;_v&quot; : 0, &quot;_cd&quot; : Date( 1465547843305 ), &quot;_ugc&quot; : false, &quot;_inflow&quot; : false }\r\n\r\n\r\nHow i can slove this problem ?",
        "link": "https://stackoverflow.com/questions/65249952/jq-extract-data-including-objectid",
        "title": "jq extract data including ObjectId"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1607690524,
                "post_id": 65251540,
                "comment_id": 115357973,
                "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"
                },
                "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": 1607691105,
                "post_id": 65251540,
                "comment_id": 115358224,
                "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": 1607725321,
                "post_id": 65251540,
                "comment_id": 115372689,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1607690352,
                "creation_date": 1607690352,
                "answer_id": 65251541,
                "question_id": 65251540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nFrom the manual\r\n```\r\n    --compact-output / -c:\r\n```\r\n&gt; By default, jq pretty-prints JSON output. Using this option will result in more compact output by instead putting each JSON object on a single line.\r\n\r\ncan stand in front and behind the filter\r\n```\r\n echo &#39;{&quot;name&quot;:&quot;New release&quot;,&quot;description&quot;:&quot;Super nice release&quot;,&quot;milestones&quot;:[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]}&#39; | jq -c &#39;.milestones&#39;\r\n\r\n[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]\r\n\r\n```\r\n```\r\n echo &#39;{&quot;name&quot;:&quot;New release&quot;,&quot;description&quot;:&quot;Super nice release&quot;,&quot;milestones&quot;:[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]}&#39; | jq &#39;.milestones&#39; -c \r\n\r\n[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]\r\n\r\n```\r\n",
                "title": "How to print results of jq in single row, not pretty formatted"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1607690352,
        "creation_date": 1607690352,
        "question_id": 65251540,
        "body_markdown": "How can jq get convinced to return results in one row?\r\nWithout any options, the results get formatted\r\n```\r\n echo &#39;{&quot;name&quot;:&quot;New release&quot;,&quot;description&quot;:&quot;Super nice release&quot;,&quot;milestones&quot;:[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]}&#39; | jq &#39;.milestones&#39;\r\n\r\n[\r\n  &quot;v1.0&quot;,\r\n  &quot;v1.0-rc&quot;\r\n]\r\n\r\n```\r\n\r\n\r\nI would like to have it in one row:\r\n```\r\n echo &#39;{&quot;name&quot;:&quot;New release&quot;,&quot;description&quot;:&quot;Super nice release&quot;,&quot;milestones&quot;:[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]}&#39; | jq &#39;.milestones&#39;\r\n\r\n[&quot;v1.0&quot;,&quot;v1.0-rc&quot;]\r\n\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65251540/how-to-print-results-of-jq-in-single-row-not-pretty-formatted",
        "title": "How to print results of jq in single row, not pretty formatted"
    },
    {
        "tags": [
            "bash",
            "jq",
            "github-actions"
        ],
        "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": 1607730056,
                "post_id": 65260018,
                "comment_id": 115373866,
                "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": 1607730069,
                "post_id": 65260018,
                "comment_id": 115373869,
                "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": 1607730144,
                "post_id": 65260018,
                "comment_id": 115373889,
                "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": 1607730274,
                "post_id": 65260018,
                "comment_id": 115373917,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607730630,
                "post_id": 65260018,
                "comment_id": 115373986,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607730268,
                "creation_date": 1607730268,
                "answer_id": 65260096,
                "question_id": 65260018,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`--arg` will treat your value as a literal string, so the quotes and commas won&#39;t have any effect. \r\n\r\nYou can instead format your list as a valid JSON list, and use `--argjson`:\r\n\r\n    testValues=&#39;[ &quot;value1&quot;, &quot;value2&quot; ]&#39;\r\n    jq --argjson TESTVALUES &quot;$testValues&quot; &#39;.[] | select(.name==($TESTVALUES[]))&#39; file.json\r\n\r\nOr perhaps even better, specify some delimiter and have jq split up your string instead, so you don&#39;t have to worry about JSON escaping:\r\n\r\n    testValues=&#39;value1,value2&#39;\r\n    jq --arg TESTVALUES &quot;$testValues&quot; &#39;.[] | select(.name==($TESTVALUES | split(&quot;,&quot;)[]))&#39; file.json\r\n",
                "title": "Pass Bash comma delimited string values variable to jq arg filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1607730268,
        "creation_date": 1607729526,
        "question_id": 65260018,
        "body_markdown": "I am trying to filter data from a json file using jq with a filter based on a dynamic list of values from within a Bash script.\r\n\r\nThe following jq command works by itself:\r\n\r\n```\r\njq -r &#39;.[] | select(.name==(&quot;value1&quot;,&quot;value2&quot;))&#39; file.json\r\n```\r\n\r\nIn Bash the following command works if I set the variable to a single value and pass it in\r\n\r\n```    \r\ntestValue=&quot;value1&quot;\r\nresult=$(jq -r --arg TESTVALUE &quot;$testValue&quot; &#39;.[] | select(.name==($TESTVALUE))&#39; file.json)\r\necho &quot;$result&quot;\r\n```\r\n\r\nIf I set the variable to a comma delimited list of values and pass it in it returns no results\r\n\r\n```    \r\ntestValues=&quot;\\&quot;value1\\&quot;, \\&quot;value2\\&quot;&quot;\r\nresult=$(jq -r --arg TESTVALUES &quot;$testValues&quot; &#39;.[] | select(.name==($TESTVALUES))&#39; file.json)\r\necho &quot;$result&quot;\r\n```\r\n\r\nI am a novice in bash scripting, so I am sure I am missing something simple in how the variable is being interpreted.  I have included the file.json below as well.\r\n\r\n```\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;value1&quot;,\r\n        &quot;test&quot;: &quot;blah1&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;value2&quot;,\r\n        &quot;test&quot;: &quot;blah2&quot;\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/65260018/pass-bash-comma-delimited-string-values-variable-to-jq-arg-filter",
        "title": "Pass Bash comma delimited string values variable to jq arg filter"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607731732,
                "post_id": 65260214,
                "comment_id": 115374183,
                "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"
                },
                "reply_to_user": {
                    "account_id": 8306545,
                    "reputation": 58596,
                    "user_id": 6243352,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/193965abcb7230d85c6264e55e2f0bda?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "ggorlen",
                    "link": "https://stackoverflow.com/users/6243352/ggorlen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607732611,
                "post_id": 65260214,
                "comment_id": 115374367,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1607733899,
                "last_edit_date": 1607733899,
                "creation_date": 1607732669,
                "answer_id": 65260330,
                "question_id": 65260214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this:\r\n\r\n    jq &#39;.dependencies[]=&quot;latest&quot;&#39; package.json\r\n\r\nOutput:\r\n\r\n    {\r\n      &quot;dependencies&quot;: {\r\n        &quot;body-parser&quot;: &quot;latest&quot;,\r\n        &quot;eslint&quot;: &quot;latest&quot;,\r\n        &quot;express&quot;: &quot;latest&quot;\r\n      }\r\n    }",
                "title": "Change value for all keys with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1607733917,
                "creation_date": 1607733917,
                "answer_id": 65260452,
                "question_id": 65260214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A succinct, precise, and easy-to-read solution:\r\n\r\n    .dependencies |= map_values(&quot;latest&quot;)",
                "title": "Change value for all keys with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1607824135,
                "creation_date": 1607824135,
                "answer_id": 65271671,
                "question_id": 65260214,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if `package.json` by chance contains nested items, like this:\r\n\r\n    {\r\n      &quot;dependencies&quot;: {\r\n        &quot;body-parser&quot;: &quot;^1.19.0&quot;,\r\n        &quot;eslint&quot;: &quot;^7.15.0&quot;,\r\n        &quot;express&quot;: &quot;^4.17.1&quot;,\r\n        &quot;branch&quot;: {\r\n            &quot;alternative&quot;: &quot;^1.2.3&quot;\r\n        }\r\n      } \r\n    }\r\nthen an alternative (non-jq) solution, using `jtc` would look like this:\r\n```\r\n&lt;package.json jtc -w&#39;&lt;&gt;a:&#39; -u&#39;&quot;latest&quot;&#39;\r\n```\r\n\\- that solution won&#39;t break the original JSON structure.\r\n\r\nPS. I&#39;m the developer of `jtc` unix JSON processor.  \r\nPPS. the disclaimer is required by SO. ",
                "title": "Change value for all keys with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1607824135,
        "creation_date": 1607731445,
        "last_edit_date": 1607757211,
        "question_id": 65260214,
        "body_markdown": "I have this package.json\r\n\r\n```\r\n{\r\n  &quot;dependencies&quot;: {\r\n    &quot;body-parser&quot;: &quot;^1.19.0&quot;,\r\n    &quot;eslint&quot;: &quot;^7.15.0&quot;,\r\n    &quot;express&quot;: &quot;^4.17.1&quot;\r\n  } \r\n} \r\n```\r\n\r\nwith this command :\r\n\r\n```\r\njq &#39;.dependencies.eslint=&quot;latest&quot;|.dependencies.express=&quot;latest&quot;&#39; package.json\r\n```\r\n\r\nI got this result :\r\n```\r\n{\r\n  &quot;dependencies&quot;: {\r\n    &quot;body-parser&quot;: &quot;^1.19.0&quot;,\r\n    &quot;eslint&quot;: &quot;latest&quot;,\r\n    &quot;express&quot;: &quot;latest&quot;\r\n  }\r\n}\r\n```\r\n\r\nHow can I change all versions to &quot;latest&quot; without enumerating individual keys ?",
        "link": "https://stackoverflow.com/questions/65260214/change-value-for-all-keys-with-jq",
        "title": "Change value for all keys with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "default",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1607740644,
                "creation_date": 1607740644,
                "answer_id": 65261062,
                "question_id": 65260809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Of course right after posting this, I figure it out. The solution I came up with is to flatten the array of objects into a single object, using the `add()` function. \r\n\r\nSo this filter:\r\n```\r\n[.[] | { (.name): .value }] | add\r\n```\r\nproduces:\r\n```json\r\n{\r\n  &quot;alpha&quot;: 1,\r\n  &quot;beta&quot;: 2\r\n}\r\n```\r\nAnd then to select the individual fields I&#39;m interested in, it&#39;s basic object creation; e.g. `| {alpha, beta, gamma}` (where &quot;gamma&quot; is missing from the input array) produces:\r\n```json\r\n{\r\n  &quot;alpha&quot;: 1,\r\n  &quot;beta&quot;: 2,\r\n  &quot;gamma&quot;: null\r\n}\r\n```\r\nIn case anyone wants to play around with this: https://jqplay.org/s/vqEYyGCg7W\r\n\r\nI&#39;ll leave this question open for awhile, in case someone has a better solution!",
                "title": "How to use fallback value when jq select() returns false"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1607755284,
                "last_edit_date": 1607755284,
                "creation_date": 1607745289,
                "answer_id": 65261447,
                "question_id": 65260809,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq-esque solution to the problem is illustrated by:\r\n\r\n    jq &#39;from_entries | {alpha, beta, gamma}&#39; input.json\r\n\r\nThis will convert the array to an object, and then select the values corresponding to the specified keys if present, while also ensuring all the specified keys are present.\r\n\r\n## Keylist\r\n\r\nIf you have a JSON array of key namess (say $keylist), you could write:\r\n```\r\nfrom_entries as $in\r\n| reduce $keylist[] as $key ({}; .[$key]=$in[$key])\r\n\r\n```\r\n\r\n## Fallback value\r\n\r\nOr if you want to specify your own fallback value, say $default:\r\n\r\n```\r\nfrom_entries as $in\r\n| reduce $keylist[] as $key ({}; .[$key] = $in[$key] // $default)\r\n\r\n```\r\n\r\nor perhaps (depending on your detailed requirements):\r\n```\r\nfrom_entries as $in\r\n| reduce $keylist[] as $key ({};\r\n    .[$key] = if ($in | has($key)) then $in[$key] else $default end)\r\n```\r\n",
                "title": "How to use fallback value when jq select() returns false"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1607755352,
        "creation_date": 1607737946,
        "last_edit_date": 1607755352,
        "question_id": 65260809,
        "body_markdown": "Let&#39;s say I have a JSON array like this:\r\n```json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;alpha&quot;,\r\n        &quot;value&quot;: 1\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;beta&quot;,\r\n        &quot;value&quot;: 2\r\n    },\r\n    ...\r\n]\r\n```\r\n(It contains about 50-100 items; this is a simplified example.)\r\n\r\nI want to produce a JSON object from it like this:\r\n```json\r\n{\r\n  &quot;alpha&quot;: 1,\r\n  &quot;beta&quot; 2,\r\n  ...\r\n}\r\n```\r\n\r\nI _think_ the jq filter for it looks something like this:\r\n```\r\n.[] | { \r\n  &quot;alpha&quot;: select(.name == &quot;alpha&quot;) | .value,\r\n  &quot;beta&quot;: select(.name == &quot;beta&quot;) | .value,\r\n  ...\r\n}\r\n```\r\n\r\nThat doesn&#39;t actually work when I try it on https://jqplay.org/s/SOKd4oCh2k, but I think it&#39;s pretty close.\r\n\r\nOK now here&#39;s the tricky part: sometimes the object with `&quot;name&quot;: &quot;alpha&quot;` (or `&quot;name&quot;: &quot;beta&quot;`, etc.) won&#39;t actually exist in the input array! In that case, I want to print `&quot;alpha&quot;: null` or `&quot;alpha&quot;: &quot;&quot;`. But I can&#39;t figure out how to integrate that into my `select()` call.\r\n\r\nIn practice I need this to scrape job metrics from a batch scheduling system, where I&#39;m changing the metrics over time as I run performance tests, so any given metric that I&#39;m querying might not exist for a particular job run, but I still want to see all the _other_ metrics from that job run.",
        "link": "https://stackoverflow.com/questions/65260809/how-to-use-fallback-value-when-jq-select-returns-false",
        "title": "How to use fallback value when jq select() returns false"
    },
    {
        "tags": [
            "json",
            "jq",
            "projection"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607878652,
                "creation_date": 1607878652,
                "answer_id": 65278232,
                "question_id": 65277686,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First select the fields, then modify `ipAddressTab`.\r\n``` none\r\nmap({network, ipAddressTab, full}\r\n    | .ipAddressTab[] |= {foo1, foo3})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/HjbVSbnHgi)&lt;/sup&gt;",
                "title": "Select multiple fields at different levels"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1608364196,
        "creation_date": 1607875572,
        "last_edit_date": 1608364196,
        "question_id": 65277686,
        "body_markdown": "I&#39;ve a .json file that look like :\r\n\r\n```\r\n[\r\n    {\r\n        &quot;network&quot;: &quot;X.X.X.1&quot;,\r\n        &quot;defaultGateway&quot;: &quot;X.X.X.X&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {   \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n        &quot;id&quot;: &quot;xxx&quot;\r\n    },\r\n     {\r\n        &quot;network&quot;: &quot;X.X.X.2&quot;,\r\n        &quot;defaultGateway&quot;: &quot;X.X.X.X&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {   \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n        &quot;id&quot;: &quot;xxx&quot;\r\n    }\r\n]\r\n\r\n```\r\n\r\nThe first thing that I try that is to display each element like that :\r\n```\r\ncat myfile.txt | jq &#39;.[]| {network: .network, ipAddressTab: .ipAddressTab}&#39;\r\n\r\n```\r\n\r\nEach lines of the file xas displayed.\r\n\r\nNow, I want to display some lines :\r\n\r\n - network\r\n - ipAddressTab\r\n - foo1\r\n - foo3\r\n\r\n```\r\n   {\r\n        &quot;network&quot;: &quot;X.X.X.1&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n           \r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n            \r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n             \r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n            \r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n            \r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n    },\r\n     {\r\n        &quot;network&quot;: &quot;X.X.X.2&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n           \r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n          \r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo3&quot;: &quot;reserved&quot;,\r\n            \r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n          \r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n\r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;foo3&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n    }\r\n]\r\n```\r\n\r\nI&#39;ve try something like :\r\n```\r\ncat myfile.txt | jq &#39;.[]| {network: .network, ipAddressTab: .ipAddressTab(.foo1, .foo3)}&#39;\r\ncat myfile.txt | jq &#39;.[]| {network: .network, ipAddressTab: .ipAddressTab[.foo1, .foo3]}&#39;\r\n\r\n```\r\n\r\nBut it doesn&#39;t work !\r\n\r\nSome one to show me how to display each elements that I need ?\r\n\r\nThansk a lot !",
        "link": "https://stackoverflow.com/questions/65277686/select-multiple-fields-at-different-levels",
        "title": "Select multiple fields at different levels"
    },
    {
        "tags": [
            "json",
            "csv",
            "parent-child",
            "jq",
            "transitive-closure"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11958806,
                    "reputation": 626,
                    "user_id": 9287163,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5a25f88bb7e0f15afd93347fb9f9b2d1?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "krishank Tripathi",
                    "link": "https://stackoverflow.com/users/9287163/krishank-tripathi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607928063,
                "post_id": 65278602,
                "comment_id": 115416033,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607925045,
                "last_edit_date": 1607925045,
                "creation_date": 1607923702,
                "answer_id": 65284040,
                "question_id": 65278602,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To fill in the details about children recursively can most easily be\r\naccomplished using a recursive function -- here `closure/2`, which is written so as to be quite efficient.\r\n```\r\ndef obj($headers):\r\n  . as $in\r\n  | reduce range(0; $headers|length) as $i ({}; \r\n      .[$headers[$i]] = $in[$i]);\r\n\r\n# input:  either the id of an individual or \r\n#         an object representing an individual;\r\n# output: the same individual but with .children and recursively\r\n#         their children as an array of objects\r\ndef closure($dictionary; $children):\r\n  def c: \r\n    if type == &quot;string&quot; then $dictionary[.] | c\r\n    elif type==&quot;object&quot;\r\n    then if has(&quot;children&quot;)\r\n         then if (.children|length)&gt;0 then .children = map(c) else . end\r\n         elif $children[.id] then .children = ($children[.id] | map(c))\r\n         else . end\r\n    else . end;\r\n  c;\r\n\r\nsplit(&quot;,&quot;) as $headers\r\n| [ inputs\r\n    | split(&quot;,&quot;)\r\n    | map_values(if . == &quot;Null&quot; then null else . end)\r\n    | obj($headers) ]\r\n| INDEX(.[]; .id) as $ids   # a dictionary mapping id =&gt; object\r\n| (reduce .[] as $row ({};\r\n      if $row.parent_id\r\n      then .[$row.parent_id] += [$row.id]\r\n      else . end ) ) as $children  # string =&gt; [ string ]\r\n| map(closure($ids; $children) )\r\n# tidy up:\r\n| walk(if type==&quot;object&quot; \r\n       then if .children and (.children|length) &gt; 0 \r\n            then del(.size)\r\n            else . end\r\n       | del(.parent_id)\r\n       else . end)\r\n```\r\n",
                "title": "JQ, convert CSV (parent child format) to JSON, another questions"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1607927569,
        "creation_date": 1607880701,
        "last_edit_date": 1607927569,
        "question_id": 65278602,
        "body_markdown": "This is a continue of another post:\r\nhttps://stackoverflow.com/questions/65190223/jq-convert-csv-parent-child-format-to-json/65191089\r\n\r\n\r\nHi, sorry to ask again. I tried to get the following format, without success. Really appreciate for some advice. I attach a picture to show how it looks like in a hierarchy view [a picture to show in a hierarchy way][1], maybe it is easier. Hope it is possible ?\r\n\r\n*** CSV file *****\r\n&lt;Pre&gt;\r\nid,parent_id,size\r\nSubject,Null,1\r\nanalytics,Subject,1\r\ncluster,analytics,1\r\nAgglomerativeCluster,cluster,1\r\nMergeEdge,cluster,2\r\nanimate,Subject,1\r\nEasing,animate,3\r\ninterpolate,animate,1\r\nArrayInterpolator,interpolate,4\r\nRectangleInterpolator,interpolate,5\r\nTween,animate,6\r\n&lt;/Pre&gt;\r\n\r\nHere is the JSON file which I tried to achieve. If it is a parent (has a child under), only show ID. If it is a child, then show ID and Size.\r\n\r\n**** JSON file ****\r\n&lt;Pre&gt;\r\n{\r\n    &quot;ID&quot;: &quot;Subject&quot;,\r\n    &quot;children&quot;: [{\r\n        &quot;ID&quot;: &quot;analytics&quot;,\r\n        &quot;children&quot;: [{\r\n            &quot;ID&quot;: &quot;cluster&quot;,\r\n            &quot;children&quot;: [{\r\n                &quot;ID&quot;: &quot;Aggl,ome,rativeCluster&quot;,\r\n                &quot;size&quot;: 1\r\n            }, {\r\n                &quot;ID&quot;: &quot;MergeEdge&quot;,\r\n                &quot;size&quot;: 2\r\n            }]\r\n        }]\r\n    }, {\r\n        &quot;ID&quot;: &quot;animate&quot;,\r\n        &quot;children&quot;: [{\r\n            &quot;ID&quot;: &quot;Easing&quot;,\r\n            &quot;size&quot;: 3\r\n        }, {\r\n            &quot;ID&quot;: &quot;interpolate&quot;,\r\n            &quot;children&quot;: [{\r\n                &quot;ID&quot;: &quot;ArrayInterpolator&quot;,\r\n                &quot;size&quot;: 4\r\n            }, {\r\n                &quot;ID&quot;: &quot;RectangleInterpolator&quot;,\r\n                &quot;size&quot;: 5\r\n            }]\r\n        }, {\r\n            &quot;ID&quot;: &quot;Tween&quot;,\r\n            &quot;size&quot;: 6\r\n            }]\r\n        }]\r\n}\r\n&lt;/Pre&gt;\r\n\r\n\r\n  [1]: https://i.sstatic.net/yr37q.jpg",
        "link": "https://stackoverflow.com/questions/65278602/jq-convert-csv-parent-child-format-to-json-another-questions",
        "title": "JQ, convert CSV (parent child format) to JSON, another questions"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1607925122,
                "last_edit_date": 1607925122,
                "creation_date": 1607921653,
                "answer_id": 65283805,
                "question_id": 65283527,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a loop there.\r\n``` bash\r\n$ dynamic_values=(&#39;dynamic-value-1&#39; &#39;dynamic-value-2&#39; &#39;dynamic-value-3&#39;)\r\n$ printf &#39;%s\\n&#39; &quot;${dynamic_values[@]}&quot; | jq -nR &#39;{hardcoded_value: false} | .[inputs] = true&#39;\r\n{\r\n  &quot;hardcoded_value&quot;: false,\r\n  &quot;dynamic-value-1&quot;: true,\r\n  &quot;dynamic-value-2&quot;: true,\r\n  &quot;dynamic-value-3&quot;: true\r\n}\r\n```\r\nThis will break if one of the array elements contains a line feed though. For that JQ 1.6 has **--args**, which can be used as shown below.\r\n```\r\n$ dynamic_values=(&#39;dynamic-value-1&#39; $&#39;dynamic-value-2\\n&#39; &#39;dynamic-value-3&#39;)\r\n$ jq -n &#39;{hardcoded_value: false} | .[$ARGS.positional[]] = true&#39; --args &quot;${dynamic_values[@]}&quot;\r\n{\r\n  &quot;hardcoded_value&quot;: false,\r\n  &quot;dynamic-value-1&quot;: true,\r\n  &quot;dynamic-value-2\\n&quot;: true,\r\n  &quot;dynamic-value-3&quot;: true\r\n}\r\n```",
                "title": "How to Add a JSON Field to the Root JSON Object Using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1662425970,
        "creation_date": 1607919413,
        "last_edit_date": 1662425970,
        "question_id": 65283527,
        "body_markdown": "I am trying to create the following JSON object structure:\r\n\r\n```\r\n{\r\n  &quot;hard-coded-value&quot;: false,\r\n  &quot;dynamic-value-1&quot;: true,\r\n  &quot;dynamic-value-2&quot;: true,\r\n  &quot;dynamic-value-3&quot;: true\r\n}\r\n```\r\n\r\nMy array of dynamic values is called `DYNAMIC_VALUES`.\r\n\r\nI wrote the following bash code:\r\n\r\n```\r\nDYNAMIC_VALUES=(&quot;dynamic-value-1&quot; &quot;dynamic-value-2&quot; &quot;dynamic-value-3&quot;)\r\n\r\nJSON_OBJECT=$( jq -n &#39;{&quot;hard-coded-value&quot;: false}&#39; )\r\n\r\nfor i in &quot;${DYNAMIC_VALUES[@]}&quot;\r\ndo\r\n    JSON_OBJECT+=$( jq -n \\\r\n                      --arg key &quot;$i&quot; \\\r\n                      &#39;{($key): true}&#39; )\r\ndone\r\n\r\necho $JSON_OBJECT\r\n```\r\n\r\nThe above code prints the following\r\n\r\n```\r\n{ &quot;hard-coded-value&quot;: false }{ &quot;dynamic-value-1&quot;: true }{ &quot;dynamic-value-2&quot;: true }{ &quot;dynamic-value-3&quot;: true }\r\n```\r\n\r\nWhat I want is this output to look like the output outlined at the top of this question, but I can&#39;t figure out how to tell jq to append to the root JSON object instead of creating a bunch of objects.\r\n",
        "link": "https://stackoverflow.com/questions/65283527/how-to-add-a-json-field-to-the-root-json-object-using-jq",
        "title": "How to Add a JSON Field to the Root JSON Object Using jq"
    },
    {
        "tags": [
            "arrays",
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1607948032,
                "creation_date": 1607948032,
                "answer_id": 65288863,
                "question_id": 65288238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `reduce` to count statuses.\r\n``` none\r\nmap({network, full} +\r\n  reduce .ipAddressTab[].status as $s ({}; .[$s] += 1))\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/pApUlBLhAf)&lt;/sup&gt;\r\n\r\nYou can change `{}` to `{reserved: 0, available: 0}` to maintain a consistent order of keys among all the entries.",
                "title": "How to target and count value with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607949164,
                "last_edit_date": 1607949164,
                "creation_date": 1607948464,
                "answer_id": 65288953,
                "question_id": 65288238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way to do this would be to use a function to count the objects of each type\r\n\r\n```none\r\ndef f($path; $val): $path | map(select(.status == $val)) | length;\r\nmap({network, full, reserved: f(.ipAddressTab; &quot;reserved&quot;), available: f(.ipAddressTab; &quot;available&quot;)})\r\n```\r\n&lt;sup&gt;[jqplay - Demo][1]&lt;/sup&gt;\r\n\r\nThe function `f` takes a path and the status string to be looked-up then gets the length of the objects in the array.\r\n\r\n---\r\n\r\nWith [oguz ismail&#39;s][2] suggestion to avoid repetition \r\n\r\n```none\r\ndef f($val): map(select(.status == $val)) | length; \r\nmap({network, full} + (.ipAddressTab | { reserved: f(&quot;reserved&quot;), available: f(&quot;available&quot;)}))\r\n```\r\n\r\n\r\n  [1]: https://jqplay.org/s/IIwu8K6LSh\r\n  [2]: https://stackoverflow.com/users/10248678/oguz-ismail",
                "title": "How to target and count value with JQ?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607984505,
                "last_edit_date": 1607984505,
                "creation_date": 1607955604,
                "answer_id": 65290619,
                "question_id": 65288238,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When counting a potentially large number of objects, it&#39;s usually better to\r\nuse stream-oriented filters so as to avoid constructing arrays. These two are often useful as a pair, though in the present case defining just `count/1` by itself would be sufficient:\r\n```\r\ndef sigma(s): reduce s as $x (0; .+$x);\r\n\r\ndef count(s): sigma(s|1);\r\n```\r\nTo achieve the stated goal, one can now simply write the specification as a program:\r\n```\r\n\r\nmap({network,\r\n    full,\r\n    reserved:   count(.ipAddressTab[] | select(.status == &quot;reserved&quot;)),\r\n    available:  count(.ipAddressTab[] | select(.status == &quot;available&quot;))\r\n    })\r\n```\r\n\r\n## Generalization\r\n\r\nNow for a little jq magic -- no references to specific &quot;status&quot; values at all:\r\n```\r\ndef countStatus($s):\r\n  {($s): count(.ipAddressTab[] | select(.status == $s))};\r\n\r\ndef statuses: [.ipAddressTab[].status] | unique;\r\n\r\nmap( {network, full}\r\n     + ([countStatus(statuses[])] | add) )\r\n```\r\n\r\n\r\n## total_available\r\n\r\nIn a comment, a question about showing `total_available` was asked.\r\nTo add a `total_available` key to each object, you could append the \r\nfollowing to either of the above pipelines:\r\n```\r\n| {total_available: sigma(.[] | .available)} as $total\r\n| map(. + $total)\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\n\r\n\r\n",
                "title": "How to target and count value with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1607984505,
        "creation_date": 1607945331,
        "question_id": 65288238,
        "body_markdown": "From this file :\r\n```\r\n[\r\n    {\r\n        &quot;network&quot;: &quot;X.X.X.1&quot;,\r\n        &quot;defaultGateway&quot;: &quot;X.X.X.X&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {   \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n        &quot;id&quot;: &quot;xxx&quot;\r\n    },\r\n     {\r\n        &quot;network&quot;: &quot;X.X.X.2&quot;,\r\n        &quot;defaultGateway&quot;: &quot;X.X.X.X&quot;,\r\n        &quot;ipAddressTab&quot;: [\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.1&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.2&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n            },\r\n            {\r\n                &quot;foo1&quot;: &quot;10.0.0.3&quot;,\r\n                &quot;foo2&quot;: &quot;network&quot;,\r\n                &quot;status&quot;: &quot;reserved&quot;,\r\n                &quot;foo4&quot;: null,\r\n                &quot;foo5&quot;: null,\r\n                &quot;foo6&quot;: null,\r\n                &quot;foo7&quot;: null,\r\n                &quot;foo8&quot;: null,\r\n                &quot;foo9&quot;: null,\r\n                &quot;foo10&quot;: null,\r\n                &quot;foo11&quot;: null\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.4&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {   \r\n                &quot;foo1&quot;: &quot;10.0.0.5&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.6&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             },\r\n             {\r\n                &quot;foo1&quot;: &quot;10.0.0.7&quot;,\r\n                &quot;status&quot;: &quot;available&quot;\r\n             }\r\n        ],\r\n        &quot;full&quot;: false,\r\n        &quot;id&quot;: &quot;xxx&quot;\r\n    }\r\n]\r\n\r\n# Just an example, there is more lines in my file\r\n```\r\n\r\nI can keep the informations that I want :\r\n```\r\ncat myfile | jq &#39;map({network, full})&#39;\r\n[\r\n  {\r\n    &quot;network&quot;: &quot;X.X.X.1&quot;,\r\n    &quot;full&quot;: false\r\n  },\r\n  {\r\n    &quot;network&quot;: &quot;X.X.X.2&quot;,\r\n    &quot;full&quot;: false\r\n  }\r\n]\r\n\r\n```\r\n\r\nNow I&#39;m looking for a tip to count and display some values. For example, I would like to display the number of reserved, allocated and available like that :\r\n```\r\n[\r\n  {\r\n    &quot;network&quot;: &quot;X.X.X.1&quot;,\r\n    &quot;full&quot;: false\r\n    reserved: 3\r\n    available: 4\r\n\r\n    \r\n\r\n  },\r\n  {\r\n    &quot;network&quot;: &quot;X.X.X.2&quot;,\r\n    &quot;full&quot;: false\r\n    reserved: 3\r\n    available: 4\r\n\r\n  }\r\n]\r\n``` \r\n\r\nI&#39;ve look everywhere and I found no good example to do that...\r\n\r\nSome one to show me how can I have this output ?\r\n\r\nThanks !",
        "link": "https://stackoverflow.com/questions/65288238/how-to-target-and-count-value-with-jq",
        "title": "How to target and count value with JQ?"
    },
    {
        "tags": [
            "json",
            "jq",
            "ls"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607957475,
                "post_id": 65290874,
                "comment_id": 115427638,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2721473,
                    "reputation": 6789,
                    "user_id": 2347677,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/1fWTO.png?s=256",
                    "display_name": "Greg",
                    "link": "https://stackoverflow.com/users/2347677/greg"
                },
                "reply_to_user": {
                    "account_id": 10648681,
                    "reputation": 13005,
                    "user_id": 7840440,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/8YBUl.png?s=256",
                    "display_name": "Raman Sailopal",
                    "link": "https://stackoverflow.com/users/7840440/raman-sailopal"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607965858,
                "post_id": 65290874,
                "comment_id": 115431680,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1607959177,
                "last_edit_date": 1607959177,
                "creation_date": 1607957720,
                "answer_id": 65291170,
                "question_id": 65290874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;d have to be extra careful in dealing with Unix filenames in general. They can contain almost any character in a filename, including whitespace, newlines, commas, pipe symbols, and pretty much anything else you&#39;d ever try to use as a delimiter except NUL. Your best bet is to separate the names with the NUL character, which is the only character that can&#39;t be part of a valid filename and split on it with `jq`\r\n\r\nUse the native shell `printf` to separate entries on `\\0` and delimit it back\r\n\r\n```bash\r\nprintf &#39;%s\\0&#39; * | jq -Rn &#39;inputs | split(&quot;\\u0000&quot;)&#39;\r\n```\r\n\r\nor for just files\r\n\r\n```bash\r\nfor file in *; do \r\n  [ -f &quot;$file&quot; ] &amp;&amp; printf &#39;%s\\0&#39; &quot;$file&quot;\r\ndone | jq -Rn &#39;inputs | split(&quot;\\u0000&quot;)&#39;\r\n```",
                "title": "read raw input lines and output single array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1607977062,
                "creation_date": 1607977062,
                "answer_id": 65295883,
                "question_id": 65290874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `find` opens up other possibilities:\r\n\r\n    find . -type f -maxdepth 1 -print0 |\r\n      jq -Rs &#39;split(&quot;\\u0000&quot;) | map(sub(&quot;./&quot;;&quot;&quot;))&#39;",
                "title": "read raw input lines and output single array"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1711776372,
                "creation_date": 1711776372,
                "answer_id": 78246912,
                "question_id": 65290874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works. Slightly simpler than what you have:\r\n\r\n```sh\r\nls mydir | jq -sR &#39;split(&quot;\\n&quot;)[0:-1]&#39;\r\n```\r\n\r\n",
                "title": "read raw input lines and output single array"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1711776372,
        "creation_date": 1607956525,
        "last_edit_date": 1607979469,
        "question_id": 65290874,
        "body_markdown": "I have a directory with files in it. I would like to create an array from that list of files. I thought it would be pretty easy, like:\r\n\r\n    ls mydir | jq -R &#39;[.]&#39;\r\n    [\r\n      &quot;file1&quot;\r\n    ]\r\n    [\r\n      &quot;file2&quot;\r\n    ]\r\n    [\r\n      &quot;file3&quot;\r\n    ]\r\n\r\nThe only thing I could figure out is this:\r\n\r\n    ls mydir | jq -sR &#39;[split(&quot;\\n&quot;)[]|select(.|length&gt;0)]&#39;\r\n    [\r\n      &quot;file1&quot;,\r\n      &quot;file2&quot;,\r\n      &quot;file3&quot;\r\n    ]\r\n\r\nIs there a better way?",
        "link": "https://stackoverflow.com/questions/65290874/read-raw-input-lines-and-output-single-array",
        "title": "read raw input lines and output single array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1607978207,
                "post_id": 65296079,
                "comment_id": 115436698,
                "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": 1607978380,
                "post_id": 65296079,
                "comment_id": 115436774,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1237659,
                    "reputation": 252,
                    "user_id": 1200928,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/df780c6a790cef8e181003f5eec419b2?s=256&d=identicon&r=PG",
                    "display_name": "Andrew",
                    "link": "https://stackoverflow.com/users/1200928/andrew"
                },
                "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": 1607978707,
                "post_id": 65296079,
                "comment_id": 115436898,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1607978456,
                "creation_date": 1607978456,
                "answer_id": 65296200,
                "question_id": 65296079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need a `select()` at all here. Consider:\r\n\r\n```\r\njq &#39;.DBInventory.Inventory[0][].folder[].Schemas?.files // empty&#39;\r\n```",
                "title": "Selecting from nested array in JSON using jq gives empty result"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607987397,
                "creation_date": 1607987397,
                "answer_id": 65297832,
                "question_id": 65296079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON data is not completely regular, so you could specify the path of interest more precisely, or sprinkle some &quot;bailouts&quot; (such as `// empty` or `?`) into the query, e.g.:\r\n\r\n    .DBInventory.Inventory[].Sys1 // empty\r\n    | (.folder[].Schemas // empty).files\r\n\r\nor simply:\r\n```\r\ntry (.DBInventory.Inventory[].Sys1.folder[].Schemas.files) // empty\r\n```",
                "title": "Selecting from nested array in JSON using jq gives empty result"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1607987397,
        "creation_date": 1607977909,
        "question_id": 65296079,
        "body_markdown": "I&#39;ve been racking my brains over this because on its face, the jq statement I&#39;m using should produce the desired result, but using a tool like jqplay to test gives me a blank result....\r\n\r\nHere is the JSON I&#39;m using:\r\n\r\n```\r\n{\r\n  &quot;DBInventory&quot;:\r\n    {\r\n      &quot;InventoryID&quot;: &quot;ABSCBD&quot;,\r\n      &quot;Inventory&quot;:[\r\n            {\r\n              &quot;Sys1&quot;: \r\n                {\r\n                  &quot;folder&quot;:[\r\n                    {\r\n                      &quot;Scripts&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1O&quot;,\r\n                            &quot;FileName2O&quot;\r\n                            ]\r\n                        }\r\n                        \r\n                    },\r\n                    {\r\n                      &quot;Schemas&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1S&quot;,\r\n                            &quot;FileName2S&quot;\r\n                            ]\r\n                        }\r\n                                   \r\n                    },\r\n                    {\r\n                      &quot;StoredProcedures&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1SP&quot;,\r\n                            &quot;FileName2SP&quot;,\r\n                            &quot;FileName3SP&quot;\r\n                            ]\r\n                        }\r\n                            \r\n                    },\r\n                    {\r\n                      &quot;Tables&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1T&quot;,\r\n                            &quot;FileName2T&quot;\r\n                            ]\r\n                        }\r\n                                      \r\n                    }\r\n                    ]\r\n                }\r\n                \r\n           \r\n            },\r\n            {\r\n              &quot;Sys2&quot;: \r\n                {\r\n                  &quot;folder&quot;:[\r\n                    {\r\n                      &quot;MaintScripts&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                        \r\n                    },\r\n                    {\r\n                      &quot;Schemas&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                                 \r\n                    },\r\n                    {\r\n                      &quot;StoredProcedures&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                              \r\n                    },\r\n                    {\r\n                      &quot;Tables&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                                        \r\n                    },\r\n                    {\r\n                      &quot;ExternalTables&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                              \r\n                    }, \r\n                    {\r\n                      &quot;Scripts&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1&quot;,\r\n                            &quot;FileName2&quot;\r\n                            ]\r\n                        }\r\n                                       \r\n                    },\r\n                    {\r\n                      &quot;Views&quot;:\r\n                        {\r\n                          &quot;files&quot;: [\r\n                            &quot;FileName1v&quot;,\r\n                            &quot;FileName2v&quot;\r\n                            ]\r\n                        }\r\n                                       \r\n                    }\r\n                    ]\r\n                }\r\n            }\r\n        ]\r\n    }\r\n  \r\n}\r\n```\r\nI&#39;m trying to select an object only return the filenames in the array under it like so (say I wanted just the files in &#39;Schemas&#39; for &#39;Sys1&#39;). The desired output would be:\r\n\r\n``` [&quot;Filename1S&quot;,&quot;Filename2S&quot;] ```\r\n\r\nfrom this section:\r\n\r\n```\r\nInventory &gt; Sys1 &gt; folder &gt; Schemas\r\n```\r\nThe jq statement I&#39;ve been invoking is:\r\n\r\n```\r\n.DBInventory.Inventory[0][] | select(any(.folder[]; .Key == &quot;Schemas&quot;)) | .files[]\r\n```\r\nAny help would be greatly appreciated. I think I&#39;m close, but the whole blank output has thrown me for a loop.",
        "link": "https://stackoverflow.com/questions/65296079/selecting-from-nested-array-in-json-using-jq-gives-empty-result",
        "title": "Selecting from nested array in JSON using jq gives empty result"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1607996715,
                "creation_date": 1607996715,
                "answer_id": 65298902,
                "question_id": 65298839,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```js\r\nconst splittedObject = Object.keys( // get all the keys\r\n    yourObject\r\n).map((key) =&gt; { // then for each key, turn the key into an object with the key-value pair\r\n    return {\r\n        [key]: yourObject[key] // assign the value to the key and voila\r\n    }\r\n});\r\n```\r\n\r\nNow `splittedObject` is an array of those objects with one key, it&#39;s better to demonstrate with this snippet:\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 yourObject = { &quot;138.68.226.120:26969&quot;: 1, &quot;178.128.50.37:26969&quot;: 1, &quot;207.180.218.133:26969&quot;: 1, &quot;66.42.67.157:26969&quot;: 1, &quot;140.82.14.193:26969&quot;: 1, &quot;51.15.39.62:26969&quot;: 1, &quot;144.217.91.232:26969&quot;: 1, &quot;144.217.81.95:26969&quot;: 1, &quot;68.183.105.143:26969&quot;: 1, &quot;192.99.246.177:26969&quot;: 1, &quot;167.99.98.151:26969&quot;: 1, &quot;59.79.71.205:26969&quot;: 1 };\r\n\r\n    const splittedObject = Object.keys( // get all the keys\r\n        yourObject\r\n    ).map((key) =&gt; { // then for each key, turn the key into an object with the key-value pair\r\n        return {\r\n            [key]: yourObject[key] // assign the value to the key and voila\r\n        }\r\n    });\r\n\r\n    console.log(splittedObject);\r\n\r\n&lt;!-- end snippet --&gt;\r\n\r\n\r\nBy the way, can I ask why you need to do this?",
                "title": "get a key-value pair from an object to a new object jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608006206,
                "creation_date": 1608006206,
                "answer_id": 65299973,
                "question_id": 65298839,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer is in the Object Construction section of the [manual](https://stedolan.github.io/jq/manual/v1.6/#TypesandValues).\r\n\r\n    jq &#39;{&quot;59.79.71.205:26969&quot;}&#39;",
                "title": "get a key-value pair from an object to a new object jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1608020055,
        "creation_date": 1607996098,
        "last_edit_date": 1608020055,
        "question_id": 65298839,
        "body_markdown": "I get this object \r\n```json\r\n{\r\n  &quot;138.68.226.120:26969&quot;: 1,\r\n  &quot;178.128.50.37:26969&quot;: 1,\r\n  &quot;207.180.218.133:26969&quot;: 1,\r\n  &quot;66.42.67.157:26969&quot;: 1,\r\n  &quot;140.82.14.193:26969&quot;: 1,\r\n  &quot;51.15.39.62:26969&quot;: 1,\r\n  &quot;144.217.91.232:26969&quot;: 1,\r\n  &quot;144.217.81.95:26969&quot;: 1,\r\n  &quot;68.183.105.143:26969&quot;: 1,\r\n  &quot;192.99.246.177:26969&quot;: 1,\r\n  &quot;167.99.98.151:26969&quot;: 1,\r\n  &quot;59.79.71.205:26969&quot;: 1\r\n}\r\n```\r\n\r\nWhen I use jq &#39;.&quot;59.79.71.205:26969&quot;&#39; it give me the value only, is there a way to get the key-value from the object into an object like the example \r\n\r\n    {\r\n     &quot;59.79.71.205:26969&quot;: 1\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65298839/get-a-key-value-pair-from-an-object-to-a-new-object-jq",
        "title": "get a key-value pair from an object to a new object jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608014684,
                "last_edit_date": 1608014684,
                "creation_date": 1608004676,
                "answer_id": 65299805,
                "question_id": 65299626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With JQ 1.6, you can use **$ARGS** builtin variable in conjunction with **gsub** and a named capturing group to achieve this.\r\n```\r\njq --arg REGION &quot;ap-south-1&quot; \\\r\n   --arg ACCOUNTID &quot;46311000000&quot; \\\r\n   --arg QNAME &quot;orders&quot; &#39;\r\nwalk(\r\n  if type == &quot;string&quot; \r\n  then gsub(&quot;\\\\$(?&lt;name&gt;\\\\w+)&quot;; $ARGS.named[.name])\r\n  else . end\r\n)&#39; input.json\r\n```",
                "title": "Replacing variables in JSON document"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608019964,
                "last_edit_date": 1608019964,
                "creation_date": 1608009565,
                "answer_id": 65300394,
                "question_id": 65299626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In a jq program, `&quot;$ACCOUNTID&quot;` is a string whereas `$ACCOUNTID` is a jq variable. In other words, the approach you seem to be adopting would require dropping the quotation marks for this particular variable, similar changes for the others, and reading the template file as a jq program, not as a JSON file.",
                "title": "Replacing variables in JSON document"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1608019964,
        "creation_date": 1608003095,
        "last_edit_date": 1608018736,
        "question_id": 65299626,
        "body_markdown": "I am working with this [example][1] for the following input JSON document using `cat input.json | jq --arg REGION &quot;ap-south-1&quot; --arg ACCOUNTID &quot;46311000000&quot; --arg QNAME &quot;orders&quot;`. However, the output does not show any transformation.\r\n\r\nCan you please advise how to apply the replacement?\r\n\r\n\r\n`input.json`\r\n\r\n```json\r\n{\r\n  &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n  &quot;Id&quot;: &quot;policy-15122020&quot;,\r\n  &quot;Statement&quot;: [\r\n    {\r\n      &quot;Sid&quot;: &quot;1&quot;,\r\n      &quot;Effect&quot;: &quot;Allow&quot;,\r\n      &quot;Principal&quot;: {\r\n        &quot;AWS&quot;: &quot;*&quot;\r\n      },\r\n      &quot;Action&quot;: [\r\n        &quot;sqs:ReceiveMessage&quot;,\r\n        &quot;sqs:SendMessage&quot;\r\n      ],\r\n      &quot;Resource&quot;: &quot;arn:aws:sqs:$REGION:$ACCOUNTID:$QNAME&quot;,\r\n      &quot;Condition&quot;: {\r\n        &quot;StringEquals&quot;: {\r\n          &quot;aws:SourceAccount&quot;: &quot;$ACCOUNTID&quot;\r\n        }\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n  [1]: https://stackoverflow.com/q/54601240/919480",
        "link": "https://stackoverflow.com/questions/65299626/replacing-variables-in-json-document",
        "title": "Replacing variables in JSON document"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "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": 0,
                "creation_date": 1608024146,
                "post_id": 65302856,
                "comment_id": 115448609,
                "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": 1608024212,
                "post_id": 65302856,
                "comment_id": 115448631,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1608024635,
                "post_id": 65302856,
                "comment_id": 115448798,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1362214,
                    "reputation": 319,
                    "user_id": 1299369,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9fb5f3b4f4f6a237641aa0ed62185f36?s=256&d=identicon&r=PG",
                    "display_name": "Tao",
                    "link": "https://stackoverflow.com/users/1299369/tao"
                },
                "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": 1608062022,
                "post_id": 65302856,
                "comment_id": 115466325,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608121653,
                "post_id": 65302856,
                "comment_id": 115484743,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608453500,
                "post_id": 65302856,
                "comment_id": 115584746,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32384,
                    "reputation": 127026,
                    "user_id": 89817,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/df253c3b6533949ea94f31f328f3e769?s=256&d=identicon&r=PG",
                    "display_name": "Gordon Davisson",
                    "link": "https://stackoverflow.com/users/89817/gordon-davisson"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608453544,
                "post_id": 65302856,
                "comment_id": 115584758,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609900381,
                "creation_date": 1609900381,
                "answer_id": 65589411,
                "question_id": 65302856,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the end, I have to disable the bash wildcard expansion to achieve my goal :( \r\n\r\n`set noglob on` ",
                "title": "How to escape asterisk symbol &#39;*&#39; in an array in bash shell"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1609900688,
        "creation_date": 1608023153,
        "last_edit_date": 1609900688,
        "question_id": 65302856,
        "body_markdown": "I am a newbie for the bash shell. The previous developer created the following codes to use a shell script to deploy AWS cloudformation stack. \r\n\r\n1. Read a json file and using `jq` to convert it to an array called `parameters`\r\n1. Using `${parameters[@]}` to spread into key=value pair strings\r\n\r\nThe problem is one array value is `cron(0 20-6 * * ? *)`. The deploy.sh will convert the `*` as current directory file names such as `cron(0 20-6 CODEOWNERS README.md CODEOWNERS README.md ? *)`\r\n\r\n**My question:**\r\nHow can I let my deploy.sh to escape the `*` characters when calling `${parameters[@]}`.\r\n\r\nHere are the example codes:\r\n\r\ndev.json\r\n\r\n```\r\n{\r\n  &quot;Parameters&quot;: {\r\n    &quot;Environment&quot;: &quot;dev&quot;,\r\n    &quot;CrawlerScheduleExpression&quot;: &quot;cron(0 20-6  * * ? *)&quot;\r\n  },\r\n  &quot;Tags&quot;: {\r\n    &quot;Severity&quot;: &quot;High&quot;,\r\n    &quot;Environment&quot;: &quot;dev&quot;,\r\n    &quot;DeletionPolicy&quot;: &quot;Retain&quot;\r\n  }\r\n}\r\n```\r\ndeploy.sh\r\n```\r\nparameters=($(jq -r &#39;.Parameters | keys[] as $k | &quot;\\($k)=\\(.[$k])&quot;&#39; &quot;dev.json&quot;)) \r\ntags=($(jq -r &#39;.Tags | keys[] as $k | &quot;\\($k)=\\(.[$k])&quot;&#39; &quot;${conf_file}&quot;))\r\n\r\n    aws cloudformation deploy \\\r\n    --s3-bucket ${BUILD_ARTIFACTS_BUCKET} \\\r\n    --s3-prefix ${PROJECT_NAME} \\\r\n    --template-file ${template} --stack-name ${STACK_NAME} \\\r\n    --parameter-overrides &quot;${parameters[@]}&quot; \\ # Environment=dev CrawlerScheduleExpression=cron(0 20-6 CODEOWNERS README.md CODEOWNERS README.md ? *) \r\n    --tags &quot;${tags[@]}&quot;  \r\n```",
        "link": "https://stackoverflow.com/questions/65302856/how-to-escape-asterisk-symbol-in-an-array-in-bash-shell",
        "title": "How to escape asterisk symbol &#39;*&#39; in an array in bash shell"
    },
    {
        "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": 1608041004,
                "post_id": 65307236,
                "comment_id": 115456349,
                "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": 1608041056,
                "post_id": 65307236,
                "comment_id": 115456373,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20221038,
                    "reputation": 75,
                    "user_id": 14830478,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqIBtYvz2A9vZ6aiSv3U8AQl9br-6xrWAJCWzdhw=k-s256",
                    "display_name": "Srinivas B",
                    "link": "https://stackoverflow.com/users/14830478/srinivas-b"
                },
                "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": 1608041286,
                "post_id": 65307236,
                "comment_id": 115456488,
                "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": 1608041593,
                "post_id": 65307236,
                "comment_id": 115456639,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20221038,
                    "reputation": 75,
                    "user_id": 14830478,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqIBtYvz2A9vZ6aiSv3U8AQl9br-6xrWAJCWzdhw=k-s256",
                    "display_name": "Srinivas B",
                    "link": "https://stackoverflow.com/users/14830478/srinivas-b"
                },
                "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": 1608041792,
                "post_id": 65307236,
                "comment_id": 115456744,
                "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": 1608041862,
                "post_id": 65307236,
                "comment_id": 115456777,
                "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": 1608042046,
                "post_id": 65307236,
                "comment_id": 115456866,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20221038,
                    "reputation": 75,
                    "user_id": 14830478,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqIBtYvz2A9vZ6aiSv3U8AQl9br-6xrWAJCWzdhw=k-s256",
                    "display_name": "Srinivas B",
                    "link": "https://stackoverflow.com/users/14830478/srinivas-b"
                },
                "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": 1608042397,
                "post_id": 65307236,
                "comment_id": 115457065,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1608043295,
                "post_id": 65307236,
                "comment_id": 115457547,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20221038,
                    "reputation": 75,
                    "user_id": 14830478,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GiqIBtYvz2A9vZ6aiSv3U8AQl9br-6xrWAJCWzdhw=k-s256",
                    "display_name": "Srinivas B",
                    "link": "https://stackoverflow.com/users/14830478/srinivas-b"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608045209,
                "post_id": 65307236,
                "comment_id": 115458457,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1608041921,
                "creation_date": 1608041921,
                "answer_id": 65307722,
                "question_id": 65307236,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a handy group-by operator. \r\n\r\nSince you&#39;ve made it clear [in comments](https://stackoverflow.com/questions/65307236/i-have-a-json-with-repeated-parent-objects-i-need-to-merge-all-childs-under-one/65307722#comment115456488_65307236) that the goal of this question is to know how to perform grouping, and the exact output format is secondary, an example of such grouping would be:\r\n\r\n```\r\njq &#39;group_by(.source?.id // &quot;&quot;) | [.[] | {&quot;\\(.[0].source?.id)&quot;: [.[].target.id]}] | add&#39;\r\n```\r\n\r\n...generating output (for your given input) of:\r\n\r\n```json\r\n{\r\n  &quot;1&quot;: [\r\n    2,\r\n    3,\r\n    10,\r\n    11\r\n  ],\r\n  &quot;null&quot;: [\r\n    1\r\n  ]\r\n}\r\n```",
                "title": "I have a json with repeated parent objects. I need to merge all childs under one parent using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608046382,
        "creation_date": 1608040225,
        "last_edit_date": 1608046382,
        "question_id": 65307236,
        "body_markdown": "I have a json with repeated parent objects. I need to merge all childs under one parent using jq in bash. Below is the json array. Below source one&#39;s are parents. I need to take a single parent item and merge it with all child items. Is it possible with jq?\r\n \r\n  \r\n\r\n     [\r\n            {\r\n                &quot;source&quot;: null,\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 1\r\n                }\r\n            },\r\n            {\r\n                &quot;source&quot;: {\r\n                    &quot;id&quot;: 1\r\n                },\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 2\r\n                }\r\n            },\r\n            {\r\n                &quot;source&quot;: {\r\n                    &quot;id&quot;: 1\r\n                },\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 3\r\n                }\r\n            },\r\n            {\r\n                &quot;source&quot;: {\r\n                    &quot;id&quot;: 1\r\n                },\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 10\r\n                }\r\n            },\r\n            {\r\n                &quot;source&quot;: {\r\n                    &quot;id&quot;: 1\r\n                },\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 11\r\n                }\r\n            }\r\n        ]\r\n\r\nExpected output:-\r\n\r\n   \r\n\r\n     [\r\n            {\r\n                &quot;source&quot;: null,\r\n                &quot;target&quot;: {\r\n                    &quot;id&quot;: 1\r\n                }\r\n            },\r\n            {\r\n                &quot;source&quot;: {\r\n                    &quot;id&quot;: 1\r\n                },\r\n                &quot;target-1&quot;: {\r\n                    &quot;id&quot;: 2\r\n                },\r\n                &quot;target-2&quot;: {\r\n                    &quot;id&quot;: 3\r\n                },\r\n                &quot;target-3&quot;: {\r\n                    &quot;id&quot;: 10\r\n                },\r\n                &quot;target-4&quot;: {\r\n                    &quot;id&quot;: 11\r\n                }\r\n            }\r\n        ]",
        "link": "https://stackoverflow.com/questions/65307236/i-have-a-json-with-repeated-parent-objects-i-need-to-merge-all-childs-under-one",
        "title": "I have a json with repeated parent objects. I need to merge all childs under one parent using jq in bash"
    },
    {
        "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": 1608050775,
                "post_id": 65310051,
                "comment_id": 115461321,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 245583,
                    "reputation": 840,
                    "user_id": 519151,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/QShdR.jpg?s=256",
                    "display_name": "Isaac",
                    "link": "https://stackoverflow.com/users/519151/isaac"
                },
                "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": 1608054372,
                "post_id": 65310051,
                "comment_id": 115463066,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608051419,
                "last_edit_date": 1608051419,
                "creation_date": 1608050831,
                "answer_id": 65310139,
                "question_id": 65310051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I would use the following :\r\n\r\n    jq --slurp --compact-output &#39;{ a: map(.a) }&#39; foo.txt\r\n\r\n`--slurp` makes `jq` read a sequence of JSON objects as an array of those objects. We map this array of objects to an array of the values of their `.a` field, and finally return an object which holds this array as its `.a` field.\r\n\r\nYou can [try it here](https://jqplay.org/s/sFwfKCpIir).",
                "title": "Join multiple JSON objects into an array"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1608051142,
                "last_edit_date": 1608051142,
                "creation_date": 1608050842,
                "answer_id": 65310142,
                "question_id": 65310051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were really close. JQ won&#39;t extract `.a` from input objects unless you explicitly state that.\r\n```\r\n$ jq -n &#39;.a = [inputs.a]&#39; foo.txt\r\n{\r\n  &quot;a&quot;: [\r\n    &quot;b&quot;,\r\n    &quot;e&quot;,\r\n    &quot;f&quot;\r\n  ]\r\n}\r\n```",
                "title": "Join multiple JSON objects into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1623225740,
        "creation_date": 1608050496,
        "last_edit_date": 1623225740,
        "question_id": 65310051,
        "body_markdown": "I have a command that outputs multiple simple json objects like this (for development purposes previously piped to a file `foo.txt`):\r\n \r\n    $ cat foo.txt\r\n    {&quot;a&quot;: &quot;b&quot;}\r\n    {&quot;a&quot;: &quot;e&quot;}\r\n    {&quot;a&quot;: &quot;f&quot;}\r\n\r\nNow I would like to get it formatted like this:\r\n\r\n    {\r\n      &quot;a&quot;: [&quot;b&quot;, &quot;e&quot;, &quot;f&quot;]\r\n    }\r\n\r\nI am pretty sure it can be done with `jq`, but all I can get is the following:\r\n```\r\n$ cat foo.txt |jq -n &#39;.a |= [inputs]&#39;\r\n{\r\n  &quot;a&quot;: [\r\n    {\r\n      &quot;a&quot;: &quot;b&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;e&quot;\r\n    },\r\n    {\r\n      &quot;a&quot;: &quot;f&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAny hints?",
        "link": "https://stackoverflow.com/questions/65310051/join-multiple-json-objects-into-an-array",
        "title": "Join multiple JSON objects into an array"
    },
    {
        "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": 1608053231,
                "post_id": 65310490,
                "comment_id": 115462564,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 33190,
                    "reputation": 24775,
                    "user_id": 92692,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/046e863d3603ce0dca9c2254a1457a9b?s=256&d=identicon&r=PG",
                    "display_name": "esac",
                    "link": "https://stackoverflow.com/users/92692/esac"
                },
                "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": 1608054072,
                "post_id": 65310490,
                "comment_id": 115462949,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608053750,
                "creation_date": 1608053750,
                "answer_id": 65310872,
                "question_id": 65310490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can enrich the partitions with the device and filter the enriched partitions:\r\n```\r\njq &#39;.disk[]\r\n    | .device as $d\r\n    | .partitions[] += { device: $d }\r\n    | .partitions[]\r\n    | select(.mount != null)\r\n    &#39; file.json\r\n",
                "title": "Extract child elements and add parent field into them"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608056506,
                "last_edit_date": 1608056506,
                "creation_date": 1608053894,
                "answer_id": 65310913,
                "question_id": 65310490,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need to go back one level to fetch **device**. Just get a copy of it, select **partitions**, and add them together.\r\n```\r\n.disk\r\n| map((.partitions[] | select(.mount != null)) + {device})\r\n| sort_by(.mount)[]\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/Sgs_dXGHuU)&lt;/sup&gt;",
                "title": "Extract child elements and add parent field into them"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1608088648,
        "creation_date": 1608052253,
        "last_edit_date": 1608088648,
        "question_id": 65310490,
        "body_markdown": "I am trying to combine nested arrays into a single object so that I can do some sorting. For example, I have the following\r\n\r\n```\r\n{\r\n    &quot;disk&quot;: [\r\n        { \r\n            &quot;device&quot;: &quot;/dev/sda&quot;,\r\n            &quot;partitions&quot;: [\r\n                { &quot;type&quot;: &quot;fat32&quot;, &quot;mount&quot;: &quot;/efi&quot; },\r\n                { &quot;type&quot;: &quot;ext4&quot;, &quot;mount&quot;: &quot;/boot&quot; }\r\n            ]\r\n        },\r\n        {\r\n            &quot;device&quot;: &quot;/dev/sdb&quot;,\r\n            &quot;partitions&quot;: [\r\n                { &quot;type&quot;: &quot;xfs&quot;, &quot;mount&quot;: &quot;/&quot; }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI am trying to say &#39;give me all partitions where mount is not null, sort them by mount, but include their device name in the output&#39;.\r\n\r\nSo far I have `jq -c &#39;.disk[].partitions[] | select (.mount != null)&#39;` which is giving me the correct partitions as such:\r\n\r\n```json\r\n{ &quot;type&quot;: &quot;xfs&quot;, &quot;mount&quot;: &quot;/&quot; }\r\n{ &quot;type&quot;: &quot;ext4&quot;, &quot;mount&quot;: &quot;/boot&quot; }\r\n{ &quot;type&quot;: &quot;fat32&quot;, &quot;mount&quot;: &quot;/efi&quot; }\r\n```\r\n\r\nHowever, I would like to pull in the parent device as such:\r\n\r\n```json\r\n{ &quot;type&quot;: &quot;xfs&quot;, &quot;mount&quot;: &quot;/&quot;, &quot;device&quot;: &quot;/sdb&quot; }\r\n{ &quot;type&quot;: &quot;ext4&quot;, &quot;mount&quot;: &quot;/boot&quot;, &quot;device&quot;: &quot;/sda&quot; }\r\n{ &quot;type&quot;: &quot;fat32&quot;, &quot;mount&quot;: &quot;/efi&quot;, &quot;device&quot;: &quot;/sda&quot; }\r\n```\r\n\r\nI&#39;ve seen other examples that drive off the parent and then pull in the children, but it doesn&#39;t seem to work when the parent itself is an array. Is there a way to say &quot;get a child property&quot; such as ` ... | .device = ..device`",
        "link": "https://stackoverflow.com/questions/65310490/extract-child-elements-and-add-parent-field-into-them",
        "title": "Extract child elements and add parent field into them"
    },
    {
        "tags": [
            "arrays",
            "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": 0,
                "creation_date": 1608058131,
                "post_id": 65311888,
                "comment_id": 115464697,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608058184,
                "post_id": 65311888,
                "comment_id": 115464717,
                "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": 1608058259,
                "post_id": 65311888,
                "comment_id": 115464748,
                "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": 1608058444,
                "post_id": 65311888,
                "comment_id": 115464842,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14932609,
                    "reputation": 898,
                    "user_id": 10781626,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/FYTvJ.jpg?s=256",
                    "display_name": "codlix",
                    "link": "https://stackoverflow.com/users/10781626/codlix"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608058485,
                "post_id": 65311888,
                "comment_id": 115464867,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1608072855,
                "last_edit_date": 1608072855,
                "creation_date": 1608058694,
                "answer_id": 65312057,
                "question_id": 65311888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could doubtless make your program work by updating `batch` along the lines of:\r\n\r\n```bash\r\nbatch=$(jq --argjson json &quot;$json&quot; &#39;. + [$json]&#39; &lt;&lt;&lt; &quot;$batch&quot;)\r\n```\r\n\r\nHowever, the approach you&#39;re taking seems to be both fragile and astoundingly inefficient. Have you considered accumulating all the items in a file (as a stream of JSON entities), and when they need to be bundled into an array, using `jq -s .`?\r\n\r\nIn the particular example given, it would in fact be sufficient to write:\r\n\r\n```bash\r\nprintf &quot;%s\\n&quot; &quot;${data[@]}&quot; |\r\n    jq -n &#39;[{data: inputs}]&#39; |\r\n    curl -d @- &lt;OTHER CURL OPTIONS&gt;\r\n```\r\nThat is, you can pipe directly into `curl`.\r\n\r\nNotice that a call to `tonumber` is unnecessary, whether or not it is known that all the `data` items are numbers.  For reference, `tonumber` is often used in the idiom `(tonumber? // .)` in case the string or other input is not numeric.\r\n\r\n## Another variation\r\n\r\nIf there were other actions to be taken on each data element that jq cannot readily handle:\r\n```bash\r\nbatch=$(\r\n   (\r\n       for data_object in &quot;${data[@]}&quot;; do\r\n           jq -n --argjson inf &quot;$data_object&quot; &#39;{data: $inf}&#39;\r\n       done\r\n   ) | jq -s .\r\n)\r\n```\r\nHere, a call to `tonumber` is unnecessary, this time thanks to `--argjson`.\r\n",
                "title": "How to create a JSON array and append JSON objects to it?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608072855,
        "creation_date": 1608058001,
        "last_edit_date": 1608058470,
        "question_id": 65311888,
        "body_markdown": "I&#39;m creating JSON objects from given data. \r\nIf an JSON object is created it should be appended to an JSON array which is stored in a bash-variable. This batch of JSON objects should later be send via curl. \r\n\r\nCode is:\r\n\r\n```\r\ndeclare -a data=(&#39;10.4&#39; &#39;100.23&#39; &#39;20.02&#39;);\r\nbatch=&quot;[]&quot;\r\nfor data_object in &quot;${data[@]}&quot;; do\r\n    json=$(jq -n --arg inf $data_object &#39;{data: $inf|tonumber}&#39;)\r\n    batch=$(jq &#39;$batch += [&quot;$json&quot;]&#39;)\r\ndone\r\n```\r\n\r\nThe expected result after n loops should be:\r\n\r\n```\r\n[\r\n   {\r\n      &quot;data&quot;: 10.4\r\n   },\r\n   {\r\n      &quot;data&quot;: 100.23\r\n   },\r\n   {\r\n      &quot;data&quot;: 20.02\r\n   }\r\n]\r\n```\r\nI&#39;m constantly getting this error: `jq: error: $batch is not defined at &lt;top-level&gt;, line 1:`. How can I solve this?",
        "link": "https://stackoverflow.com/questions/65311888/how-to-create-a-json-array-and-append-json-objects-to-it",
        "title": "How to create a JSON array and append JSON objects to it?"
    },
    {
        "tags": [
            "json",
            "windows",
            "cmd",
            "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": 0,
                "creation_date": 1608101338,
                "post_id": 65317996,
                "comment_id": 115476372,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1608106332,
                "last_edit_date": 1608106332,
                "creation_date": 1608101142,
                "answer_id": 65318475,
                "question_id": 65317996,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Unfortunately the jq documentation in trying to be helpful about Windows ends up being a bit misleading.  Perhaps it would have been better to provide a pointer to comprehensive documentation, with the suggestion to avoid the headaches by using the -f command-line option.\r\n\r\nOne of the important details that is missing is that the caret character `^` serves as an escape character for symbols such as `|`. So you could write:\r\n\r\n     .entries ^| map(.id +^&quot; ^| ^&quot;+ .title) ^| join(^&quot;\\n^&quot;)\r\n\r\nwithout any surrounding quotes.\r\n\r\nAlternatively - and a bit more mysteriously - you could write:\r\n\r\n    &quot;.entries | map(.id +\\&quot; ^| \\&quot;+ .title) | join(\\&quot;\\n\\&quot;)&quot;\r\n  \r\nAs you can infer from the fact that not all pipe characters in the above line are escaped, this technique is not so simple.  For more detailed information, see for example this SO article: https://stackoverflow.com/questions/7760545/escape-double-quotes-in-parameter\r\n\r\nor:\r\n\r\n&gt; https://www.robvanderwoude.com/escapechars.php\r\n\r\nFor an online tool, see http://output.jsbin.com/anitaz/11\r\n\r\n  ",
                "title": "Using double quotes in JQ on CMD (windows)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1608106332,
        "creation_date": 1608098116,
        "question_id": 65317996,
        "body_markdown": "Json file sample (test1.json) :\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;duration&quot;: 478,\r\n          &quot;id&quot;: &quot;uCPPyitzI&quot;,\r\n          &quot;title&quot;: &quot;Why | TV&quot;,\r\n          &quot;description&quot;: null,\r\n          &quot;uploader&quot;: null,\r\n          &quot;view_count&quot;: null,\r\n          &quot;ie_key&quot;: &quot;Youtube&quot;,\r\n          &quot;url&quot;: &quot;uCPPyitzI&quot;,\r\n          &quot;_type&quot;: &quot;url_transparent&quot;\r\n        },\r\n        {\r\n          &quot;duration&quot;: 245,\r\n          &quot;id&quot;: &quot;F9ClW8Dv0&quot;,\r\n          &quot;title&quot;: &quot;Kejrixxxx | TV&quot;,\r\n          &quot;description&quot;: null,\r\n          &quot;uploader&quot;: null,\r\n          &quot;view_count&quot;: null,\r\n          &quot;ie_key&quot;: &quot;Youtube&quot;,\r\n          &quot;url&quot;: &quot;F9ClW8Dv0&quot;,\r\n          &quot;_type&quot;: &quot;url_transparent&quot;\r\n        },\r\n        {\r\n          &quot;duration&quot;: 990,\r\n          &quot;id&quot;: &quot;JchBXwZ8o&quot;,\r\n          &quot;title&quot;: &quot;Battle Of xxxx: | Dr. cccccc | TV&quot;,\r\n          &quot;description&quot;: null,\r\n          &quot;uploader&quot;: null,\r\n          &quot;view_count&quot;: null,\r\n          &quot;ie_key&quot;: &quot;Youtube&quot;,\r\n          &quot;url&quot;: &quot;JchBXwZ8o&quot;,\r\n          &quot;_type&quot;: &quot;url_transparent&quot;\r\n        },\r\n        {\r\n          &quot;duration&quot;: 1178,\r\n          &quot;id&quot;: &quot;4x9dWcG2c&quot;,\r\n          &quot;title&quot;: &quot;Dirty Politics | Dr. xxxxx | TV&quot;,\r\n          &quot;description&quot;: null,\r\n          &quot;uploader&quot;: null,\r\n          &quot;view_count&quot;: null,\r\n          &quot;ie_key&quot;: &quot;Youtube&quot;,\r\n          &quot;url&quot;: &quot;4x9dWcd2c&quot;,\r\n          &quot;_type&quot;: &quot;url_transparent&quot;\r\n        }\r\n      ],\r\n      &quot;uploader_id&quot;: &quot;xxxx&quot;,\r\n      &quot;webpage_url&quot;: &quot;https://www.youtube.com/playlist?list=xxx&quot;,\r\n      &quot;title&quot;: &quot;.aabbcc&quot;,\r\n      &quot;extractor&quot;: &quot;xxx:xxx&quot;,\r\n      &quot;uploader&quot;: &quot;xxxxxx&quot;,\r\n      &quot;uploader_url&quot;: &quot;https://www.youtube.com/channel/xxxx&quot;,\r\n      &quot;id&quot;: &quot;xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx&quot;,\r\n      &quot;extractor_key&quot;: &quot;xxxxx&quot;,\r\n      &quot;webpage_url_basename&quot;: &quot;xxxxxx&quot;,\r\n      &quot;_type&quot;: &quot;playlist&quot;\r\n    }\r\n\r\nThe following command works fine in Linux:\r\n\r\n&lt;pre&gt;\r\ncat test1.json | jq -r &#39;.entries | map(.id +&quot; | &quot;+ .title) | join(&quot;\\n&quot;)&#39;\r\n&lt;/pre&gt;\r\n\r\nAs per jq documentations :\r\n\r\n&gt; When using the Windows command shell (cmd.exe) it&#39;s best to use double\r\n&gt; quotes around your jq program when given on the command-line (instead\r\n&gt; of the -f program-file option), but then double-quotes in the jq\r\n&gt; program need backslash escaping.\r\n\r\nSo I modified the command to for cmd.exe (Windows 10):\r\n&lt;pre&gt;\r\ncat test1.json | jq -r &quot;.[] | map(.id +\\&quot; | \\&quot; + .title) | join(\\&quot; \\n \\&quot;)&quot;\r\n&lt;/pre&gt;\r\n\r\nBut I keep getting the following error :\r\n&lt;pre&gt;\r\n&#39;\\&quot; + .title) | join(\\&quot;&#39; is not recognized as an internal or external command,\r\noperable program or batch file.\r\n&lt;/pre&gt;\r\n\r\nWhat am I doing wrong? Please help. ",
        "link": "https://stackoverflow.com/questions/65317996/using-double-quotes-in-jq-on-cmd-windows",
        "title": "Using double quotes in JQ on CMD (windows)"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1608121766,
                "creation_date": 1608121766,
                "answer_id": 65323299,
                "question_id": 65323254,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just need to use the `.[]` [object value iterator][1] syntax to first let `.current` expand to its constituent value and then the expression becomes `.&quot;config1&quot;` which matches the `config1` key \r\n\r\n```none\r\njq &#39;.[.current]&#39;\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]",
                "title": "Use value as key for another object in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1608121860,
        "creation_date": 1608121635,
        "last_edit_date": 1608121860,
        "question_id": 65323254,
        "body_markdown": "I setup a json config file like this\r\n\r\n    {\r\n        &quot;current&quot;: &quot;config1&quot;,\r\n        &quot;config1&quot;: {\r\n            &quot;p1&quot;: &quot;val1-1&quot;,\r\n            &quot;p2&quot;: &quot;val1-2&quot;\r\n        },\r\n        &quot;config2&quot;: {\r\n            &quot;p1&quot;: &quot;val2-1&quot;,\r\n            &quot;p2&quot;: &quot;val2-2&quot;\r\n        }\r\n    }\r\n\r\nI would like to get &quot;current&quot; config with bash and jq. \r\nAt the moment I use:\r\n\r\n```\r\n#!/usr/bin/env bash\r\n\r\nC=`jq &#39;.current&#39; $1`\r\nD=`eval jq &#39;.&quot;$C&quot;&#39; $1`\r\necho &quot; ------  D is $D&quot;\r\necho $D | jq  &#39;.p1&#39;\r\n```\r\n\r\nIs there a direct jq filter/key trick to obtain the same result?",
        "link": "https://stackoverflow.com/questions/65323254/use-value-as-key-for-another-object-in-jq",
        "title": "Use value as key for another object in jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 19615808,
                    "reputation": 551,
                    "user_id": 14357329,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/6aca6f496280501f5d88e9f788137d7f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Serge Vu",
                    "link": "https://stackoverflow.com/users/14357329/serge-vu"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608140790,
                "post_id": 65328195,
                "comment_id": 115494123,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2141010,
                    "reputation": 124401,
                    "user_id": 1899640,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47374ccb28e4b0d2454b64f7b975bc66?s=256&d=identicon&r=PG",
                    "display_name": "that other guy",
                    "link": "https://stackoverflow.com/users/1899640/that-other-guy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608145431,
                "post_id": 65328195,
                "comment_id": 115496276,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1608149310,
                "last_edit_date": 1608149310,
                "creation_date": 1608141934,
                "answer_id": 65328735,
                "question_id": 65328195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This would probably do:\r\n\r\n```sh\r\n. &lt;(\r\n  jq -r &#39;&quot;export &quot;+(to_entries|map((.key|ascii_upcase)+&quot;=&quot;+(.value|@sh))|.[])&#39;\\\r\n    &lt;&lt;&lt;&#39;{&quot;foo&quot;:&quot;John&quot;,&quot;bar&quot;:&quot;Smith&quot;}&#39;\r\n)\r\n```\r\n\r\nAlternative with one export for all variables:\r\n```sh\r\n. &lt;(\r\n  jq -r &#39;\r\n    &quot;export&quot;+(\r\n      to_entries|\r\n        map(\r\n            &quot; &quot; +\r\n            (.key|ascii_upcase) +\r\n            &quot;=&quot; +\r\n            (.value|@sh)\r\n          ) | add\r\n        )\r\n  &#39; &lt;&lt;&lt;&#39;{&quot;foo&quot;:&quot;John&quot;,&quot;bar&quot;:&quot;Smith&quot;}&#39;\r\n)\r\n```\r\n\r\nYou may also consider filtering-out replacing characters within `.key` strings so they are always valid shell variable identifiers.\r\n",
                "title": "How do I break a long string in jq in a bash command?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1608149310,
        "creation_date": 1608139760,
        "last_edit_date": 1608143918,
        "question_id": 65328195,
        "body_markdown": "Here&#39;s the minimal example:\r\n```\r\necho &quot;{\\&quot;foo\\&quot;: \\&quot;John\\&quot;,\\&quot;bar\\&quot;:\\&quot;Smith\\&quot;}&quot; | jq -r &#39;@sh &quot;export FOO=\\(.foo)\\nexport BAR=\\(.bar) \\n&quot;&#39;\r\n```\r\n\r\nAnd in my real life scenario case that `jq` selector is really long (think about 10 exports), how can I break them into multiple lines or something? I tried using `\\` as a separator at the end of the lines but it doesn&#39;t work unfortunately.",
        "link": "https://stackoverflow.com/questions/65328195/how-do-i-break-a-long-string-in-jq-in-a-bash-command",
        "title": "How do I break a long string in jq in a bash command?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608144367,
                "post_id": 65328491,
                "comment_id": 115495721,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2721473,
                    "reputation": 6789,
                    "user_id": 2347677,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/1fWTO.png?s=256",
                    "display_name": "Greg",
                    "link": "https://stackoverflow.com/users/2347677/greg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608154071,
                "post_id": 65328491,
                "comment_id": 115499524,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608155912,
                "creation_date": 1608155912,
                "answer_id": 65331727,
                "question_id": 65328491,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; the string that jq parses\r\n\r\nIf you use the -n command-line option, then the JSON that jq is currently parsing is none other than `input`; otherwise, it is `.`.  \r\n\r\nSo you could for example write:\r\n\r\n    jq &#39;. as $json | ....&#39;\r\n\r\nwhere .... can contain `$json`.\r\n\r\nYou might also like to look at the documentation for `input_filename` and `input_filename` for finer-grain details about the JSON being read.\r\n\r\n(`$__loc__` by contrast gives some information about where in the jq program execution is taking place.)",
                "title": "language reference for current command being executed"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608155912,
        "creation_date": 1608140865,
        "question_id": 65328491,
        "body_markdown": "I was just wondering if there is a way to reference the query we are doing?\r\n\r\n```\r\njq { &quot;foo&quot;: currentquerystring }\r\n```\r\n\r\nthis jq command would output:\r\n```\r\n{ &quot;foo&quot;: &quot;{ \\&quot;foo\\&quot;: currentquerystring }&quot; }\r\n```\r\n\r\nI realize the input can come from include files, is there some way I can get a look at the string that jq parses? Is there such a reference for *currentquerystring* ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65328491/language-reference-for-current-command-being-executed",
        "title": "language reference for current command being executed"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value",
            "weather-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608148108,
                "post_id": 65330108,
                "comment_id": 115497317,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8007028,
                    "reputation": 75,
                    "user_id": 6166837,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-Eb8m0PSAiJo/AAAAAAAAAAI/AAAAAAAAAD8/LHQwtAFPzfw/s256-rj/photo.jpg",
                    "display_name": "Ogal Finklestein",
                    "link": "https://stackoverflow.com/users/6166837/ogal-finklestein"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608151592,
                "post_id": 65330108,
                "comment_id": 115498571,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8007028,
                    "reputation": 75,
                    "user_id": 6166837,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-Eb8m0PSAiJo/AAAAAAAAAAI/AAAAAAAAAD8/LHQwtAFPzfw/s256-rj/photo.jpg",
                    "display_name": "Ogal Finklestein",
                    "link": "https://stackoverflow.com/users/6166837/ogal-finklestein"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608212144,
                "post_id": 65330108,
                "comment_id": 115517777,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608155185,
                "last_edit_date": 1608155185,
                "creation_date": 1608154402,
                "answer_id": 65331432,
                "question_id": 65330108,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.properties.periods[:3]` evaluates to an array of the three items, whereas `.properties.periods[0,1,2]` produces an itemization.  So the abbreviation of the latter would be:\r\n\r\n    .properties.periods[:3][]\r\n\r\n## Selection\r\n\r\nThere are numerous possibilities, e.g. to get a specific set of key-value pairs on a single line:\r\n\r\n    jq -c &#39;.properties.periods[:3][]\r\n           | {shortForecast, temperature}&#39; input.json\r\n\r\nTo select just the values as CSV:\r\n```\r\n.properties.periods[:3][]\r\n| {shortForecast, temperature}\r\n| [.[]]\r\n| @csv\r\n```\r\n\r\nYou might like to use `@tsv` instead, or `join(&quot; &quot;)`, or ....\r\n\r\n## Bonus\r\n\r\nTo get all the values in the order in which they are given, you could simply omit the selection line: `| {....}`\r\n\r\nHowever, that would not be so robust.  The following would be safer:\r\n\r\n```\r\n.properties.periods[:3]\r\n| (.[0] | keys_unsorted) as $keys\r\n| .[]\r\n| [.[$keys[]]]\r\n| @tsv\r\n```\r\n",
                "title": "jq: grab specific repeating key-value from first N elements"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1608223160,
        "creation_date": 1608147770,
        "last_edit_date": 1608223160,
        "question_id": 65330108,
        "body_markdown": "I am trying to parse https://api.weather.gov/gridpoints/PHI/47,91/forecast/hourly, with mild success.\r\n\r\n    {\r\n      &quot;number&quot;: 1,\r\n      &quot;name&quot;: &quot;&quot;,\r\n      &quot;startTime&quot;: &quot;2020-12-16T13:00:00-05:00&quot;,\r\n      &quot;endTime&quot;: &quot;2020-12-16T14:00:00-05:00&quot;,\r\n      &quot;isDaytime&quot;: true,\r\n      &quot;temperature&quot;: 30,\r\n      &quot;temperatureUnit&quot;: &quot;F&quot;,\r\n      &quot;temperatureTrend&quot;: null,\r\n      &quot;windSpeed&quot;: &quot;15 mph&quot;,\r\n      &quot;windDirection&quot;: &quot;NE&quot;,\r\n      &quot;icon&quot;: &quot;https://api.weather.gov/icons/land/day/snow,40?size=small&quot;,\r\n      &quot;shortForecast&quot;: &quot;Chance Light Snow&quot;,\r\n      &quot;detailedForecast&quot;: &quot;&quot;\r\n    }\r\n\r\nI started with `jq &#39;.properties.periods[0]&#39;` to grab the first element, worked with `jq &#39;.properties.periods[0].shortForecast&#39;` and I figured out that `jq &#39;.properties.periods[0,1,2,3]&#39;` gets me the first 4 elements in the array.\r\n\r\nHowever, I run into a syntax error if I try `jq &#39;.properties.periods[:3]&#39;`\r\n&gt; jq: error: syntax error, unexpected &#39;[&#39;\r\n\r\nwhich I thought would be a shorthand for 0-3.\r\n\r\nAdditionally, I only want (the same, repeating) specific K/V pairs from each element (eg: `shortForecast`, `temperature`, etc.), but I have not been able to figure out how to combine it all into one `jq` statement.\r\n\r\nSo how do I grab specific values from the first X elements of an array?  (*I dont really need the keys, just the values.*)\r\n\r\nBonus: would be great to have all values from each element on a single line.\r\n\r\nSample:\r\n```\r\n&quot;2020-12-16T14:00:00-05:00&quot; 30 &quot;Chance Light Snow&quot;\r\n&quot;2020-12-16T15:00:00-05:00&quot; 30 &quot;Snow&quot;\r\n&quot;2020-12-16T16:00:00-05:00&quot; 29 &quot;Heavy Snow&quot;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/65330108/jq-grab-specific-repeating-key-value-from-first-n-elements",
        "title": "jq: grab specific repeating key-value from first N elements"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 12253459,
                    "reputation": 1290,
                    "user_id": 8943092,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/72c7ffe32d55b5a3697090a19f6b97b4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "It&#39;sNotMe",
                    "link": "https://stackoverflow.com/users/8943092/itsnotme"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608150096,
                "post_id": 65330282,
                "comment_id": 115498089,
                "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": 1608153057,
                "post_id": 65330282,
                "comment_id": 115499088,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608152912,
                "last_edit_date": 1608152912,
                "creation_date": 1608152196,
                "answer_id": 65330994,
                "question_id": 65330282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "1. In the first query, there is no need to call jq twice; you can also avoid the UUOC:\r\n```\r\n&lt; sax.json jq &#39;.sax[] | select(.name | contains(&quot;mex&quot;)) | .id&#39; \r\n```\r\n2. To make a shell variable&#39;s value available to jq, it is often best to use the --arg or --argjson command-line option. In your case, you&#39;d want to use --argjson as $i already contains the enclosing quotation marks: `jq --argjson i &quot;$i&quot; ...`\r\n\r\n3. Alternatively, you could set the array contents using `jq -r` to strip away the quotation marks, and then use `--arg i &quot;$i&quot;`.\r\n\r\n4. The semantics of `contains` is rather complex; in general, to check if one string is a substring of another, it is better to use `startswith`, `index`, `test`, or similar, as appropriate.\r\n",
                "title": "jq parse json problem cant get it to cycle loop"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608187662,
                "last_edit_date": 1608187662,
                "creation_date": 1608178429,
                "answer_id": 65334637,
                "question_id": 65330282,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --argjson i &quot;$i&quot; \r\n```\r\n\r\nSo `jq` can&#39;t be used in loop?\r\nforeach?",
                "title": "jq parse json problem cant get it to cycle loop"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1608187662,
        "creation_date": 1608148551,
        "last_edit_date": 1608151186,
        "question_id": 65330282,
        "body_markdown": "```\r\n$ cat sax.json \r\n\r\n{&quot;sax&quot;: [{&quot;name&quot;: &quot;mex20&quot;, &quot;links&quot;: {&quot;self&quot;: &quot;http://website/catalog/sax/e49887&quot;}, &quot;tags&quot;: null, &quot;enabled&quot;: true, &quot;id&quot;: &quot;e49887&quot;, &quot;description&quot;: null}, {&quot;name&quot;: &quot;mex15&quot;, &quot;links&quot;: {&quot;self&quot;: &quot;http://website/catalog/sax/e6de26&quot;}, &quot;tags&quot;: null, &quot;enabled&quot;: true, &quot;id&quot;: &quot;e6de26&quot;, &quot;description&quot;: null}, {&quot;name&quot;: &quot;mex56&quot;, &quot;links&quot;: {&quot;self&quot;: &quot;http://website/catalog/sax/6cc093&quot;}, &quot;tags&quot;: null, &quot;enabled&quot;: true, &quot;id&quot;: &quot;6cc093&quot;, &quot;description&quot;: null}, {&quot;name&quot;: &quot;mex82&quot;, &quot;links&quot;: {&quot;self&quot;: &quot;http://website/catalog/sax/89e0fe&quot;}, &quot;tags&quot;: null, &quot;enabled&quot;: true, &quot;id&quot;: &quot;89e0fe&quot;, &quot;description&quot;: null}]}\r\n```\r\n```\r\n$ cat sax.json | jq  &#39;.sax[] | select(.name | contains(&quot;mex&quot;))&#39; | jq .id\r\n\r\n&quot;e49887&quot;\r\n&quot;e6de26&quot;\r\n&quot;6cc093&quot;\r\n&quot;89e0fe&quot;\r\n```\r\n\r\nget_id.sh\r\n\r\n```\r\n#!/bin/bash\r\n\r\ndeclare -a array=($(jq .sax[].name sax.json ))\r\n\r\nfor i in &quot;${array[@]}&quot;\r\n  do  cat sax.json | jq &#39;.sax[] | select(.name | contains($i))&#39; | jq .id\r\ndone\r\n```\r\ncycle doesnt work.\r\nhelp please\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65330282/jq-parse-json-problem-cant-get-it-to-cycle-loop",
        "title": "jq parse json problem cant get it to cycle loop"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1608197465,
                "post_id": 65337689,
                "comment_id": 115511178,
                "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": 1608199128,
                "post_id": 65337689,
                "comment_id": 115511950,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1608309036,
                "last_edit_date": 1608309036,
                "creation_date": 1608302151,
                "answer_id": 65358881,
                "question_id": 65337689,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider the following json file (`./json.json`):\r\n```json\r\n{\r\n    &quot;data&quot;: {\r\n        &quot;stage1&quot;: {\r\n            &quot;name&quot;: 1\r\n        },\r\n        &quot;stage2&quot;: {\r\n            &quot;name&quot;: 2\r\n        },\r\n        &quot;stage3&quot;: {\r\n            &quot;name&quot;: 3\r\n        },\r\n        &quot;stage4&quot;: {\r\n            &quot;name&quot;: 4\r\n        },\r\n        &quot;stage5&quot;: {\r\n            &quot;name&quot;: 5\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nWith this setup, you can use [tag:jq]&#39;s arg to parse your iterator:\r\n```bash\r\n#!/bin/bash\r\nfor (( i = 1; i &lt;= 5; i++ )); do\r\n    echo &quot;i: $i&quot;\r\n    jq --arg i $i &#39;.data.stage&#39;$i&#39;.name&#39; &lt; json.json\r\ndone\r\n```\r\n\r\nProducing the following output:\r\n```none\r\ni: 1\r\n1\r\ni: 2\r\n2\r\ni: 3\r\n3\r\ni: 4\r\n4\r\ni: 5\r\n5\r\n```\r\n\r\n&lt;https://stackoverflow.com/questions/34745451/passing-arguments-to-jq-filter&gt;",
                "title": "Pass shell variable to JQ and build a key name using it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608309036,
        "creation_date": 1608196482,
        "last_edit_date": 1608223477,
        "question_id": 65337689,
        "body_markdown": "I need to execute `cat build.json | jq &#39;.Stage*.Name&#39;` for 5 times, where `*` is a number from 1 to 5.\r\n\r\nI tried this:\r\n```\r\nfor (( c=1; c&lt;5; c++ ))\r\ndo\r\n  echo $c\r\n  cat build.json | jq &#39;.Stage${c}.Name&#39;\r\ndone\r\n```\r\nAnd I got this error: \r\n```\r\njq: error: syntax error, unexpected &#39;$&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.Stage${c}.Name      \r\njq: 1 compile error\r\n```\r\nHow do I do this properly?",
        "link": "https://stackoverflow.com/questions/65337689/pass-shell-variable-to-jq-and-build-a-key-name-using-it",
        "title": "Pass shell variable to JQ and build a key name using it"
    },
    {
        "tags": [
            "json",
            "jq",
            "csv"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608214945,
                "post_id": 65341026,
                "comment_id": 115519170,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608210596,
                "creation_date": 1608210596,
                "answer_id": 65341376,
                "question_id": 65341026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There might be a shorter way, but this seems to work:\r\n\r\n    jq -r &#39;.allow[]\r\n           | .ipstart as $ip | .name as $name\r\n           | .resources[].appservice | select(.)\r\n           | .[].name |= $name | .[].ip |= $ip\r\n           | .[] | [.ip, .resourcegroup, .resource, .name]\r\n           | @tsv\r\n    &#39; file.json",
                "title": "jq JSON display all values on same line"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608220567,
                "creation_date": 1608220567,
                "answer_id": 65344075,
                "question_id": 65341026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This simple variation should not have the Cartesian product problem of your attempt. Your mistake seems to be introducing the string interpolation too early.\r\n\r\n```\r\njq -r &#39;.allow[]\r\n       | {ipstart,name} + .resources[].appservice[]?\r\n       | &quot;\\(.ipstart) \\(.resourcegroup) \\(.resource) \\(.name)&quot;\r\n&#39; file.json\r\n```",
                "title": "jq JSON display all values on same line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608310097,
                "creation_date": 1608310097,
                "answer_id": 65360833,
                "question_id": 65341026,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want space-separated values (without regard to whether the values contain spaces), you could use `join/1`:\r\n\r\n    jq -r &#39;.allow[]\r\n       | [.ipstart] \r\n         + (.resources[].appservice[]?\r\n            | [.resourcegroup, .resource]) \r\n         + [.name]\r\n       | join(&quot; &quot;)\r\n     &#39; file.json ",
                "title": "jq JSON display all values on same line"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1608310097,
        "creation_date": 1608209179,
        "last_edit_date": 1608309403,
        "question_id": 65341026,
        "body_markdown": "I am sure this is simple, but I have been trying for hours.  \r\n\r\nI want to display the two values in each object under the appservice array, and list both values per block on one line along with the relevant IP and name.\r\n\r\nMy JSON is like this:\r\n\r\n```\r\n{\r\n  &quot;allow&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;username1&quot;,\r\n      &quot;scm&quot;: &quot;true&quot;,\r\n      &quot;ipstart&quot;: &quot;192.168.1.2&quot;,\r\n      &quot;ipend&quot;: &quot;192.168.1.2&quot;,\r\n      &quot;cidr&quot;: &quot;/32&quot;,\r\n      &quot;resources&quot;: [\r\n        {\r\n          &quot;appservice&quot;: [\r\n            {\r\n              &quot;resourcegroup&quot;: &quot;resourcegroup1&quot;,\r\n              &quot;resource&quot;: &quot;resource1&quot;\r\n            },\r\n            {\r\n              &quot;resourcegroup&quot;: &quot;resourcegroup2&quot;,\r\n              &quot;resource&quot;: &quot;resource2&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;sqlserver&quot;: [\r\n            {\r\n              &quot;resourcegroup&quot;: &quot;resourcegroup3&quot;,\r\n              &quot;resource&quot;: &quot;resource3&quot;\r\n            },\r\n            {\r\n              &quot;resourcegroup&quot;: &quot;resourcegroup4&quot;,\r\n              &quot;resource&quot;: &quot;resource4&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;username2&quot;,\r\n...\r\n...\r\n```\r\n\r\nand I want to end up like this:\r\n\r\n```\r\n192.168.1.2 resourcegroup1 resource1 username1\r\n192.168.1.2 resourcegroup2 resource2 username1\r\n\r\n192.168.1.3 resourcegroup5 resource5 username2\r\n192.168.1.3 resourcegroup6 resource6 username2\r\n```\r\n\r\nI have tried:\r\n\r\n```\r\njq -r &#39;.allow[] | &quot;\\(.ipstart) \\(.resources[].appservice[]?.resourcegroup) \\(.resources[].appservice[]?.resource) \\(.name)&quot;&#39; test.json\r\n```\r\n\r\nwhich must be iterating too many times, as I get double the lines and the &quot;resourcegroup&quot; names are not matching the &quot;resource&quot; names\r\n```\r\n192.168.1.2 resourcegroup1 resource1 username1\r\n192.168.1.2 resourcegroup2 resource1 username1\r\n192.168.1.2 resourcegroup1 resource2 username1\r\n192.168.1.2 resourcegroup2 resource2 username1\r\n192.168.1.3 resourcegroup5 resource5 username2\r\n192.168.1.3 resourcegroup6 resource5 username2\r\n192.168.1.3 resourcegroup5 resource6 username2\r\n192.168.1.3 resourcegroup6 resource6 username2\r\n```\r\nAnd I tried:\r\n\r\n```\r\njq -r &#39;.allow[] | &quot;\\(.ipstart) \\(.resources[].appservice[]? | .[])  \\(.name)&quot;&#39; test.json\r\n```\r\nwhich gives me:\r\n\r\n```\r\n192.168.1.2 resourcegroup1  username1\r\n192.168.1.2 resource1  username1\r\n192.168.1.2 resourcegroup2  username1\r\n192.168.1.2 resource2  username1\r\n192.168.1.3 resourcegroup5  username2\r\n192.168.1.3 resource5  username2\r\n192.168.1.3 resourcegroup6  username2\r\n192.168.1.3 resource6  username2\r\n```\r\n\r\nI tried other combos as well, but the above were the closest.\r\nI could do some sed/awk work to re-parse the jq output, but I&#39;m sure there must be some really simple way via jq to avoid having to re-parse it.",
        "link": "https://stackoverflow.com/questions/65341026/jq-json-display-all-values-on-same-line",
        "title": "jq JSON display all values on same line"
    },
    {
        "tags": [
            "command-line-arguments",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1608259035,
                "post_id": 65350355,
                "comment_id": 115535154,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8877922,
                    "reputation": 173,
                    "user_id": 7187965,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh5.googleusercontent.com/-9HNRD1vFFi0/AAAAAAAAAAI/AAAAAAAAABA/kJ8g7S-I524/s256-rj/photo.jpg",
                    "display_name": "Prashant Pathak",
                    "link": "https://stackoverflow.com/users/7187965/prashant-pathak"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643884995,
                "post_id": 65350355,
                "comment_id": 125460122,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 8877922,
                    "reputation": 173,
                    "user_id": 7187965,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh5.googleusercontent.com/-9HNRD1vFFi0/AAAAAAAAAAI/AAAAAAAAABA/kJ8g7S-I524/s256-rj/photo.jpg",
                    "display_name": "Prashant Pathak",
                    "link": "https://stackoverflow.com/users/7187965/prashant-pathak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643916181,
                "post_id": 65350355,
                "comment_id": 125473131,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8877922,
                    "reputation": 173,
                    "user_id": 7187965,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh5.googleusercontent.com/-9HNRD1vFFi0/AAAAAAAAAAI/AAAAAAAAABA/kJ8g7S-I524/s256-rj/photo.jpg",
                    "display_name": "Prashant Pathak",
                    "link": "https://stackoverflow.com/users/7187965/prashant-pathak"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643977677,
                "post_id": 65350355,
                "comment_id": 125488451,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 8877922,
                    "reputation": 173,
                    "user_id": 7187965,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://lh5.googleusercontent.com/-9HNRD1vFFi0/AAAAAAAAAAI/AAAAAAAAABA/kJ8g7S-I524/s256-rj/photo.jpg",
                    "display_name": "Prashant Pathak",
                    "link": "https://stackoverflow.com/users/7187965/prashant-pathak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1643983345,
                "post_id": 65350355,
                "comment_id": 125490603,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608253127,
                "creation_date": 1608253127,
                "answer_id": 65350427,
                "question_id": 65350355,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; `Argument list too long is a system error`. Argument and environment\r\n&gt; sizes are limited by all Unix-like kernels. You exceeded that size.\r\n&gt; Use -f to pass extra large programs. (But beware that jq function\r\n&gt; bodies, and the top-level jq program, are limited in compiled size to\r\n&gt; 64K code units each.)",
                "title": "-bash: /bin/jq: Argument list too long"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608260036,
                "last_edit_date": 1608260036,
                "creation_date": 1608259626,
                "answer_id": 65351192,
                "question_id": 65350355,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The --slurpfile option is very different from the --arg option.  For one thing, it expects a file (or file handle) to be provided; also, it wraps the contents of the file into an array.\r\n\r\nEven though the --argfile option is deprecated, I would suggest you begin by trying to use it in the simplest possible way, e.g. by first writing the contents of your shell variable to a file, perhaps along the lines of:\r\n\r\n    jq -r &#39;tojson&#39; api.json &gt; out.tmp\r\n    jq --argfile definition out.tmp &#39;.apiDefinition = $definition&#39; api-new.json &gt; api-spec.json\r\n\r\nWhen you&#39;ve got that working, you can move onto better variations.  \r\n\r\nBetter yet, you should be able to combine the two calls to jq into one:\r\n\r\n    jq --argfile definition api.json &#39;.apiDefinition = ($definition|tojson)&#39; api-new.json &gt; api-spec.json\r\n\r\n",
                "title": "-bash: /bin/jq: Argument list too long"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1608294830,
        "creation_date": 1608252468,
        "last_edit_date": 1608294830,
        "question_id": 65350355,
        "body_markdown": "Below 2 jq statements read large json file and copy to another json file. but this statement throws &quot;Argument too long&quot; error. This perfectly fine for smaller json files.\r\n\r\n    $ apiDefinitionString=`jq -r &#39;. | tojson&#39; api.json`\r\n    $ jq --arg definition &quot;$apiDefinitionString&quot; &#39;.apiDefinition = $definition&#39; api-new.json &gt; api-spec.json\r\n\r\nI tried to replace --arg with ----slurpfile as well as recommended in another thread[1] and its same error.\r\n\r\n[1]: https://stackoverflow.com/questions/59854249/usr-bin-jq-argument-list-too-long-error-bash\r\n\r\nDo I any other option to solve this Jq issue ? Is this Jq limitation ? Thanks in Advance.\r\n",
        "link": "https://stackoverflow.com/questions/65350355/bash-bin-jq-argument-list-too-long",
        "title": "-bash: /bin/jq: Argument list too long"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608396211,
                "last_edit_date": 1608396211,
                "creation_date": 1608348090,
                "answer_id": 65366372,
                "question_id": 65366371,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So I experimented on [jqplay](https://jqplay.org) until it delivered the needed format. I don&#39;t know if it&#39;s optimal, but this worked:\r\n\r\n`jq &#39;[.[] | {hero, superpowers: [ .superpowers[] | {name, des} ] } ]&#39;`\r\n\r\n\r\n(A graphQL-like filter syntax would make this easier.)\r\n\r\nNote: The output required for my json differs from what is mentioned in [this question and answer](https://stackoverflow.com/questions/65277686/select-multiple-fields-at-different-levels\r\n), and I have avoided using map (iterator) in the solution. In other words, I&#39;m not asking the same question, or presenting the same answer. \r\n\r\nIt would be helpful to know if my solution is optimal.\r\n\r\n\r\n",
                "title": "Use jq nested array values"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608396211,
        "creation_date": 1608348090,
        "last_edit_date": 1608349308,
        "question_id": 65366371,
        "body_markdown": "I have a file, let&#39;s call it `heroes.json`, where part of the data is a nested array of object, `superpowers`: \r\n```\r\n[\r\n  {\r\n    &quot;hero&quot;: &quot;Superman&quot;,\r\n    &quot;id&quot;: &quot;123&quot;,\r\n    &quot;realName&quot;: &quot;Clark Kent&quot;,\r\n    &quot;age&quot;: &quot;?&quot;,\r\n    &quot;superpowers&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;speed&quot;,\r\n        &quot;num&quot;: &quot;1&quot;,\r\n        &quot;des&quot;: &quot;Faster than a speeding bullet.&quot;,\r\n        &quot;value&quot;: &quot;50&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;strength&quot;,\r\n        &quot;num&quot;: &quot;2&quot;,\r\n        &quot;des&quot;: &quot;More powerful than a locomotive.&quot;,\r\n        &quot;value&quot;: &quot;100&quot;\r\n      }\r\n    ],\r\n    &quot;weakness&quot;: &quot;kryptonite&quot;\r\n  },\r\n  {\r\n    &quot;hero&quot;: &quot;Batman&quot;,\r\n    &quot;id&quot;: &quot;456&quot;,\r\n...\r\n```\r\n\r\nI want to select `hero` and `superpowers`, and keep only `name` and `des` keys within `superpowers`, like:\r\n \r\n```\r\n[\r\n  {\r\n    &quot;hero&quot;: &quot;Superman&quot;,\r\n    &quot;superpowers&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;speed&quot;,\r\n        &quot;des&quot;: &quot;Faster than a speeding bullet.&quot;\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;strength&quot;,\r\n        &quot;des&quot;: &quot;More powerful than a locomotive.&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;hero&quot;: &quot;Batman&quot;,\r\n    &quot;superpowers&quot;: [\r\n ...\r\n```\r\n\r\nIt wouldn&#39;t be hard to write an iterator to do this, but I want to try jq as I&#39;m new to this tool and it seems useful to learn.",
        "link": "https://stackoverflow.com/questions/65366371/use-jq-nested-array-values",
        "title": "Use jq nested array values"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608484233,
                "post_id": 65382515,
                "comment_id": 115592405,
                "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": 1608486774,
                "post_id": 65382515,
                "comment_id": 115593181,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1608484829,
                "creation_date": 1608484829,
                "answer_id": 65382679,
                "question_id": 65382515,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the jq program, `$i` refers to the jq variable `$i`, not the bash variable `$i`.\r\n\r\n```bash\r\njq -r --arg i &quot;$i&quot; &#39;.magic[] | select(.id == $i) | .name&#39;\r\n```",
                "title": "for loop select construction jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608484850,
        "creation_date": 1608483972,
        "last_edit_date": 1608484850,
        "question_id": 65382515,
        "body_markdown": "required help\r\nneed get the name value from id\r\nmy bash script\r\ncant get it to work \r\n\r\n\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\narray=( &quot;111&quot; &quot;222&quot; etc...)\r\n\r\nfor i in &quot;${array[@]}&quot;; do\r\n   my_power=$(\r\n      curl -s -X GET -H &quot;Content-Type: application/json&quot; http://website/list |\r\n         jq -r &#39;.magic[] | select(.id == &quot;$i&quot;) | .name&#39;\r\n   )\r\n   echo &quot;$my_power&quot;\r\n   magic_array+=( &quot;$my_power&quot; )\r\ndone \r\n```\r\n\r\n`$magic_array` is empty. The `echo` prints nothing.\r\n\r\n```bash\r\ncurl -s -X GET -H &quot;Content-Type: application/json&quot; http://website/list \r\n```\r\n\r\noutputs the following all on one line:\r\n\r\n```json\r\n{\r\n  &quot;magic&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;fly&quot;,\r\n      &quot;links&quot;: {\r\n        &quot;self&quot;: &quot;http://website/111&quot;\r\n      },\r\n      &quot;tags&quot;: null,\r\n      &quot;enabled&quot;: true,\r\n      &quot;id&quot;: &quot;111&quot;,\r\n      &quot;description&quot;: null\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;sleep&quot;,\r\n      &quot;links&quot;: {\r\n        &quot;self&quot;: &quot;http://website/222&quot;\r\n      },\r\n      &quot;tags&quot;: null,\r\n      &quot;enabled&quot;: true,\r\n      &quot;id&quot;: &quot;222&quot;,\r\n      &quot;description&quot;: null\r\n    }\r\n  ],\r\n  &quot;links&quot;: {\r\n    &quot;self&quot;: &quot;http://website/list&quot;,\r\n    &quot;previous&quot;: null,\r\n    &quot;next&quot;: null\r\n  }\r\n}\r\n```\r\n\r\nDirect request from command line work perfect \r\n\r\n```lang-none\r\n$ curl -s -X GET -H &quot;Content-Type: application/json&quot; http://website/list |\r\n   jq -r &#39;.magic[] | select(.id == &quot;111&quot;) | .name&#39;\r\nfly\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/65382515/for-loop-select-construction-jq-in-bash",
        "title": "for loop select construction jq in bash"
    },
    {
        "tags": [
            "json",
            "path",
            "key",
            "element",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608652536,
                "last_edit_date": 1608652536,
                "creation_date": 1608517249,
                "answer_id": 65386816,
                "question_id": 65384888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think this does what you want.\r\n\r\n    curl -s &quot;https://poloniex.com/public?command=returnTicker&quot; | \\\r\n    jq -r &#39;to_entries\r\n           | .[] \r\n           | [ .key, (.value | to_entries | .[] | .value) ] \r\n           | join(&quot; : &quot;)&#39;\r\n\r\nIn a nutshell, put everything in an array and use `join` to produce the desired output.\r\n\r\n**Update**\r\n\r\nAs luciole75w notes, my solution has too many steps. This is better.\r\n\r\n    jq -r &#39;to_entries[] | [ .key, .value[] ] | join(&quot; : &quot;)&#39;\r\n\r\nThat said, I would use peak&#39;s solution. Mine does not guarantee that the columns are the same for each line.",
                "title": "Getting the first element of json data with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608520526,
                "creation_date": 1608520526,
                "answer_id": 65387151,
                "question_id": 65384888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To be safe, it might be better not to assume that the ordering of the keys is the same in all the inner objects.  Ergo:\r\n```\r\nkeys_unsorted as $outer\r\n| (.[$outer[0]] | keys_unsorted) as $keys\r\n| $outer[] as $k\r\n| [ $k, .[$k][$keys[]] ]\r\n| join(&quot; : &quot;)\r\n```",
                "title": "Getting the first element of json data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1608652536,
        "creation_date": 1608499141,
        "last_edit_date": 1608523955,
        "question_id": 65384888,
        "body_markdown": "I&#39;m working with Poloniex API. While using returnTicker function, the data comes like this.\r\n\r\ncurl &quot;https://poloniex.com/public?command=returnTicker&quot;\r\n\r\n```\r\n{\r\n  &quot;BTC_BTS&quot;: {\r\n    &quot;id&quot;: 14,\r\n    &quot;last&quot;: &quot;0.00000111&quot;,\r\n    &quot;lowestAsk&quot;: &quot;0.00000112&quot;,\r\n    &quot;highestBid&quot;: &quot;0.00000110&quot;,\r\n    &quot;percentChange&quot;: &quot;0.09900990&quot;,\r\n    &quot;baseVolume&quot;: &quot;3.12079869&quot;,\r\n    &quot;quoteVolume&quot;: &quot;2318738.79293715&quot;,\r\n    &quot;isFrozen&quot;: &quot;0&quot;,\r\n    &quot;high24hr&quot;: &quot;0.00000152&quot;,\r\n    &quot;low24hr&quot;: &quot;0.00000098&quot;\r\n  },\r\n  &quot;BTC_DASH&quot;: {\r\n    &quot;id&quot;: 24,\r\n    &quot;last&quot;: &quot;0.00466173&quot;,\r\n    &quot;lowestAsk&quot;: &quot;0.00466008&quot;,\r\n    &quot;highestBid&quot;: &quot;0.00464358&quot;,\r\n    &quot;percentChange&quot;: &quot;0.02318430&quot;,\r\n    &quot;baseVolume&quot;: &quot;1.98111396&quot;,\r\n    &quot;quoteVolume&quot;: &quot;425.22973220&quot;,\r\n    &quot;isFrozen&quot;: &quot;0&quot;,\r\n    &quot;high24hr&quot;: &quot;0.00482962&quot;,\r\n    &quot;low24hr&quot;: &quot;0.00450482&quot;\r\n....\r\n\r\n  },\r\n  &quot;USDT_GRT&quot;: {\r\n    &quot;id&quot;: 497,\r\n    &quot;last&quot;: &quot;0.72811272&quot;,\r\n    &quot;lowestAsk&quot;: &quot;0.75999916&quot;,\r\n    &quot;highestBid&quot;: &quot;0.72740000&quot;,\r\n    &quot;percentChange&quot;: &quot;0.48594450&quot;,\r\n    &quot;baseVolume&quot;: &quot;133995.43411815&quot;,\r\n    &quot;quoteVolume&quot;: &quot;194721.36672887&quot;,\r\n    &quot;isFrozen&quot;: &quot;0&quot;,\r\n    &quot;high24hr&quot;: &quot;0.79000000&quot;,\r\n    &quot;low24hr&quot;: &quot;0.45000020&quot;\r\n  },\r\n  &quot;TRX_SUN&quot;: {\r\n    &quot;id&quot;: 498,\r\n    &quot;last&quot;: &quot;500.00000000&quot;,\r\n    &quot;lowestAsk&quot;: &quot;449.99999999&quot;,\r\n    &quot;highestBid&quot;: &quot;100.00000000&quot;,\r\n    &quot;percentChange&quot;: &quot;0.00000000&quot;,\r\n    &quot;baseVolume&quot;: &quot;0.00000000&quot;,\r\n    &quot;quoteVolume&quot;: &quot;0.00000000&quot;,\r\n    &quot;isFrozen&quot;: &quot;0&quot;,\r\n    &quot;high24hr&quot;: &quot;0.00000000&quot;,\r\n    &quot;low24hr&quot;: &quot;0.00000000&quot;\r\n  }\r\n}  \r\n\r\n\r\n```\r\n\r\nI want the output like this \r\n\r\n```\r\nBTC_BTS : 14 : 0.00000111 : 0.00000112 : 0.00000110 : 0.09900990 : 3.12079869 : 2318738.79293715 : 0 : 0.00000152 : 0.00000098\r\n...\r\nUSDT_GRT : 497 : 0.72428700 : 0.75999958 : 0.72630001 : 0.47813685 : 133968.74968533 : 194695.96886712 : 0 : 0.79000000 : 0.45000020\r\nTRX_SUN : 498 : 500.00000000 : 449.99999999 : 100.00000000 : 0.00000000 : 0.00000000 : 0.00000000 : 0 : 0.00000000 : 0.00000000\r\n\r\n```\r\n\r\n\r\n\r\nI am using jq and my problem is accesing the currency pair name. \r\n\r\nI could do this; \r\n\r\n\r\n```\r\n14 : 0.00000111 : 0.00000112 : 0.00000110 : 0.09900990 : 3.12079869 : 2318738.79293715 : 0 : 0.00000152 : 0.00000098\r\n...\r\n497 : 0.72428700 : 0.75999958 : 0.72630001 : 0.47813685 : 133968.74968533 : 194695.96886712 : 0 : 0.79000000 : 0.45000020\r\n498 : 500.00000000 : 449.99999999 : 100.00000000 : 0.00000000 : 0.00000000 : 0.00000000 : 0 : 0.00000000 : 0.00000000\r\n\r\n```\r\n\r\nby using this command; \r\n\r\n```\r\ncurl &quot;https://poloniex.com/public?command=returnTicker&quot; |jq -r | jq &#39;.[] | (.id|tostring) + &quot; : &quot; + (.last|tostring) + &quot; : &quot; + (.lowestAsk|tostring) + &quot; : &quot; + (.highestBid|tostring) + &quot; : &quot; + (.percentChange|tostring) + &quot; : &quot; + (.baseVolume|tostring) + &quot; : &quot; + (.quoteVolume|tostring) + &quot; : &quot; + (.isFrozen|tostring) + &quot; : &quot; + (.high24hr|tostring) + &quot; : &quot; + (.low24hr|tostring)&#39;|jq -r\r\n```\r\n\r\n\r\n\r\n\r\nnot only this, in every jq pipeline, I cant access the first element of json \r\n\r\n\r\n\r\nI am not meaning the **|jq .BTC_BTS** or **|jq .USDT_GRT** pipeline. \r\n\r\n **|jq .** gives whole json, **|jq .[]** gives the sub elements after the first element. \r\n\r\nHow can i access the first path? \r\n\r\n\r\n\r\nBy the way, I may have written stupid and long pipeline with jq. If you have any idea to convert whole json to a row-column data, I am open to your ideas. \r\n\r\n\r\n\r\nThank you all for your answers. \r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65384888/getting-the-first-element-of-json-data-with-jq",
        "title": "Getting the first element of json data with jq"
    },
    {
        "tags": [
            "json",
            "select",
            "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": 1608532838,
                "post_id": 65388388,
                "comment_id": 115603048,
                "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": 1608532978,
                "post_id": 65388388,
                "comment_id": 115603078,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19883782,
                    "reputation": 71,
                    "user_id": 14567176,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/77oYW.jpg?s=256",
                    "display_name": "FrinkLabs",
                    "link": "https://stackoverflow.com/users/14567176/frinklabs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608533970,
                "post_id": 65388388,
                "comment_id": 115603332,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608536833,
                "last_edit_date": 1608536833,
                "creation_date": 1608533457,
                "answer_id": 65388580,
                "question_id": 65388388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The program below selects planets whose moons have all been spoiled. As each *parameter* is a name-value pair, we can use `from_entries` to transform the array of parameters into an object and retrieve the *unspoiled* status with just `.unspoiled`, and thus avoid another `select` to find the parameter we&#39;re interested in.\r\n```\r\n.Planets[] | select(.satellites | all(.parameters | from_entries .unspoiled == &quot;no&quot;)) .names.french\r\n```\r\nIf a single spoiled moon is enough, change `all` to `any`.\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/BWoS6URuiI)&lt;/sup&gt;",
                "title": "Display an object if a nephew element array contains a value"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608976575,
                "last_edit_date": 1608976575,
                "creation_date": 1608802066,
                "answer_id": 65436410,
                "question_id": 65388388,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "And here, also a solution for the same JSON query using an alternative tool (`jtc`):\r\n\r\nIn the simplest form, the following will do:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;[value]:&lt;no&gt;:[-5][names][french]&#39;\r\n&quot;Terre&quot;\r\n```\r\n\r\nHowever, that solution will return planet&#39;s french name for each of the moon, e.g., for spoiled moons it would give this:\r\n```\r\nbash $ &lt;file.json jtc -w&#39;[value]:&lt;yes&gt;:[-5][names][french]&#39;\r\n&quot;Mars&quot;\r\n&quot;Mars&quot;\r\nbash $ \r\n```\r\n\r\nFor the case when there&#39;re multiple moons but the name is required only once, strengthen the query like this (showcasing here spoiled moons): \r\n \r\n```\r\nbash $ &lt;file.json jtc -w&#39;&lt;satellites&gt;l:[value]:&lt;yes&gt;[-5][names][french]&#39;\r\n&quot;Mars&quot;\r\nbash $ \r\n```\r\n\r\nPS. I&#39;m a deveoper of `jtc` unix JSON processor  \r\nPPS. the above disclaimer is required by SO.\r\n\r\n### Update:\r\nthe answer was updated based on discussion in comments with @oguzismail to enhance structural relationship between `value` and `french` labels so that other (irrelevant) possible `value` matches won&#39;t trigger false positives.  \r\nIf, by a chance, the structural relation `[-5][names]` is not enough, the query then can be ultimately enhanced by inserting `&lt;unspoiled&gt;[-1]` before `[value]...` lexeme",
                "title": "Display an object if a nephew element array contains a value"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1608976575,
        "creation_date": 1608532109,
        "last_edit_date": 1608540152,
        "question_id": 65388388,
        "body_markdown": "[Select objects based on value of variable in object using jq][1]\r\n\r\nThat shows how to return values directly above the selection criteria but how would I get another object that was adjacent to a value above my selection criteria?\r\n\r\nGiven the data below, what jq invocation would return the French name of planets whose moon(s) have been spoiled?   (this is a structural reproduction of the live data with which I am working -- which actually uses the word &quot;value&quot; in this way, so that&#39;s not helping)\r\n\r\n    {&quot;kind&quot;:&quot;solarsystem&quot;,&quot;name&quot;:&quot;Sol&quot;,\r\n    &quot;Planets&quot;: [\r\n     { &quot;kind&quot;:&quot;habitable&quot;,\r\n      &quot;names&quot;: { &quot;english&quot;:&quot;Earth&quot;,&quot;french&quot;:&quot;Terre&quot;},\r\n      &quot;satellites&quot; : [\r\n        {&quot;name&quot;:&quot;The Moon&quot;,\r\n         &quot;parameters&quot;: [\r\n           {&quot;name&quot;:&quot;diameter&quot;, &quot;intValue&quot;:&quot;3476&quot;},\r\n           {&quot;name&quot;:&quot;diameter_units&quot;, &quot;value&quot;:&quot;km&quot;},\r\n           {&quot;name&quot;:&quot;unspoiled&quot;,&quot;value&quot;:&quot;no&quot;}]}]},\r\n     {&quot;kind&quot;:&quot;uninhabitable&quot;,\r\n      &quot;names&quot;: {&quot;english&quot;:&quot;Mars&quot;,&quot;french&quot;:&quot;Mars&quot;},\r\n      &quot;satellites&quot; : [\r\n        {&quot;name&quot;:&quot;Phobos&quot;,\r\n         &quot;parameters&quot;: [\r\n           {&quot;name&quot;:&quot;diameter&quot;, &quot;intValue&quot;:&quot;2200&quot;},\r\n           {&quot;name&quot;:&quot;diameter_units&quot;, &quot;value&quot;:&quot;m&quot;},\r\n           {&quot;name&quot;:&quot;unspoiled&quot;,&quot;value&quot;:&quot;yes&quot;}]},\r\n        {&quot;name&quot;:&quot;Deimos&quot;,\r\n         &quot;parameters&quot;: [\r\n           {&quot;name&quot;:&quot;diameter&quot;, &quot;intValue&quot;:&quot;1200&quot;},\r\n           {&quot;name&quot;:&quot;diameter_units&quot;, &quot;value&quot;:&quot;m&quot;},\r\n           {&quot;name&quot;:&quot;unspoiled&quot;,&quot;value&quot;:&quot;yes&quot;}]}]}]}\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/18592173/select-objects-based-on-value-of-variable-in-object-using-jq",
        "link": "https://stackoverflow.com/questions/65388388/display-an-object-if-a-nephew-element-array-contains-a-value",
        "title": "Display an object if a nephew element array contains a value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608570066,
                "post_id": 65391557,
                "comment_id": 115618153,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608574360,
                "post_id": 65391557,
                "comment_id": 115620080,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608549054,
                "creation_date": 1608549054,
                "answer_id": 65391714,
                "question_id": 65391557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    Try : Array[index_of_object].property = value\r\n    for example : array[0].a = 1\r\n\r\n",
                "title": "How to &quot;number&quot; array items?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1608573442,
                "last_edit_date": 1608573442,
                "creation_date": 1608549683,
                "answer_id": 65391858,
                "question_id": 65391557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `reduce`, without disassembling/reassembling the input:\r\n```\r\nreduce range(length) as $index (.; .[$index] += {$index})\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/9rmU_bulwH)&lt;/sup&gt;",
                "title": "How to &quot;number&quot; array items?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608551164,
                "last_edit_date": 1608551164,
                "creation_date": 1608549813,
                "answer_id": 65391886,
                "question_id": 65391557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Store the structure into a variable, then use `keys` to get the indices, retrieve the corresponding object from the variable using the index and add the index to it:\r\n\r\n    jq &#39;[ . as $d | keys[] | $d[.] + {index:.} ]&#39; file.json",
                "title": "How to &quot;number&quot; array items?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608551488,
                "creation_date": 1608551488,
                "answer_id": 65392275,
                "question_id": 65391557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`to_entries` takes an object and returns an array of key/value pairs.\r\nIt can be used effectively and intuitively.\r\n* [jq/to_entries](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)\r\n### input file\r\n```json\r\n// file.json\r\n[\r\n    {\r\n      &quot;a&quot;: 1\r\n    },\r\n    {\r\n      &quot;a&quot;: 2\r\n    },\r\n    {\r\n      &quot;a&quot;: 7\r\n    }\r\n]\r\n```\r\n\r\n### commands\r\n```\r\njq &#39;to_entries | map(.value+{index:.key})&#39; file.json\r\n```\r\n\r\n### results\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;index&quot;: 0\r\n  },\r\n  {\r\n    &quot;a&quot;: 2,\r\n    &quot;index&quot;: 1\r\n  },\r\n  {\r\n    &quot;a&quot;: 7,\r\n    &quot;index&quot;: 2\r\n  }\r\n]\r\n```\r\n",
                "title": "How to &quot;number&quot; array items?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608558689,
                "creation_date": 1608558689,
                "answer_id": 65393978,
                "question_id": 65391557,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s also an alternative (non-jq) solution, using `jtc`:\r\n```\r\nbash $ &lt;input.json jtc -w&#39;[:]&lt;I&gt;k&#39; -i&#39;{&quot;index&quot;:{I}}&#39;\r\n[\r\n   {\r\n      &quot;a&quot;: 1,\r\n      &quot;index&quot;: 0\r\n   },\r\n   {\r\n      &quot;a&quot;: 2,\r\n      &quot;index&quot;: 1\r\n   },\r\n   {\r\n      &quot;a&quot;: 7,\r\n      &quot;index&quot;: 2\r\n   }\r\n]\r\nbash $ \r\n```\r\n\r\n\r\nPS. I&#39;m a developer of `jtc` - unix JSON processor  \r\nPPS. The disclaimer is required by SO.",
                "title": "How to &quot;number&quot; array items?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 2,
        "last_activity_date": 1664763858,
        "creation_date": 1608548434,
        "last_edit_date": 1664763858,
        "question_id": 65391557,
        "body_markdown": "Considering input:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 1\r\n      },\r\n      {\r\n        &quot;a&quot;: 2\r\n      },\r\n      {\r\n        &quot;a&quot;: 7\r\n      }\r\n    ]\r\n\r\nhow do I add new field to each object, which value would be index in array? Producing:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: 1,\r\n        &quot;index&quot;: 0\r\n      },\r\n      {\r\n        &quot;a&quot;: 2,\r\n        &quot;index&quot;: 1\r\n      },\r\n      {\r\n        &quot;a&quot;: 7,\r\n        &quot;index&quot;: 2\r\n      }\r\n    ]\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65391557/how-to-number-array-items",
        "title": "How to &quot;number&quot; array items?"
    },
    {
        "tags": [
            "iteration",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1666859,
                    "reputation": 3179,
                    "user_id": 1534084,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ef28a37ab34404c23fb91ca55a09ba8a?s=256&d=identicon&r=PG",
                    "display_name": "Martin Mucha",
                    "link": "https://stackoverflow.com/users/1534084/martin-mucha"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608558835,
                "post_id": 65391586,
                "comment_id": 115612858,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608564531,
                "last_edit_date": 1608564531,
                "creation_date": 1608560807,
                "answer_id": 65394512,
                "question_id": 65391586,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\nreduce SOURCE as $VAR (INIT; REDUCTION)\r\n```\r\n\r\nis equivalent to\r\n\r\n```jq\r\n[ foreach SOURCE as $VAR (INIT; REDUCTION; .) ] | last\r\n```\r\n\r\nConversely,\r\n\r\n```jq\r\nforeach SOURCE as $VAR (INIT; UPDATE; EXTRACT)\r\n```\r\n\r\nis equivalent to\r\n\r\n```jq\r\nreduce SOURCE as $VAR (\r\n   { state: ( INIT ), rv: [] };\r\n   .state |= ( UPDATE ) |\r\n   .rv += [ .state | EXTRACT ]\r\n) | .rv[]\r\n```\r\n\r\nA you can see, they are very similar. Practically identical, in fact. \r\n\r\n* Use `reduce` when you want a single result.\r\n* Use `foreach` when you want a result for each input.\r\n\r\n---\r\n\r\nFor example, say we have the following input:\r\n\r\n```json\r\n[&quot;abc&quot;, &quot;def&quot;, &quot;ghi&quot;, &quot;jkl&quot;, &quot;mno&quot;]\r\n```\r\n\r\n```jq\r\nforeach .[] as $var (false; not; .)\r\n```\r\n\r\nproduces\r\n\r\n```jsonl\r\ntrue\r\nfalse\r\ntrue\r\nfalse\r\ntrue\r\n```\r\n\r\nso\r\n\r\n```jq\r\nforeach .[] as $var (false; not; if . then $var else empty end)\r\n```\r\n\r\nproduces\r\n\r\n```jsonl\r\n&quot;abc&quot;\r\n&quot;ghi&quot;\r\n&quot;mno&quot;\r\n```\r\n",
                "title": "how is reduce defined (using foreach)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608612925,
        "creation_date": 1608548563,
        "last_edit_date": 1608612925,
        "question_id": 65391586,
        "body_markdown": "I&#39;m having hard time understanding how to use `foreach`. I kinda &quot;understands&quot; the text, but the example given in manual is little bit over my head. Can you please show me how to define `reduce` operation using `foreach`?",
        "link": "https://stackoverflow.com/questions/65391586/how-is-reduce-defined-using-foreach",
        "title": "how is reduce defined (using foreach)"
    },
    {
        "tags": [
            "json",
            "max",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608558720,
                "creation_date": 1608558720,
                "answer_id": 65393984,
                "question_id": 65392957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`max` expects an array.\r\n\r\n```jq\r\n[ .backup[] | select( .type == &quot;full&quot; ).timestamp.stop ] | max\r\n```\r\n\r\n[Test](https://jqplay.org/s/hVP6AyGoSo)\r\n\r\nor\r\n\r\n```jq\r\n.backup | map( select( .type == &quot;full&quot; ).timestamp.stop ) | max\r\n```\r\n\r\n[Test](https://jqplay.org/s/6FpqjnOqTH)",
                "title": "How to select max value by condition and then compare it with others?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608567149,
                "last_edit_date": 1608567149,
                "creation_date": 1608566466,
                "answer_id": 65395984,
                "question_id": 65392957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the aid of a generic helper-function for counting, here&#39;s a complete solution, assuming you want to count based on `.timestamp.start`:\r\n```\r\ndef count(s): reduce s as $x (0; .+1);\r\n\r\n.backup\r\n| (map( select( .type == &quot;full&quot; ).timestamp.stop) | max) as $max\r\n| count(.[] | select( .type == &quot;incr&quot; and  .timestamp.start &gt; $max))\r\n```\r\n\r\n## Using `max/1`\r\n\r\nFor large arrays, it would probably be more efficient to use a streaming version of `max`:\r\n```\r\ndef count(s): reduce s as $x (0; .+1);\r\n\r\n# Note: max(empty) #=&gt; null\r\ndef max(s):\r\n  reduce s as $s (null; if $s &gt; .m then $s else . end);\r\n\r\n.backup\r\n| max(.[] | select( .type == &quot;full&quot; ).timestamp.stop) as $max\r\n| count(.[] | select( .type == &quot;incr&quot; and  .timestamp.start &gt; $max))\r\n```\r\n\r\n",
                "title": "How to select max value by condition and then compare it with others?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608644941,
                "creation_date": 1608644941,
                "answer_id": 65409834,
                "question_id": 65392957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "So, after I solved problem with getting concrete value (thanks @ikegami), I solved my entire question by this way\r\n\r\n````\r\n jq &#39;(.[0] |[.backup[] | select(.type==&quot;full&quot;).timestamp.stop]|max) as $i| [.[0] |.backup[] | select(.type==&quot;incr&quot; and .timestamp.stop&gt;$i)]|length\r\n````\r\n\r\nNot sure if it made optimal, but it works anyway.",
                "title": "How to select max value by condition and then compare it with others?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608739276,
                "last_edit_date": 1608739276,
                "creation_date": 1608738031,
                "answer_id": 65426936,
                "question_id": 65392957,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s also an alternative (non-jq) solution how to achieve the same JSON query with `jtc` tool:\r\n\r\n```\r\nbash $ &lt;input.json jtc -jw&#39;[timestamp]:&lt;&gt;G:[-1][type]&#39; / -w&#39;&lt;full&gt;&lt;&gt;k&#39;\r\n2\r\n```\r\n\r\nPS. I&#39;m a developer of `jtc` unix JSON processor  \r\nPPS. the above disclaimer is required by SO. ",
                "title": "How to select max value by condition and then compare it with others?"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1608739276,
        "creation_date": 1608554376,
        "last_edit_date": 1608585133,
        "question_id": 65392957,
        "body_markdown": "I have a backup set that is described by json. Sample is below.\r\nI want to count how much increment backups were added since the last full backup.\r\nI try to select max timestamp of the record with type &quot;full&quot; so after that i will count how much records with type &quot;incr&quot; has the bigger timestamp.\r\n\r\n\r\n```json\r\n{\r\n  &quot;archive&quot;: [\r\n    {\r\n      &quot;database&quot;: {\r\n        &quot;id&quot;: 1\r\n      },\r\n      &quot;id&quot;: &quot;11-1&quot;,\r\n      &quot;max&quot;: &quot;0000000A000018B90000006A&quot;,\r\n      &quot;min&quot;: &quot;0000000A0000167D000000C7&quot;\r\n    }\r\n  ],\r\n  &quot;backup&quot;: [\r\n    {\r\n      &quot;archive&quot;: {\r\n        &quot;start&quot;: &quot;0000000A0000181600000030&quot;,\r\n        &quot;stop&quot;: &quot;0000000A0000181C00000083&quot;\r\n      },\r\n      &quot;backrest&quot;: {\r\n        &quot;format&quot;: 5,\r\n        &quot;version&quot;: &quot;2.28&quot;\r\n      },\r\n      &quot;database&quot;: {\r\n        &quot;id&quot;: 1\r\n      },\r\n      &quot;info&quot;: {\r\n        &quot;delta&quot;: 417875448942,\r\n        &quot;repository&quot;: {\r\n          &quot;delta&quot;: 67466720725,\r\n          &quot;size&quot;: 67466720725\r\n        },\r\n        &quot;size&quot;: 417875448942\r\n      },\r\n      &quot;label&quot;: &quot;20201213-200009F&quot;,\r\n      &quot;prior&quot;: null,\r\n      &quot;reference&quot;: null,\r\n      &quot;timestamp&quot;: {\r\n        &quot;start&quot;: 1607878809,\r\n        &quot;stop&quot;: 1607896232\r\n      },\r\n      &quot;type&quot;: &quot;full&quot;\r\n    },\r\n    {\r\n      &quot;archive&quot;: {\r\n        &quot;start&quot;: &quot;0000000A0000182900000065&quot;,\r\n        &quot;stop&quot;: &quot;0000000A0000182F00000069&quot;\r\n      },\r\n      &quot;backrest&quot;: {\r\n        &quot;format&quot;: 5,\r\n        &quot;version&quot;: &quot;2.28&quot;\r\n      },\r\n      &quot;database&quot;: {\r\n        &quot;id&quot;: 1\r\n      },\r\n      &quot;info&quot;: {\r\n        &quot;delta&quot;: 122520170241,\r\n        &quot;repository&quot;: {\r\n          &quot;delta&quot;: 19316550760,\r\n          &quot;size&quot;: 67786280115\r\n        },\r\n        &quot;size&quot;: 416998156028\r\n      },\r\n      &quot;label&quot;: &quot;20201213-200009F_20201214-200009I&quot;,\r\n      &quot;prior&quot;: &quot;20201213-200009F&quot;,\r\n      &quot;reference&quot;: [\r\n        &quot;20201213-200009F&quot;\r\n      ],\r\n      &quot;timestamp&quot;: {\r\n        &quot;start&quot;: 1607965209,\r\n        &quot;stop&quot;: 1607974161\r\n      },\r\n      &quot;type&quot;: &quot;incr&quot;\r\n    },\r\n    {\r\n      &quot;archive&quot;: {\r\n        &quot;start&quot;: &quot;0000000A0000185B000000DD&quot;,\r\n        &quot;stop&quot;: &quot;0000000A0000185B000000F4&quot;\r\n      },\r\n      &quot;backrest&quot;: {\r\n        &quot;format&quot;: 5,\r\n        &quot;version&quot;: &quot;2.28&quot;\r\n      },\r\n      &quot;database&quot;: {\r\n        &quot;id&quot;: 1\r\n      },\r\n      &quot;info&quot;: {\r\n        &quot;delta&quot;: 126982395984,\r\n        &quot;repository&quot;: {\r\n          &quot;delta&quot;: 19541379733,\r\n          &quot;size&quot;: 67993072945\r\n        },\r\n        &quot;size&quot;: 421395153101\r\n      },\r\n      &quot;label&quot;: &quot;20201213-200009F_20201217-200105I&quot;,\r\n      &quot;prior&quot;: &quot;20201213-200009F_20201214-200009I&quot;,\r\n      &quot;reference&quot;: [\r\n        &quot;20201213-200009F&quot;,\r\n        &quot;20201213-200009F_20201214-200009I&quot;\r\n      ],\r\n      &quot;timestamp&quot;: {\r\n        &quot;start&quot;: 1608224465,\r\n        &quot;stop&quot;: 1608233408\r\n      },\r\n      &quot;type&quot;: &quot;incr&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nI tried to complete first part by this command but it says that &quot;number (1607896232) and number (1607896232) cannot be iterated over&quot;\r\n\r\n```jq\r\n.[0] |.backup[] | select(.type==&quot;full&quot;).timestamp.stop|max\r\n```\r\n\r\nI tried sort_by but has no luck. So what am I doing wrong here?",
        "link": "https://stackoverflow.com/questions/65392957/how-to-select-max-value-by-condition-and-then-compare-it-with-others",
        "title": "How to select max value by condition and then compare it with others?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608564713,
                "last_edit_date": 1608564713,
                "creation_date": 1608563487,
                "answer_id": 65395233,
                "question_id": 65395098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can use *hardcoded* index in the `value` array, you can use:\r\n```\r\n.result[] | .value[1]\r\n```\r\n\r\n[Online demo @ jqplay](https://jqplay.org/s/GGLnjplglN)\r\n\r\n&lt;hr&gt;\r\n\r\nOr, as [@vgersh99](https://stackoverflow.com/questions/65395098/how-to-extract-string-from-array-with-jq/65395233?noredirect=1#comment115615452_65395233) and [@ikegami](https://stackoverflow.com/questions/65395098/how-to-extract-string-from-array-with-jq/65395233?noredirect=1#comment115615594_65395233) suggested, using `.value[-1]` to get the **last index**:\r\n```\r\n.result[] | .value[-1]\r\n```\r\n\r\n[Online demo @ jqplay](https://jqplay.org/s/5OkInAV_dk)",
                "title": "How to extract string from array with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608564713,
        "creation_date": 1608562989,
        "question_id": 65395098,
        "body_markdown": "How can I extract the value `&quot;0.9212835072256392&quot;` from the `value` array with jq?  \r\n\r\n    {\r\n      &quot;resultType&quot;: &quot;vector&quot;,\r\n        &quot;result&quot;: [\r\n          {\r\n            &quot;metric&quot;: {},\r\n            &quot;value&quot;: [\r\n              1608561506.684,\r\n              &quot;0.9212835072256392&quot;\r\n            ]\r\n          }\r\n        ]\r\n     }\r\n\r\nI tried different solutions such as `jq &#39;.result.value[1]&#39;`. This gives me the error message `jq: error (at &lt;stdin&gt;:1): Cannot index array with string &quot;value&quot;`.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65395098/how-to-extract-string-from-array-with-jq",
        "title": "How to extract string from array with jq?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608641314,
                "creation_date": 1608641314,
                "answer_id": 65409036,
                "question_id": 65408895,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The first command assigns the JSON to the `activity` variable.\r\n\r\nThe second command, need&#39;s to be altert to &#39;feed&#39; the json through the pipe since in `activityCause=$activity` `$activity` is interpreted as a command, and not the JSON;\r\n\r\n1) Use [bash Here](https://linux.die.net/abs-guide/x15683.html)\r\n    ```\r\n    activityCause=$(jq -r &#39;.Activities[].Cause&#39; &lt;&lt;&lt; &quot;$activity&quot;)\r\n    ```\r\n\r\n2) Use *oldschool* echo:\r\n    ```\r\n    activityCause=$(echo &quot;$activity&quot; | jq -r &#39;.Activities[].Cause&#39;)\r\n    ```\r\n",
                "title": "using jq how do you query from variable which has json"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608647832,
        "creation_date": 1608640714,
        "last_edit_date": 1608647832,
        "question_id": 65408895,
        "body_markdown": "How do a query a variable which has json value using jq. Below the command returs a json assigns to `activity` variable. But from `activity` variable not sure how to query using jq? \r\n\r\n    activity=`aws autoscaling describe-scaling-activities --profile mfa --auto-scaling-group-name cb-citation-needed --max-items 1`\r\n\r\nWhen I try below it the variable activityCause is empty.\r\n\r\n    activityCause=$activity| jq -r &#39;.Activities[].Cause&#39;\r\n\r\nor\r\n\r\n    activityCause=`$activity| jq -r &#39;.Activities[].Cause&#39;` i get error for this one\r\n\r\nHowever when I try to query in one single command it works\r\n\r\n    activityCause=`aws autoscaling describe-scaling-activities --profile mfa --auto-scaling-group-name cb-citation-needed --max-items 1 | jq -r &#39;.Activities[].Cause&#39;`",
        "link": "https://stackoverflow.com/questions/65408895/using-jq-how-do-you-query-from-variable-which-has-json",
        "title": "using jq how do you query from variable which has json"
    },
    {
        "tags": [
            "docker",
            "tags",
            "jq",
            "gcloud"
        ],
        "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": 1608756812,
                "post_id": 65430770,
                "comment_id": 115678861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11455322,
                    "reputation": 101,
                    "user_id": 8396516,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c801bedfe5bb48e6a7d7819e8e64a05f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "jrow",
                    "link": "https://stackoverflow.com/users/8396516/jrow"
                },
                "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": 1608757250,
                "post_id": 65430770,
                "comment_id": 115679032,
                "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": 1608758230,
                "post_id": 65430770,
                "comment_id": 115679361,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608757789,
                "creation_date": 1608757789,
                "answer_id": 65430980,
                "question_id": 65430770,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can do `sort_by` on the length of the strings in the array and reverse the order to keep the longest string first. Remove the `reverse` function to keep the shortest string first\n\n    sort_by(length) | reverse",
                "title": "Sort strings in array by length using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1608758404,
        "creation_date": 1608756504,
        "last_edit_date": 1608758404,
        "question_id": 65430770,
        "body_markdown": "I am grabbing a list of all docker tags from GCP via the gcloud cli\r\n\r\n```\r\ngcloud container images list-tags gcr.io/my_image --format=json | jq -S .[].tags\r\n```\r\n\r\nthe output:\r\n```\r\n[\r\n  &quot;build.160&quot;,\r\n  &quot;ed37ba0ea1f31d62ff48ef817addd30c8be9952c&quot;\r\n]\r\n[\r\n  &quot;5cd7190a96f633cfb8b5fa0f876f147dbe700dad&quot;,\r\n  &quot;build.161&quot;\r\n]\r\n[\r\n  &quot;9a9f030fcf7544565b9ebf8ba37330b649e156ba&quot;,\r\n  &quot;build.159&quot;\r\n]\r\n```\r\n\r\nIs there a way to sort the values to keep consistency? That way it can look like this:\r\n\r\n```\r\n[\r\n  &quot;ed37ba0ea1f31d62ff48ef817addd30c8be9952c&quot;,\r\n  &quot;build.160&quot;\r\n]\r\n[\r\n  &quot;5cd7190a96f633cfb8b5fa0f876f147dbe700dad&quot;,\r\n  &quot;build.161&quot;\r\n]\r\n[\r\n  &quot;9a9f030fcf7544565b9ebf8ba37330b649e156ba&quot;,\r\n  &quot;build.159&quot;\r\n]\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65430770/sort-strings-in-array-by-length-using-jq",
        "title": "Sort strings in array by length using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1608796136,
                "post_id": 65435240,
                "comment_id": 115686889,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1608819185,
                "last_edit_date": 1608819185,
                "creation_date": 1608796515,
                "answer_id": 65435510,
                "question_id": 65435240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apparently what you&#39;re looking for is the `{field}` syntax. You don&#39;t need to resort to *string outputs*.\r\n``` none\r\n{ data: [\r\n    .data.children[].data\r\n    | select(has(&quot;post_type&quot;) and (.post_type | index(&quot;image&quot;)))\r\n    | {id, title} + (.preview.images[].source | {url})\r\n  # or, if images array always contains one element:\r\n  # | {id, title, url: .preview.images[0].source.url}\r\n  ]\r\n}\r\n```",
                "title": "Leveling select fields"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608799097,
                "last_edit_date": 1608799097,
                "creation_date": 1608798146,
                "answer_id": 65435742,
                "question_id": 65435240,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple solution to the main question is:\r\n\r\n```\r\n{data: [.data.children[]\r\n        | .data\r\n        | {id, title, url: .preview.images[0].source.url} ]}\r\n```\r\n(The &quot;post_type&quot; seems to have disappeared, but hopefully if it&#39;s relevant, you will be able to adapt the above as required.  Likewise if `.images[1]` and beyond are relevant.) \r\n\r\n## String Output\r\nIf you want linear output, you should probably consider CSV or TSV, both of which are supported by jq via `@csv` and `@tsv` respectively.",
                "title": "Leveling select fields"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1608819185,
        "creation_date": 1608794779,
        "last_edit_date": 1608803454,
        "question_id": 65435240,
        "body_markdown": "I am fetching a json response of following structure:\r\n\r\n```\r\n{\r\n  &quot;data&quot;: {\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;data&quot;: {\r\n          &quot;id&quot;: &quot;abcdef&quot;,\r\n          &quot;preview&quot;: {\r\n            &quot;images&quot;: [\r\n              {\r\n                &quot;source&quot;: {\r\n                  &quot;url&quot;: &quot;https://example.com/somefiles_1.jpg&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;title&quot;: &quot;Boring Title One&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;data&quot;: {\r\n          &quot;id&quot;: &quot;ghijkl&quot;,\r\n          &quot;preview&quot;: {\r\n            &quot;images&quot;: [\r\n              {\r\n                &quot;source&quot;: {\r\n                  &quot;url&quot;: &quot;https://example.com/somefiles_2.jpg&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;title&quot;: &quot;Boring Title Two&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;data&quot;: {\r\n          &quot;id&quot;: &quot;mnopqr&quot;,\r\n          &quot;preview&quot;: {\r\n            &quot;images&quot;: [\r\n              {\r\n                &quot;source&quot;: {\r\n                  &quot;url&quot;: &quot;https://example.com/somefiles_3.jpg&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;title&quot;: &quot;Boring Title Three&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;data&quot;: {\r\n          &quot;id&quot;: &quot;stuvwx&quot;,\r\n          &quot;preview&quot;: {\r\n            &quot;images&quot;: [\r\n              {\r\n                &quot;source&quot;: {\r\n                  &quot;url&quot;: &quot;https://example.com/somefiles_4.jpg&quot;\r\n                }\r\n              }\r\n            ]\r\n          },\r\n          &quot;title&quot;: &quot;Boring Title Four&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nIdeally I would like to have a shortened json like this:\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;abcdef&quot;,\r\n\t\t\t&quot;title&quot;: &quot;Boring Title One&quot;,\r\n            &quot;url&quot;: &quot;https://example.com/somefiles_1.jpg&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;ghijkl&quot;,\r\n\t\t\t&quot;title&quot;: &quot;Boring Title Two&quot;,\r\n            &quot;url&quot;: &quot;https://example.com/somefiles_2.jpg&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;mnopqr&quot;,\r\n\t\t\t&quot;title&quot;: &quot;Boring Title Three&quot;,\r\n            &quot;url&quot;: &quot;https://example.com/somefiles_3.jpg&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;stuvwx&quot;,\r\n\t\t\t&quot;title&quot;: &quot;Boring Title Four&quot;,\r\n            &quot;url&quot;: &quot;https://example.com/somefiles_4.jpg&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nIf this is not possible I can work with joining those three values into a single string and latter split when necessary; like this:\r\n\r\n```\r\nabcdef@Boring Title One@https://example.com/somefiles_1.jpg\r\nghijkl@Boring Title Two@https://example.com/somefiles_2.jpg\r\nmnopqr@Boring Title Three@https://example.com/somefiles_3.jpg\r\nstuvwx@Boring Title Four@https://example.com/somefiles_4.jpg\r\n```\r\n\r\n\r\nThis is where I am. I was uring the `jq` with `select()` and then pipe the results to `to_entries` like this:\r\n\r\n\r\n```\r\njq -r &#39;.data.children[] | select(.data.post_type|test(&quot;image&quot;)?) | .data | to_entries[] | [ .value.title , .value.preview.images[0].source.url ] | join(&quot;@&quot;)&#39; ~/Documents/json/sample.json\r\n```\r\n\r\n1. I don&#39;t understand what goes after `to_entries[]`; I have tried multiple variations of .key and .values; Mostly I don&#39;t get any result but sometimes I get key pairs I do not intend to select. How to learn the proper syntax for it?\r\n2. Is creating a flat json out of a nested json like this good or is it better to create the string outputs? I feel the string might be error prone especially with the presence of spaces or special characters.",
        "link": "https://stackoverflow.com/questions/65435240/leveling-select-fields",
        "title": "Leveling select fields"
    },
    {
        "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": 1,
                "creation_date": 1608796406,
                "post_id": 65435339,
                "comment_id": 115686950,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5334124,
                    "reputation": 1013,
                    "user_id": 4253785,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Z7RjG.jpg?s=256",
                    "display_name": "Cl&#233;ment Joly",
                    "link": "https://stackoverflow.com/users/4253785/cl%c3%a9ment-joly"
                },
                "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": 1608801580,
                "post_id": 65435339,
                "comment_id": 115688394,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1608795344,
                "creation_date": 1608795344,
                "answer_id": 65435340,
                "question_id": 65435339,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `to_entries`, we can pair indices with values:\r\n```\r\n$ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;to_entries[]&#39;\r\n{\r\n  &quot;key&quot;: 0,\r\n  &quot;value&quot;: &quot;a&quot;\r\n}\r\n{\r\n  &quot;key&quot;: 1,\r\n  &quot;value&quot;: &quot;b&quot;\r\n}\r\n{\r\n  &quot;key&quot;: 2,\r\n  &quot;value&quot;: &quot;c&quot;\r\n}\r\n```\r\n\r\nSo this works:\r\n```\r\necho &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;to_entries[] | select(.value == &quot;a&quot;) | .key&#39;\r\n```",
                "title": "Find index of element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608795344,
        "creation_date": 1608795344,
        "question_id": 65435339,
        "body_markdown": "Given a json array like:\r\n```\r\n[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]\r\n```\r\nI want to get the index of `&quot;b&quot;` (here, this index is 1).\r\n\r\nHow would I proceed using `jq`?",
        "link": "https://stackoverflow.com/questions/65435339/find-index-of-element-with-jq",
        "title": "Find index of element with jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq",
            "bitbucket-api"
        ],
        "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": 1608810363,
                "post_id": 65437796,
                "comment_id": 115691103,
                "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": 1608812865,
                "post_id": 65437796,
                "comment_id": 115691933,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19897045,
                    "reputation": 35,
                    "user_id": 14577944,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f99ca06029ac3252ab6bf0d01e8165a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Hell",
                    "link": "https://stackoverflow.com/users/14577944/hell"
                },
                "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": 1608817759,
                "post_id": 65437796,
                "comment_id": 115693425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608818602,
                "creation_date": 1608818602,
                "answer_id": 65439346,
                "question_id": 65437796,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -r &#39;.values[].slug&#39; repo.json\r\n\r\n-r will remove the quotation marks and so there is no need to pipe through to sed.",
                "title": "Extract a property slug from a json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1608818602,
        "creation_date": 1608809919,
        "last_edit_date": 1608817471,
        "question_id": 65437796,
        "body_markdown": "I would like to extract the names of the repositories and their size after getting the list of all the repositories in bitbucket using API via shell script. The command I&#39;m using for that is\r\n\r\n    repo_list=$(cat repo.json | jq &#39;.[] | .slug &#39; | sed &#39;s/&quot;//g&#39;)\r\n\r\nrepo.json contains:\r\n\r\n    {\r\n    &quot;pagelen&quot;:100,\r\n    &quot;size&quot;:494,\r\n    &quot;values&quot;:[\r\n      {\r\n         &quot;scm&quot;:&quot;git&quot;,\r\n         &quot;website&quot;:&quot;&quot;,\r\n         &quot;fork_policy&quot;:&quot;no_public_forks&quot;,\r\n         &quot;full_name&quot;:&quot;org_name/ecomm-dist-cache&quot;,\r\n         &quot;name&quot;:&quot;ecomm-dist-cache&quot;,\r\n         &quot;language&quot;:&quot;java&quot;,\r\n         &quot;created_on&quot;:&quot;2014-11-18T19:01:25.741787+00:00&quot;,\r\n         &quot;mainbranch&quot;:{\r\n            &quot;type&quot;:&quot;branch&quot;,\r\n            &quot;name&quot;:&quot;master&quot;\r\n         },\r\n         &quot;workspace&quot;:{\r\n            &quot;slug&quot;:&quot;org_name&quot;,\r\n            &quot;type&quot;:&quot;workspace&quot;,\r\n            &quot;name&quot;:&quot;Org Name &quot;,\r\n            &quot;uuid&quot;:&quot;{xxxxxxxxxxxxx}&quot;\r\n         },\r\n         &quot;has_issues&quot;:true,\r\n         &quot;updated_on&quot;:&quot;2018-06-06T22:17:02.947496+00:00&quot;,\r\n         &quot;size&quot;:105095621,\r\n         &quot;type&quot;:&quot;repository&quot;,\r\n         &quot;slug&quot;:&quot;ecomm-dist-cache&quot;,\r\n         &quot;is_private&quot;:true,\r\n         &quot;description&quot;:&quot;Initial Migration of ecomm-dist-cache&quot;\r\n      },\r\n      {\r\n         &quot;scm&quot;:&quot;git&quot;,\r\n         &quot;website&quot;:&quot;&quot;,\r\n         &quot;full_name&quot;:&quot;org_name/mqfte_ecommoutboundtransfertoweddingchannel&quot;,\r\n         &quot;name&quot;:&quot;MQFTE_ECOMMOutboundTransferToWeddingChannel&quot;,\r\n         &quot;language&quot;:&quot;&quot;,\r\n         &quot;mainbranch&quot;:{\r\n            &quot;type&quot;:&quot;branch&quot;,\r\n            &quot;name&quot;:&quot;master&quot;\r\n         },\r\n         &quot;workspace&quot;:{\r\n            &quot;slug&quot;:&quot;org_name&quot;,\r\n            &quot;type&quot;:&quot;workspace&quot;,\r\n            &quot;name&quot;:&quot;Org Name &quot;,\r\n            &quot;uuid&quot;:&quot;{xxxxxxxxxxxxx}&quot;\r\n         },\r\n         &quot;has_issues&quot;:false,\r\n         &quot;size&quot;:99549,\r\n         &quot;type&quot;:&quot;repository&quot;,\r\n         &quot;slug&quot;:&quot;mqfte_ecommoutboundtransfertoweddingchannel&quot;,\r\n         &quot;is_private&quot;:true,\r\n         &quot;description&quot;:&quot;&quot;\r\n      }\r\n    ],\r\n    &quot;page&quot;:1,\r\n    &quot;next&quot;:&quot;https://api.bitbucket.org/2.0/repositories/org_name? pagelen=100&amp;page=2&quot;\r\n    }\r\n\r\nThe error msg I&#39;m getting is \r\n   \r\n    Cannot index number with string &quot;slug&quot;\r\n\r\nExpected result is \r\n\r\n    ecomm-dist-cache\r\n    mqfte_ecommoutboundtransfertoweddingchannel\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65437796/extract-a-property-slug-from-a-json-file",
        "title": "Extract a property slug from a json file"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1608821549,
                "post_id": 65439322,
                "comment_id": 115694680,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608827616,
                "post_id": 65439322,
                "comment_id": 115696628,
                "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": 1608961150,
                "post_id": 65439322,
                "comment_id": 115719334,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1608864016,
                "last_edit_date": 1608864016,
                "creation_date": 1608863466,
                "answer_id": 65444756,
                "question_id": 65439322,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `sort_by/1` on the fields, you&#39;ll have to either normalize the date/time formats or conditionally parse them out using `strptime/1`. It returns an array of the date fields in significant order combine to a single array and sort_by will do the rest.\r\n\r\n```\r\n.data.monitor\r\n  | sort_by([\r\n    (.Date | strptime(&quot;%A %d %B %Y&quot;)),\r\n    (.Time | split(&quot; &quot;)[0] | if contains(&quot;:&quot;) then\r\n      strptime(&quot;%I:%M%p&quot;)\r\n    else\r\n      strptime(&quot;%I%p&quot;)\r\n    end)\r\n  ])\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/iRse0LTSYF)\r\n",
                "title": "How to sort json data by date and time"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608954977,
                "last_edit_date": 1608954977,
                "creation_date": 1608877306,
                "answer_id": 65445765,
                "question_id": 65439322,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```jq\r\ndef mysort:\r\n   map(\r\n      .epoch =\r\n         try (\r\n            [\r\n               ( .Date | split(&quot; &quot;)[0:4] | .[] ),\r\n               ( .Time | split(&quot; &quot;)[0] | if . == &quot;All&quot; then &quot;12am&quot; else . end )\r\n            ] | join(&quot; &quot;) |\r\n            strptime(\r\n               if contains(&quot;:&quot;) then\r\n                  &quot;%A %d %B %Y %I:%M%p&quot;\r\n               else\r\n                  &quot;%A %d %B %Y %I%p&quot;\r\n               end\r\n            ) |\r\n            mktime\r\n         )\r\n         catch -1\r\n   ) |\r\n   sort_by(.epoch) |\r\n   map( del(.epoch) );\r\n\r\n.data[] |= mysort\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/xbw5qGD1vW)\r\n\r\nThis is a variation of @Jeff Mercado&#39;s work. There are five differences:\r\n\r\n* It returns the entire data set instead of just part of it.\r\n* It sorts not just `.data.monitor`, but `.data.negative` and `.data.isolate` as well (if present).\r\n* It handles dates of `$date1 to $date2 inclusive`.\r\n* It handles times of `All day`.\r\n* It uses a [Schwartzian Transform](https://en.wikipedia.org/wiki/Schwartzian_transform) to reduce the number of times a sorting key is generated.\r\n* Bad inputs are tolerated. (They end up first.)\r\n\r\nIn the linked JSON, there are a few malformed entries. The above program tolerates them, but you might want to fix them. The problems can be found using the following command:\r\n\r\n```sh\r\njq -r &#39;\r\n   def check($type; a):\r\n      a | to_entries[] |\r\n      . as $entry |\r\n      (\r\n         try ( .value.Date | split(&quot; &quot;)[0:4] | join(&quot; &quot;) | strptime(&quot;%A %d %B %Y&quot;) | empty )\r\n         catch &quot;.data.\\($type)[\\($entry.key)].Date = \\($entry.value.Date | tojson) |&quot;,\r\n\r\n         try ( .value.Time | split(&quot; &quot;)[0] | if . == &quot;All&quot; then &quot;12am&quot; else . end | strptime(if contains(&quot;:&quot;) then &quot;%I:%M%p&quot; else &quot;%I%p&quot; end) | empty )\r\n         catch &quot;.data.\\($type)[\\($entry.key)].Time = \\($entry.value.Time | tojson) |&quot;\r\n      );\r\n\r\n   .data |\r\n   . as $data |\r\n   keys_unsorted[] | check(.; $data[.])\r\n&#39;\r\n```\r\n\r\nExample output:\r\n\r\n```lang-none\r\n.data.monitor[26].Date = &quot;Sunday&#160;13 December 2020&quot; |             &lt;-- NBSP used\r\n.data.monitor[125].Time = &quot;1.25pm to 2.05pm&quot; |                   &lt;-- Should be 1:25\r\n.data.monitor[127].Time = &quot;Strength and Conditioning Class&quot; |    &lt;-- wut\r\n.data.monitor[130].Date = &quot;Since Monday 23 November&quot; |           &lt;-- Extra &quot;since&quot;\r\n.data.monitor[130].Time = &quot;&quot; |                                   &lt;-- wut\r\n.data.monitor[233].Date = &quot;Sunday 20 December&quot; |                 &lt;-- Missing year\r\n```\r\n[jqplay](https://jqplay.org/s/mrUixqnYs7)\r\n",
                "title": "How to sort json data by date and time"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -6,
        "last_activity_date": 1608954977,
        "creation_date": 1608818474,
        "last_edit_date": 1608857564,
        "question_id": 65439322,
        "body_markdown": "I&#39;d like to take some covid 19 JSON data and sort the results by date and time but the date and time are 2 separate keys. How would I go about using jq tool to do this? The JSON data is at https://data.nsw.gov.au/data/dataset/nsw-covid-19-case-locations/resource/f3a28eed-8c2a-437b-8ac1-2dab3cf760f9 and it looks like this:\r\n\r\n```json\r\n{\r\n  &quot;date&quot;: &quot;2020-12-24&quot;,\r\n  &quot;title&quot;: &quot;Venues&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;monitor&quot;: [\r\n      {\r\n        &quot;Venue&quot;: &quot;Hungry Ghost Caf&#233;&quot;,\r\n        &quot;Address&quot;: &quot;20 Avalon Parade, Avalon, NSW 2107&quot;,\r\n        &quot;Date&quot;: &quot;Sunday 13 December 2020&quot;,\r\n        &quot;Time&quot;: &quot;9:30am to 11am&quot;,\r\n        ...\r\n      },\r\n      {\r\n        &quot;Venue&quot;: &quot;Hungry Ghost Caf&#233;&quot;,\r\n        &quot;Address&quot;: &quot;20 Avalon Parade, Avalon, NSW 2107&quot;,\r\n        &quot;Date&quot;: &quot;Tuesday 15 December 2020&quot;,\r\n        &quot;Time&quot;: &quot;9:30am to 11am&quot;,\r\n        &quot;Alert&quot;: &quot;Monitor for symptoms&quot;,\r\n        ...\r\n      },\r\n      {\r\n        &quot;Venue&quot;: &quot;Woolworths&quot;,\r\n        &quot;Address&quot;: &quot;74 Old Barrenjoey Road, Avalon Beach, NSW 2107&quot;,\r\n        &quot;Date&quot;: &quot;Saturday 12 December 2020&quot;,\r\n        &quot;Time&quot;: &quot;12pm to 12:15pm&quot;,\r\n        ...\r\n      },\r\n      ...\r\n    ]\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/65439322/how-to-sort-json-data-by-date-and-time",
        "title": "How to sort json data by date and time"
    },
    {
        "tags": [
            "json",
            "bash",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1608838286,
                "post_id": 65442426,
                "comment_id": 115699598,
                "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": 1608864107,
                "post_id": 65442426,
                "comment_id": 115703832,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608840143,
                "last_edit_date": 1608840143,
                "creation_date": 1608837891,
                "answer_id": 65442533,
                "question_id": 65442426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ paste data.json values.txt | sed &#39;s/}.*[[:space:]]\\(.*\\)/, &quot;color&quot;: &quot;\\1&quot;}/&#39;\r\n    {&quot;_id&quot;: 1, &quot;content&quot;: &quot;apple&quot;, &quot;color&quot;: &quot;red&quot;}\r\n    {&quot;_id&quot;: 2, &quot;content&quot;: &quot;banana&quot;, &quot;color&quot;: &quot;yellow&quot;}\r\n\r\nor assuming the string being appended doesn&#39;t contain `&amp;`:\r\n\r\n    $ paste data.json values.txt | awk &#39;{sub(/}.*/,&quot;, \\&quot;color\\&quot;: \\&quot;&quot; $NF &quot;\\&quot;}&quot;)}1&#39;\r\n    {&quot;_id&quot;: 1, &quot;content&quot;: &quot;apple&quot;, &quot;color&quot;: &quot;red&quot;}\r\n    {&quot;_id&quot;: 2, &quot;content&quot;: &quot;banana&quot;, &quot;color&quot;: &quot;yellow&quot;}\r\n\r\nor if it can contain `&amp;` then:\r\n\r\n    $ paste data.json values.txt | awk &#39;{col=$NF; sub(/}.*/,&quot;&quot;); print $0 &quot;, \\&quot;color\\&quot;: \\&quot;&quot; col &quot;\\&quot;}&quot;}&#39;\r\n    {&quot;_id&quot;: 1, &quot;content&quot;: &quot;apple&quot;, &quot;color&quot;: &quot;red&quot;}\r\n    {&quot;_id&quot;: 2, &quot;content&quot;: &quot;banana&quot;, &quot;color&quot;: &quot;yellow&quot;}\r\n\r\nThe above also assume that none of your data contains `}`.",
                "title": "How to insert data into JSON line by line?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608840388,
                "last_edit_date": 1608840388,
                "creation_date": 1608840125,
                "answer_id": 65442793,
                "question_id": 65442426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Interlace data with values and stream to JQ, there you can add each pair together.\r\n```\r\n$ paste -d &#39;\\n&#39; data.json values.txt | jq -Rc &#39;fromjson + {color: input}&#39;\r\n{&quot;_id&quot;:1,&quot;content&quot;:&quot;apple&quot;,&quot;color&quot;:&quot;red&quot;}\r\n{&quot;_id&quot;:2,&quot;content&quot;:&quot;banana&quot;,&quot;color&quot;:&quot;yellow&quot;}\r\n```",
                "title": "How to insert data into JSON line by line?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608868973,
                "last_edit_date": 1608868973,
                "creation_date": 1608841281,
                "answer_id": 65442926,
                "question_id": 65442426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple jq-only solution:\r\n```\r\n&lt; values.txt jq -nR --slurpfile json data.json &#39;\r\n  [ $json, [{color: inputs}] ] | transpose | map(add)[]\r\n&#39;\r\n```\r\nDrop the trailing `[]` if you want the result as an array.",
                "title": "How to insert data into JSON line by line?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608864691,
                "creation_date": 1608864691,
                "answer_id": 65444850,
                "question_id": 65442426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An efficient jq-only solution:\r\n```\r\n&lt; data.json jq -n --rawfile values values.txt &#39;\r\n  ($values | split(&quot;\\n&quot;)) as $values\r\n  | foreach inputs as $in (-1; .+1; $in + {color: $values[.] })\r\n```",
                "title": "How to insert data into JSON line by line?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608948757,
                "creation_date": 1608948757,
                "answer_id": 65453185,
                "question_id": 65442426,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This might work for you (GNU parallel):\r\n\r\n    parallel -q echo &#39;{=1s/}//=}, &quot;color&quot;: &quot;{2}&quot;}&#39; :::: jsonFile ::::+ valueFile\r\nEmulate pasting and build the output from the manipulated arguments. \r\n\r\nOr use a couple of sed invocations:\r\n\r\n    sed &#39;R valueFile&#39; jsonFile | sed -E &#39;N;s/}\\n(.*)/, &quot;color&quot;: &quot;\\1&quot;}/&#39; ",
                "title": "How to insert data into JSON line by line?"
            }
        ],
        "is_answered": true,
        "answer_count": 5,
        "score": 0,
        "last_activity_date": 1608948757,
        "creation_date": 1608837112,
        "last_edit_date": 1608899657,
        "question_id": 65442426,
        "body_markdown": "I have a json file `data.json` and a text file `values.txt` with line by line aligned data\r\n\r\ndata.json\r\n```\r\n{&quot;_id&quot;: 1, &quot;content&quot;: &quot;apple&quot;}\r\n{&quot;_id&quot;: 2, &quot;content&quot;: &quot;banana&quot;}\r\n```\r\nvalues.txt \r\n```\r\nred\r\nyellow\r\n```\r\n\r\nMy desired output looks something like follows, where I want to insert a new field `color` into `data.json` into each line with values from `values.txt`.\r\n\r\noutput.json\r\n```\r\n{&quot;_id&quot;: 1, &quot;content&quot;: &quot;apple&quot;, &quot;color&quot;: &quot;red&quot;}\r\n{&quot;_id&quot;: 2, &quot;content&quot;: &quot;banana&quot;, &quot;color&quot;: &quot;yellow&quot;}\r\n```\r\n\r\nWhat would be the fastest and easiest shell tool to do this? \r\n",
        "link": "https://stackoverflow.com/questions/65442426/how-to-insert-data-into-json-line-by-line",
        "title": "How to insert data into JSON line by line?"
    },
    {
        "tags": [
            "json",
            "jq",
            "key-value"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1608911183,
                "creation_date": 1608911183,
                "answer_id": 65449550,
                "question_id": 65449514,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `to_entries` function to get there!\r\n\r\n```\r\njq &#39;to_entries|.[0].value&#39; file.json\r\n```\r\nshould do the trick.\r\n\r\nFrom `jq` doc:\r\n\r\n&gt;  If to_entries is passed  an  object,\r\n       then for each k: v entry in the input, the output array includes {&quot;key&quot;: k, &quot;value&quot;: v}.\r\n\r\nSo after it your json will look like this:\r\n```\r\n[\r\n  {\r\n    &quot;key&quot;: &quot;RandomKey1&quot;,\r\n    &quot;value&quot;: &quot;3.1.44.0&quot;\r\n  },\r\n  {\r\n    &quot;key&quot;: &quot;Common&quot;,\r\n    &quot;value&quot;: {\r\n      &quot;Services&quot;: &quot;3.50.103.0&quot;,\r\n      &quot;Common&quot;: &quot;3.50.103.0&quot;\r\n    }\r\n  }\r\n]\r\n```\r\nwhere you can find the first key and its corresponding value.",
                "title": "Print the first value without knowing the key"
            },
            {
                "up_vote_count": 7,
                "is_accepted": true,
                "score": 7,
                "last_activity_date": 1609039277,
                "last_edit_date": 1609039277,
                "creation_date": 1608911386,
                "answer_id": 65449577,
                "question_id": 65449514,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`first/1`](https://stedolan.github.io/jq/manual/#first,last,nth(n)).\r\n```\r\nfirst(.[])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/f94JD1_f7L)&lt;/sup&gt;\r\n\r\nIf you at least know that the first value is always scalar, then you can discard the rest of the input to avoid exhausting memory and wasting CPU time.\r\n``` shell\r\n$ jq --stream -n &#39;input[1]&#39; file\r\n&quot;3.1.44.0&quot;\r\n```",
                "title": "Print the first value without knowing the key"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1608936217,
                "creation_date": 1608936217,
                "answer_id": 65452348,
                "question_id": 65449514,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I tried the function `keys`\r\n\r\nYou could use the `keys_unsorted` function like so:\r\n```\r\n.[keys_unsorted[0]]\r\n```",
                "title": "Print the first value without knowing the key"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1609044338,
        "creation_date": 1608910918,
        "last_edit_date": 1609044338,
        "question_id": 65449514,
        "body_markdown": "I have a JSON value\r\n\r\n    {\r\n    \t&quot;RandomKey1&quot;: &quot;3.1.44.0&quot;,\r\n    \t&quot;Common&quot;: {\r\n    \t\t&quot;Services&quot;: &quot;3.50.103.0&quot;,\r\n    \t\t&quot;Common&quot;: &quot;3.50.103.0&quot;\r\n    \t}\r\n    }\r\n\r\n\r\nI want to get the value of `RandomKey1`. As you may have guessed, the name of the key changes every time when I load the page, so I need to get the value of the 0th key. It is guaranteed to be at the 0th position \r\n\r\nI was expecting at least some result with this \r\n\r\n    cat result.json | jq -r &#39;.[0]&#39;\r\n\r\nbut instead I get the error \r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index object with number. \r\n\r\nI tried the function `keys` and it is returning the keys as expected. However there is no `values` function otherwise I could have obtained the values and return only the first element \r\n\r\n    cat result.json | jq -r &#39;keys&#39;\r\n\r\nIs there any way to get the 0th value from this string when the key name is unknown ? ",
        "link": "https://stackoverflow.com/questions/65449514/print-the-first-value-without-knowing-the-key",
        "title": "Print the first value without knowing the key"
    },
    {
        "tags": [
            "arrays",
            "json",
            "list",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1608974639,
                "last_edit_date": 1608974639,
                "creation_date": 1608970182,
                "answer_id": 65454612,
                "question_id": 65454482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for [`inputs`](https://stedolan.github.io/jq/manual/#inputs).\r\n\r\nWith **-n**/**--null-input** option on the command line, this program produces the expected output.\r\n```\r\n{\r\n  &quot;ns:inputArticleItemList&quot;: {\r\n    &quot;#namespaces&quot;: {\r\n      &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot;\r\n    },\r\n    &quot;articles&quot;: [\r\n      { \r\n        &quot;articleID&quot;: (inputs | keys_unsorted[]),\r\n        &quot;insertCode&quot;: &quot;62&quot;,\r\n        &quot;calculatePrice&quot;: true,\r\n        &quot;checkAvailability&quot;: true,\r\n        &quot;findExclusions&quot;: true\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/ocsg-asJOc)&lt;/sup&gt;",
                "title": "Create an array out of values extracted from a stream"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1608996812,
                "last_edit_date": 1608996812,
                "creation_date": 1608995282,
                "answer_id": 65457729,
                "question_id": 65454482,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can merge the combine the inputs into an array using slurp mode (`--slurp`/`-s`) and the following program:\r\n\r\n```jq\r\n{\r\n   &quot;ns:inputArticleItemList&quot;: {\r\n      &quot;#namespaces&quot;: {\r\n         &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot;\r\n      },\r\n      articles: [\r\n         {\r\n            &quot;articleID&quot;: ( .[] | keys_unsorted[] ),\r\n            &quot;insertCode&quot;: &quot;62&quot;,\r\n            &quot;calculatePrice&quot;: true,\r\n            &quot;checkAvailability&quot;: true,\r\n            &quot;findExclusions&quot;: true\r\n         }\r\n      ]\r\n   }\r\n}\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/Ip-bO3fqq6)\r\n\r\nUsing slurp mode is functionally equivalent to using `[ inputs ]` as the source of inputs with null input (`--null-input`/`-n`), presenting an alternative solution.\r\n\r\n[jqplay](https://jqplay.org/s/uv5ERjCqNg)\r\n",
                "title": "Create an array out of values extracted from a stream"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1609007018,
        "creation_date": 1608968869,
        "last_edit_date": 1609007018,
        "question_id": 65454482,
        "body_markdown": "I am trying to use jq to formulate request parameters for an xhr.\r\n\r\nThe request must look like this:\r\n\r\n```\r\n{\r\n  &quot;ns:inputArticleItemList&quot;: {\r\n    &quot;#namespaces&quot;: {\r\n      &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot;\r\n    },\r\n    &quot;articles&quot;: [\r\n      {\r\n        &quot;articleID&quot;: &quot;000000000002158654&quot;,\r\n        &quot;insertCode&quot;: &quot;62&quot;,\r\n        &quot;calculatePrice&quot;: true,\r\n        &quot;checkAvailability&quot;: true,\r\n        &quot;findExclusions&quot;: true\r\n      },\r\n      {\r\n        &quot;articleID&quot;: &quot;000000000002147829&quot;,\r\n        &quot;insertCode&quot;: &quot;62&quot;,\r\n        &quot;calculatePrice&quot;: true,\r\n        &quot;checkAvailability&quot;: true,\r\n        &quot;findExclusions&quot;: true\r\n      },\r\n      {\r\n        &quot;articleID&quot;: &quot;000000000002103650&quot;,\r\n        &quot;insertCode&quot;: &quot;62&quot;,\r\n        &quot;calculatePrice&quot;: true,\r\n        &quot;checkAvailability&quot;: true,\r\n        &quot;findExclusions&quot;: true\r\n      },\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nMy JSON to work with comes like this:\r\n```\r\n{\r\n  &quot;2201299&quot;: {\r\n    &quot;title&quot;: &quot;this is the product description for article 2201299&quot;,\r\n    &quot;prop1&quot;: &quot;value1&quot;,\r\n    &quot;prop2&quot;: &quot;value2&quot;,\r\n    &quot;prop3&quot;: &quot;value3&quot;\r\n  }\r\n}\r\n{\r\n  &quot;2240002&quot;: {\r\n    &quot;title&quot;: &quot;this is the product description for article 2240002&quot;,\r\n    &quot;prop1&quot;: &quot;value1&quot;,\r\n    &quot;prop2&quot;: &quot;value2&quot;,\r\n    &quot;prop3&quot;: &quot;value3&quot;\r\n  }\r\n}\r\n```\r\n\r\nSo what I ideally want is the above to be transformed correctly. I see two difficulties here:\r\n 1. the article number is an &quot;unknown&quot; key\r\n 2. the JSON result doesn&#39;t seem to be an array itself?\r\n\r\nbest jq syntax I could come up with is:\r\n\r\n```{ &quot;#namespaces&quot;: { &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot; } } + (keys[]| { articleId: ., insertCode: &quot;62&quot;, calculatePrice: true, checkAvailability: true, findExclusions: true } | { articles: . }) | { &quot;ns:inputArticleItemList&quot;: . }```\r\n\r\nHowever that fails to make a real array from the keys and insert the root/parent elements correctly.\r\n\r\nHere is the result:\r\n\r\n```\r\n{\r\n  &quot;ns:inputArticleItemList&quot;: {\r\n    &quot;#namespaces&quot;: {\r\n      &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot;\r\n    },\r\n    &quot;articles&quot;: {\r\n      &quot;articleId&quot;: &quot;2201299&quot;,\r\n      &quot;insertCode&quot;: &quot;62&quot;,\r\n      &quot;calculatePrice&quot;: true,\r\n      &quot;checkAvailability&quot;: true,\r\n      &quot;findExclusions&quot;: true\r\n    }\r\n  }\r\n}\r\n{\r\n  &quot;ns:inputArticleItemList&quot;: {\r\n    &quot;#namespaces&quot;: {\r\n      &quot;ns&quot;: &quot;http://www.unknown.com/ccp/basit/service/article/api&quot;\r\n    },\r\n    &quot;articles&quot;: {\r\n      &quot;articleId&quot;: &quot;2240002&quot;,\r\n      &quot;insertCode&quot;: &quot;62&quot;,\r\n      &quot;calculatePrice&quot;: true,\r\n      &quot;checkAvailability&quot;: true,\r\n      &quot;findExclusions&quot;: true\r\n    }\r\n  }\r\n}\r\n``` \r\n\r\nHere is the jqplay to fiddle with: https://jqplay.org/s/4rGV-xU05p",
        "link": "https://stackoverflow.com/questions/65454482/create-an-array-out-of-values-extracted-from-a-stream",
        "title": "Create an array out of values extracted from a stream"
    },
    {
        "tags": [
            "json",
            "group-by",
            "aggregate",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1608975539,
                "last_edit_date": 1608975539,
                "creation_date": 1608972250,
                "answer_id": 65454803,
                "question_id": 65454644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just a series of transformation is all is required, starting with `group_by()`\r\n\r\n```shell\r\njq -n &#39;\r\n[ inputs ] | \r\ngroup_by(.author) | \r\nmap\r\n( \r\n  { \r\n    author: .[0].author, \r\n    totalpages: ( map(.pages) | add ), \r\n    books: ( map( { title, year } ) ) \r\n  }\r\n)&#39;\r\n```\r\n\r\n[jqplay - demo][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/TruWjfLSNB",
                "title": "Aggregate five individual objects to desired output using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1609069910,
        "creation_date": 1608970609,
        "last_edit_date": 1609069910,
        "question_id": 65454644,
        "body_markdown": "Iwas able to transform data but not getting the desired output\r\n\r\nfilter (which i tried): \r\n\r\n```none\r\n[inputs | {author , totalpages : .pages , books : [{&quot;title&quot;: .title, &quot;year&quot; : .year }] } ] | sort\r\n```\r\n\r\nInput : \r\n\r\n```json\r\n{&quot;title&quot;:&quot;War of the worlds&quot;,&quot;author&quot;:&quot;H G Wells&quot;,&quot;year&quot;:1896,&quot;pages&quot;:203}\r\n{&quot;title&quot;:&quot;The invisible man&quot;,&quot;author&quot;:&quot;H G Wells&quot;,&quot;year&quot;:1895,&quot;pages&quot;:2136}\r\n{&quot;title&quot;:&quot;The Lost World&quot;,&quot;author&quot;:&quot;A C Doyle&quot;,&quot;year&quot;:1912,&quot;pages&quot;:185}\r\n{&quot;title&quot;:&quot;A Study in Scarlet&quot;,&quot;author&quot;:&quot;A C Doyle&quot;,&quot;year&quot;:1887,&quot;pages&quot;:251}\r\n{&quot;title&quot;:&quot;20,000 leagues under the sea&quot;,&quot;author&quot;:&quot;J Verne&quot;,&quot;year&quot;:1870,&quot;pages&quot;:450}\r\n```\r\n\r\noutput should be:\r\n\r\n```json\r\n{\r\n  &quot;author&quot;: &quot;A C Doyle&quot;,\r\n  &quot;totalpages&quot;: 436,\r\n  &quot;books&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;The Lost World&quot;,\r\n      &quot;year&quot;: 1912\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;A Study in Scarlet&quot;,\r\n      &quot;year&quot;: 1887\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;author&quot;: &quot;H G Wells&quot;,\r\n  &quot;totalpages&quot;: 2339,\r\n  &quot;books&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;War of the worlds&quot;,\r\n      &quot;year&quot;: 1896\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;The invisible man&quot;,\r\n      &quot;year&quot;: 1895\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;author&quot;: &quot;J Verne&quot;,\r\n  &quot;totalpages&quot;: 450,\r\n  &quot;books&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;20,000 leagues under the sea&quot;,\r\n      &quot;year&quot;: 1870\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/65454644/aggregate-five-individual-objects-to-desired-output-using-jq",
        "title": "Aggregate five individual objects to desired output using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1609226136,
                "last_edit_date": 1609226136,
                "creation_date": 1609154144,
                "answer_id": 65476744,
                "question_id": 65476564,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Between square brackets, all products are collected into a single array. String interpolation doesn&#39;t have this effect.\r\n``` none\r\n.[].vs.pool | &quot;\\(.p_id_name), \\(.members[].m_name)&quot;\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/TvedhEd58S)&lt;/sup&gt;\r\n\r\nIf you want to output arrays, you need to create a separate array for each `m_name`.\r\n``` none\r\n.[].vs.pool | [.p_id_name] + (.members[] | [.m_name])\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/2Co9FEqi0h)&lt;/sup&gt;",
                "title": "Pair value with all products of a filter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1609226136,
        "creation_date": 1609153288,
        "last_edit_date": 1609154334,
        "question_id": 65476564,
        "body_markdown": "I&#39;m new to jq and I have a json response from a get request that looks like:\r\n```\r\n[\r\n  {\r\n    &quot;vs&quot;: {\r\n      &quot;name&quot;: &quot;vs_name&quot;,\r\n      &quot;pool&quot;: {\r\n        &quot;p_id_name&quot;: &quot;XYZ&quot;,\r\n        &quot;members&quot;: [\r\n          {\r\n            &quot;m_name&quot;: &quot;XXX1&quot;,\r\n            &quot;id_name&quot;: &quot;YYY1&quot;,\r\n            &quot;address&quot;: &quot;ZZZ1&quot;\r\n          },\r\n          {\r\n            &quot;m_name&quot;: &quot;XXX2&quot;,\r\n            &quot;id_name&quot;: &quot;YYY2&quot;,\r\n            &quot;address&quot;: &quot;ZZZ2&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\nI&#39;m trying to get an output that looks like (repating the `p_id_name` for each `m_name`):\r\n```\r\nXYZ, XXX1\r\nXYZ, XXX2\r\n```\r\nI tried the following but it didn&#39;t work.\r\n```\r\n$ jq &#39;.[].vs.pool|[.members[].m_name,.p_id_name]&#39; file\r\n[\r\n  &quot;XXX1&quot;,\r\n  &quot;XXX2&quot;,\r\n  &quot;XYZ&quot;\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/65476564/pair-value-with-all-products-of-a-filter",
        "title": "Pair value with all products of a filter"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1609226298,
                "last_edit_date": 1609226298,
                "creation_date": 1609187069,
                "answer_id": 65483625,
                "question_id": 65483160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Define a function to merge inputs by path(s) as follows.\r\n```\r\ndef f(p):\r\n  reduce inputs as $in (p |= [.];\r\n    reduce path(p) as $p (.;\r\n      setpath($p; getpath($p) + [$in | getpath($p)])\r\n    )\r\n  );\r\n```\r\nThen you can simply do:\r\n```\r\nf(.stargazers_count)\r\n```\r\n```\r\nf(.stargazers_count, .watchers_count)\r\n```\r\nNote that this updates only selected fields; the rest will remain unchanged.\r\n\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/qIW7O4QeUV)&lt;/sup&gt;  \r\n&lt;sup&gt;[Online demo (multiple paths)](https://jqplay.org/s/z4yW4Qy5O9)&lt;/sup&gt;",
                "title": "Merge only select paths with JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609187216,
                "creation_date": 1609187216,
                "answer_id": 65483658,
                "question_id": 65483160,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It looks like you want to preserve the fields in f2.json (the second file) except for the specified field.  If that&#39;s the case, you could achieve the desired outcome by:\r\n```\r\njq --argfile f1 f1.json &#39;\r\n  .stargazers_count |= [., $f1[&quot;stargazers_count&quot;]]\r\n&#39; f2.json \r\n```\r\nSince --argfile is officially deprecated, you might like to investigate alternative mechanisms for providing f1.json, e.g. using --slurpfile or invoking jq along the lines of: `jq ... f2.json f1.json`\r\n\r\n## Abstraction\r\nIf you want to write a script that expects an argument specifying the field to be aggregated, you could use the following as a guide:\r\n\r\n```\r\njq --argfile f1 f1.json --arg field stargazers_count &#39;\r\n  .[$field] |= [., $f1[$field]]\r\n&#39; f2.json\r\n```",
                "title": "Merge only select paths with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1609610251,
        "creation_date": 1609184517,
        "last_edit_date": 1609610251,
        "question_id": 65483160,
        "body_markdown": "Here, I have two json data. \r\n\r\n```json \r\n{\r\n  &quot;full_name&quot;: &quot;clbr/n64bootloader&quot;,\r\n  &quot;description&quot;: null,\r\n  &quot;html_url&quot;: &quot;https://github.com/clbr/n64bootloader&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-25T16:19:12Z&quot;,\r\n  &quot;language&quot;: &quot;C&quot;,\r\n  &quot;stargazers_count&quot;: 199,\r\n  &quot;watchers_count&quot;: 199,\r\n  &quot;forks_count&quot;: 10, \r\n\t&quot;url&quot;: &quot;https://api.github.com/repos/clbr/n64bootloader&quot;\r\n}\r\n```\r\n\r\n```json\r\n{\r\n  &quot;full_name&quot;: &quot;clbr/n64bootloader&quot;,\r\n  &quot;description&quot;: null,\r\n  &quot;html_url&quot;: &quot;https://github.com/clbr/n64bootloader&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-25T16:19:12Z&quot;,\r\n  &quot;language&quot;: &quot;C&quot;,\r\n  &quot;stargazers_count&quot;: 220,\r\n  &quot;watchers_count&quot;: 220,\r\n  &quot;forks_count&quot;: 10, \r\n\t&quot;url&quot;: &quot;https://api.github.com/repos/clbr/n64bootloader&quot;\r\n}\r\n```\r\n\r\nHere I want to merge some specified key(s) into an array. In this example, I like to merge `stargazers_count`, so the expected json to be resulted is like follows.\r\n\r\n```json\r\n{\r\n  &quot;full_name&quot;: &quot;clbr/n64bootloader&quot;,\r\n  &quot;description&quot;: null,\r\n  &quot;html_url&quot;: &quot;https://github.com/clbr/n64bootloader&quot;,\r\n  &quot;created_at&quot;: &quot;2020-12-25T16:19:12Z&quot;,\r\n  &quot;language&quot;: &quot;C&quot;,\r\n  &quot;stargazers_count&quot;: [199, 220],\r\n  &quot;watchers_count&quot;: 220,\r\n  &quot;forks_count&quot;: 10, \r\n\t&quot;url&quot;: &quot;https://api.github.com/repos/clbr/n64bootloader&quot;\r\n}\r\n```\r\n\r\nHow can I do this using jq? ",
        "link": "https://stackoverflow.com/questions/65483160/merge-only-select-paths-with-jq",
        "title": "Merge only select paths with JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1609330763,
                "last_edit_date": 1609330763,
                "creation_date": 1609238662,
                "answer_id": 65490866,
                "question_id": 65490789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. To retain the original structure, you need to use the [update operator (`|=`)](https://stedolan.github.io/jq/manual/#Update-assignment:|=) instead of pipe. Enclosing the entire expression to the left of it in parentheses is also necessary, otherwise the original input will be invisible to `|=`.\r\n``` none\r\n(.results[].suites[].tests[].context | strings) |= sub(&quot;#&quot;; &quot;%23&quot;)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/KW6vOOMr24)&lt;/sup&gt;",
                "title": "Omitting null values for sub() in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609357353,
                "creation_date": 1609357353,
                "answer_id": 65512694,
                "question_id": 65490789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; change # to %23 in every context value\r\n\r\nYou might wish to consider:\r\n\r\n    walk( if type==&quot;object&quot; and (.context|type)==&quot;string&quot;\r\n          then .context |= gsub(&quot;#&quot;; &quot;%23&quot;)\r\n          else . end )",
                "title": "Omitting null values for sub() in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1609357353,
        "creation_date": 1609238203,
        "last_edit_date": 1609313883,
        "question_id": 65490789,
        "body_markdown": "I&#39;m trying to change `#` to `%23` in every `context` value, but I&#39;m having problem with null values.\r\n\r\nThe shortened JSON is:\r\n``` json\r\n{\r\n  &quot;stats&quot;: {\r\n    &quot;suites&quot;: 1\r\n  },\r\n  &quot;results&quot;: [\r\n    {\r\n      &quot;uuid&quot;: &quot;676-a46b-47a1-a49f-4da4e46c1120&quot;,\r\n      &quot;title&quot;: &quot;&quot;,\r\n      &quot;suites&quot;: [\r\n        {\r\n          &quot;uuid&quot;: &quot;gghjh-56a9-4713-b139-0d5b36bc7fbc&quot;,\r\n          &quot;title&quot;: &quot;Login process&quot;,\r\n          &quot;tests&quot;: [\r\n            {\r\n              &quot;pass&quot;: false,\r\n              &quot;fail&quot;: true,\r\n              &quot;pending&quot;: false,\r\n              &quot;context&quot;: &quot;\\&quot;screenshots/login.spec.js/Login process -- should login #11 (failed).png\\&quot;&quot;\r\n            },\r\n            {\r\n              &quot;pass&quot;: false,\r\n              &quot;fail&quot;: false,\r\n              &quot;pending&quot;: true,\r\n              &quot;context&quot;: null\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd the JQ command I think it&#39;s closest to correct is:\r\n```\r\njq &#39;.results[].suites[].tests[].context | strings | sub(&quot;#&quot;;&quot;%23&quot;)&#39;\r\n```\r\nBut the problem is that I need to get in return full edited file. How could I achieve that?",
        "link": "https://stackoverflow.com/questions/65490789/omitting-null-values-for-sub-in-jq",
        "title": "Omitting null values for sub() in JQ"
    },
    {
        "tags": [
            "bash",
            "curl",
            "conditional-statements",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1609524101,
                "post_id": 65530726,
                "comment_id": 115859764,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609524192,
                "last_edit_date": 1609524192,
                "creation_date": 1609512801,
                "answer_id": 65530727,
                "question_id": 65530726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This works:\r\n\r\n```\r\nresponse=$( curl -Ls -H &#39;Cache-Control: max-age=0&#39; $endpoint )\r\n\r\nif [ -n &quot;$response&quot; ]; then  # nonempty\r\n    echo &quot;Got server response&quot;\r\n\r\n    #&#160;https://stackoverflow.com/questions/46954692/check-if-string-is-a-valid-json-with-jq\r\n    if jq --exit-status type &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt;&quot;$response&quot;; then\r\n        # Parsed JSON successfully and got something other than false/null\r\n        echo &quot;$response&quot; | jq .\r\n        echo &quot;... after $i seconds&quot;\r\n        return 0\r\n    else\r\n        echo &quot;Response is not valid JSON&quot;\r\n        echo &quot;$response&quot;\r\n        return 1\r\n    fi\r\nfi\r\n```",
                "title": "Pipe output through jq ONLY if it is JSON"
            },
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1609540780,
                "last_edit_date": 1609540780,
                "creation_date": 1609518075,
                "answer_id": 65531430,
                "question_id": 65530726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to test the response type before submitting it to `jq`, it is possible if you test the `Content-Type` header from the server&#39;s response.\r\n\r\nSo you want `curl` to send you the full response headers and body with `curl -i`.\r\n\r\nHere is an implementation of it:\r\n\r\n```sh\r\n#!/usr/bin/env sh\r\n\r\nendpoint=&#39;https://worldtimeapi.org/api/timezone/Europe/Paris.json&#39;\r\n\r\n# Headers and body are delimited by an empty line, with CRLF as the line ending.\r\n# See: RFC7230 HTTP/1.1 Message Syntax and Routing / section 3: Message Format\r\n# https://tools.ietf.org/html/rfc7230#section-3\r\ncrlf=&quot;$(printf &#39;\\r\\n_&#39;)&quot; # add trailing _ to prevent trailing newline trim\r\ncrlf=&quot;${crlf%_}&quot; # remove trailing _\r\nhttp_delim=&quot;$crlf$crlf&quot; # RFC7230 section 3\r\n\r\nfull_http_response=&quot;$(curl --silent --include --url &quot;$endpoint&quot;)&quot;\r\nhttp_headers=&quot;${full_http_response%$http_delim*}&quot;\r\nhttp_body=&quot;${full_http_response#*$http_delim}&quot;\r\n\r\ncase $http_headers in\r\n  &#39;HTTP/1.1 200 OK&#39;*&#39;Content-Type: application/json&#39;*)\r\n    # Yes, response body is JSON, so process it with jq.\r\n    jq -n &quot;$http_body&quot;\r\n    ;;\r\nesac\r\n```",
                "title": "Pipe output through jq ONLY if it is JSON"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1609545829,
                "creation_date": 1609545829,
                "answer_id": 65534869,
                "question_id": 65530726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The following works:\r\n&gt; echo $x | jq . 2&gt;/dev/null  || echo $x\r\n\r\nExcept for the use of `echo` here, this is actually a good approach - it has the advantages of both simplicity and efficiency.  It is better than using the -e option naively as the return codes produced by -e are more complex.\r\n\r\nIn other words, there is much to be said for:\r\n\r\n    printf &quot;%s&quot; &quot;$x&quot; | jq . 2&gt; /dev/null || printf &quot;%s\\n&quot; &quot;$x&quot;\r\n\r\n### Efficiency\r\n\r\nThe argument for efficiency is as follows:\r\n\r\n* If $x holds valid JSON, then there is no overhead.\r\n\r\n* If $x is invalid as JSON, jq will quickly fail; in this case also, the overhead of calling jq will almost surely be no worse or not much worse than checking the `Content-Type`. \r\n\r\n### Warning\r\nThe official documentation for the return codes produced by jq when invoked without the `-e` option is not strictly correct, as illustrated by:\r\n\r\n    $ jq empty &lt;&lt;&lt; &#39;foo bat&#39; 2&gt; /dev/null ; echo $?\r\n    4\r\n",
                "title": "Pipe output through jq ONLY if it is JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1609545829,
        "creation_date": 1609512801,
        "last_edit_date": 1609524037,
        "question_id": 65530726,
        "body_markdown": "I have the following BASH code:\r\n\r\n```\r\n    response=$( curl -Ls $endpoint )\r\n    if [ -n &quot;$response&quot; ]; then  # nonempty\r\n        echo &quot;$response&quot;  | jq .\r\n    fi\r\n```\r\n\r\nThe problem is that sometimes the response can be non-empty but not JSON (if it&#39;s not a 200).\r\n\r\nIs it possible to pipe the output through `jq` ONLY if it is valid JSON?\r\n\r\nThe following works:\r\n\r\n```\r\necho $x | jq . 2&gt;/dev/null  || echo $x\r\n```\r\n\r\nTest:\r\n```\r\n&gt; x=&#39;{&quot;foo&quot;:123}&#39;; echo $x | jq . 2&gt;/dev/null || echo &quot;Invalid: $x&quot;\r\n{\r\n  &quot;foo&quot;: 123\r\n}\r\n\r\n&gt; x=&#39;}&#39;; echo $x | jq . 2&gt;/dev/null || echo &quot;Invalid: $x&quot;\r\nInvalid: }\r\n```\r\n\r\nHowever, I don&#39;t feel comfortable with it.",
        "link": "https://stackoverflow.com/questions/65530726/pipe-output-through-jq-only-if-it-is-json",
        "title": "Pipe output through jq ONLY if it is JSON"
    },
    {
        "tags": [
            "arrays",
            "json",
            "sorting",
            "boolean",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1609593814,
                "last_edit_date": 1609593814,
                "creation_date": 1609533879,
                "answer_id": 65533540,
                "question_id": 65533453,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keep the `.peace` array intact for filtering &amp; sorting then break away from it:\r\n\r\n```\r\njq --raw-output &#39;.peace | map(select(.valid).id) | sort[]&#39; &lt;f.json&gt;\r\n                 ^        ^                        ^   ^\r\n                 A        B                        C   D\r\n```\r\n\r\nWhere:\r\n\r\n- A: Keep array intact\r\n- B: map + select = filter &amp; keep `id` only\r\n- C: sort result (which is a list of strings (i.e. ids))\r\n- D: &quot;spread&quot; each item out of the array\r\n- `--raw-output` will output as &quot;text&quot; and not as string, e.g. `Happy` instead of `&quot;Happy&quot;`\r\n\r\njq play fiddle available [here](https://jqplay.org/s/yfu8cs1A1W).\r\n\r\nAcknowledgement: this answer has been vastly improved by @peak suggestion",
                "title": "Filter &amp; sort array of objects then output only one property of each object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1609593814,
        "creation_date": 1609533078,
        "last_edit_date": 1609534539,
        "question_id": 65533453,
        "body_markdown": "I have JSON that dynamically comes to me in the format:\r\n\r\n```\r\n{\r\n\t&quot;world&quot;: 583,\r\n\t&quot;peace&quot;: [\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;Happy&quot;,\r\n\t\t\t&quot;valid&quot;: true,\r\n\t\t\t&quot;version&quot;: &quot;9&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;Old&quot;,\r\n\t\t\t&quot;valid&quot;: false,\r\n\t\t\t&quot;version&quot;: &quot;2020&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;id&quot;: &quot;New&quot;,\r\n\t\t\t&quot;valid&quot;: true,\r\n\t\t\t&quot;version&quot;: &quot;2021&quot;\r\n\t\t},\r\n        {\r\n\t\t\t&quot;id&quot;: &quot;Year&quot;,\r\n\t\t\t&quot;valid&quot;: true,\r\n\t\t\t&quot;version&quot;: &quot;5&quot;\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\nI&#39;m ***brand new*** to [`jq`][1], and I&#39;ve read the tutorial and the manual, and several questions here on Stack Overflow, including:\r\nhttps://stackoverflow.com/questions/30331504/how-to-sort-a-json-file-by-keys-and-values-of-those-keys-in-jq\r\n\r\n\r\nI want to use `jq` to output all id&#39;s that are valid (`&quot;valid&quot;`=true) and have the output sorted by id.\r\n\r\nSo in this example, I would like the output to be:\r\n```\r\nHappy\r\nNew\r\nYear\r\n```\r\n\r\nSo far, I have:  \r\n\r\n`jq &#39;..|.peace[]|select(.valid)|=sort_by(.id)&#39;`\r\n\r\nBut that issues a *`Cannot index string with string &quot;id&quot;`* error.\r\n\r\nHow can I make this work?\r\n\r\nThank you, and Happy New Year!\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/65533453/filter-sort-array-of-objects-then-output-only-one-property-of-each-object",
        "title": "Filter &amp; sort array of objects then output only one property of each object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8710332,
                    "reputation": 4519,
                    "user_id": 6516699,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/yLaE4.jpg?s=256",
                    "display_name": "Naren",
                    "link": "https://stackoverflow.com/users/6516699/naren"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609562010,
                "post_id": 65536023,
                "comment_id": 115866787,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1017978,
                    "reputation": 15810,
                    "user_id": 1029088,
                    "user_type": "registered",
                    "accept_rate": 60,
                    "profile_image": "https://i.sstatic.net/deOKl.jpg?s=256",
                    "display_name": "Bishan",
                    "link": "https://stackoverflow.com/users/1029088/bishan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609562070,
                "post_id": 65536023,
                "comment_id": 115866796,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609562159,
                "creation_date": 1609562159,
                "answer_id": 65536042,
                "question_id": 65536023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`[ .[][] ]` works for your example (go down two levels from the root and put everything found into an array), or perhaps `[ .. | objects ]`, which is insensitive to the depth of the array nesting (but does assume that none of your objects contain sub-objects... it just finds all objects at any depth).",
                "title": "jq - how to select nested objects in a single array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1609569034,
                "last_edit_date": 1609569034,
                "creation_date": 1609564233,
                "answer_id": 65536198,
                "question_id": 65536023,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just use the `flatten` filter. See demo with your data: https://jqplay.org/s/kBxBJLxDKH\r\n\r\nYou can use it in a command like: `jq flatten input_file`.",
                "title": "jq - how to select nested objects in a single array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1609569034,
        "creation_date": 1609561669,
        "question_id": 65536023,
        "body_markdown": "I have a JSON file with multiple objects within multiple arrays, like below\r\n\r\n    [\r\n      [\r\n        {\r\n          &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n          &quot;account&quot;: &quot;12344&quot;,\r\n          &quot;az&quot;: &quot;ca-central-1a&quot;\r\n        },\r\n        {\r\n          &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n          &quot;account&quot;: &quot;12344&quot;,\r\n          &quot;az&quot;: &quot;ca-central-1b&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n          &quot;account&quot;: &quot;12344&quot;,\r\n          &quot;az&quot;: &quot;us-east-1d&quot;\r\n        },\r\n        {\r\n          &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n          &quot;account&quot;: &quot;12344&quot;,\r\n          &quot;az&quot;: &quot;us-east-1d&quot;\r\n        }\r\n      ],\r\n      [\r\n        {\r\n          &quot;instance_id&quot;: &quot;i-35343453453&quot;,\r\n          &quot;account&quot;: &quot;12344&quot;,\r\n          &quot;az&quot;: &quot;eu-central-1a&quot;\r\n        }\r\n      ]\r\n    ]\r\n\r\nI want the output to be a single array with all the nested objects, like below. Using the JSON input above, how do you use jq to produce the following output?\r\n\r\n    [\r\n    {\r\n      &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n      &quot;account&quot;: &quot;12344&quot;,\r\n      &quot;az&quot;: &quot;ca-central-1a&quot;\r\n    },\r\n    {\r\n      &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n      &quot;account&quot;: &quot;12344&quot;,\r\n      &quot;az&quot;: &quot;ca-central-1b&quot;\r\n    },\r\n    {\r\n      &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n      &quot;account&quot;: &quot;12344&quot;,\r\n      &quot;az&quot;: &quot;us-east-1d&quot;\r\n    },\r\n    {\r\n      &quot;instance_id&quot;: &quot;i-35345353453&quot;,\r\n      &quot;account&quot;: &quot;12344&quot;,\r\n      &quot;az&quot;: &quot;us-east-1d&quot;\r\n    },\r\n    {\r\n      &quot;instance_id&quot;: &quot;i-35343453453&quot;,\r\n      &quot;account&quot;: &quot;12344&quot;,\r\n      &quot;az&quot;: &quot;eu-central-1a&quot;\r\n    }\r\n    ]\r\n\r\nHow to get this done in JQ? Thanks in advance.\r\n",
        "link": "https://stackoverflow.com/questions/65536023/jq-how-to-select-nested-objects-in-a-single-array",
        "title": "jq - how to select nested objects in a single array"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609573925,
                "post_id": 65536970,
                "comment_id": 115868300,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1673470276,
                "last_edit_date": 1673470276,
                "creation_date": 1609574200,
                "answer_id": 65537072,
                "question_id": 65536970,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With modern versions of bash, you&#39;d simply use `mapfile` in conjunction with the -c option of jq (as illustrated in several other SO threads, e.g. https://stackoverflow.com/questions/35005893/convert-a-json-array-to-a-bash-array-of-strings)\r\n\r\nWith older versions of bash, you would still use the -c option but would build up the array one item at a time, along the lines of:\r\n\r\n    while read -r line ; do \r\n      ary+=(&quot;$line&quot;)\r\n    done &lt; &lt;(jq -c .......)\r\n\r\n\r\n### Example\r\n```bash\r\n#!/bin/bash\r\nfunction json {\r\n    cat&lt;&lt;EOF\r\n[\r\n  { &quot;key&quot; : &quot;value1&quot; },\r\n  { &quot;key&quot; : &quot;value2&quot; },\r\n  { &quot;key&quot; : &quot;value3&quot; }\r\n]\r\nEOF\r\n}\r\n\r\nwhile read -r line ; do \r\n  ary+=(&quot;$line&quot;)\r\ndone &lt; &lt;(json | jq -c .[])\r\n\r\nprintf &quot;%s\\n&quot; &quot;${ary[@]}&quot;\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n{&quot;key&quot;:&quot;value1&quot;}\r\n{&quot;key&quot;:&quot;value2&quot;}\r\n{&quot;key&quot;:&quot;value3&quot;}\r\n```\r\n```",
                "title": "Bash: JSON Array to Bash Array of Strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1673470276,
        "creation_date": 1609573164,
        "last_edit_date": 1611308081,
        "question_id": 65536970,
        "body_markdown": "I&#39;m having a JSON file groups.json which is having data in below format - \r\n\r\n    [\r\n    { &quot;key&quot; : &quot;value&quot; },\r\n    { &quot;key&quot; : &quot;value&quot; },\r\n    { &quot;key&quot; : &quot;value&quot; }\r\n    ]\r\nI need these key value pairs to a bash array of strings like this - \r\n\r\n    bashArray = [ { &quot;key&quot; : &quot;value&quot; }  { &quot;key&quot; : &quot;value&quot; }  { &quot;key  : &quot;value&quot; } ]\r\n\r\nHow can I achieve this on Bash3.x? \r\n",
        "link": "https://stackoverflow.com/questions/65536970/bash-json-array-to-bash-array-of-strings",
        "title": "Bash: JSON Array to Bash Array of Strings"
    },
    {
        "tags": [
            "polymorphism",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1681039877,
                "last_edit_date": 1681039877,
                "creation_date": 1609598739,
                "answer_id": 65540354,
                "question_id": 65539821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Is there an easier way to replicate a list in jq N times?\r\n\r\nNo, apparently at least in part because the creators of jq felt that operators need not be maximally polymorphic. Consider “Javascript: The Bad Parts.”\r\n\r\nConsider also that with compound types, the uniqueness of “the obvious meaning” is often not assured. For example, in some contexts, one might want or even expect that [1,2]*3 should yield [3,6].",
                "title": "How to replicate a list N times in jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609804342,
                "creation_date": 1609804342,
                "answer_id": 65571407,
                "question_id": 65539821,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The syntax you&#39;re looking for does not exist. Your best bet would be to define a function to repeat the value for a reusable option.\r\n\r\n```\r\ndef repeat($n):\r\n    . as $val | range($n) | $val;\r\n```\r\n\r\nIn your case, to create an array which repeats the contents of another array N times, you could use the above to do this:\r\n\r\n```\r\n[repeat($N)[]]\r\n```\r\n\r\nfor some number `$N`.",
                "title": "How to replicate a list N times in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1681039877,
        "creation_date": 1609595530,
        "last_edit_date": 1609638665,
        "question_id": 65539821,
        "body_markdown": "The syntax `[...]*N` only works for strings and does not work for lists. Also, I haven&#39;t found a built-in in the manual that does this task easily.\r\n\r\nSo I had to do something like\r\n```\r\n[range(N)|...]|add\r\n```\r\n\r\nIs there an easier (or more idiomatic) way to replicate a list in jq N times?",
        "link": "https://stackoverflow.com/questions/65539821/how-to-replicate-a-list-n-times-in-jq",
        "title": "How to replicate a list N times in jq?"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "pipeline"
        ],
        "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": 1609690812,
                "post_id": 65552017,
                "comment_id": 115895800,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15858769,
                    "reputation": 345,
                    "user_id": 11442488,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ef1db78459e8e01e255f44ff40368af4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "florit",
                    "link": "https://stackoverflow.com/users/11442488/florit"
                },
                "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": 1609690997,
                "post_id": 65552017,
                "comment_id": 115895853,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3133303,
                    "reputation": 24922,
                    "user_id": 2650437,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3a8f26b0e42bb2b3e732f6552693452d?s=256&d=identicon&r=PG",
                    "display_name": "Marth",
                    "link": "https://stackoverflow.com/users/2650437/marth"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1609691057,
                "post_id": 65552017,
                "comment_id": 115895870,
                "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": 1609691368,
                "post_id": 65552017,
                "comment_id": 115895989,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 15858769,
                    "reputation": 345,
                    "user_id": 11442488,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ef1db78459e8e01e255f44ff40368af4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "florit",
                    "link": "https://stackoverflow.com/users/11442488/florit"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609692869,
                "post_id": 65552017,
                "comment_id": 115896485,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1609701333,
                "last_edit_date": 1609701333,
                "creation_date": 1609695243,
                "answer_id": 65552879,
                "question_id": 65552017,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Problems with the snippets you posted:\r\n\r\n* Don&#39;t try to generate code in the shell! Use `--arg` (or some other mechanism) to pass values to your program instead.\r\n* Your timestamps are not valid ISO8601 timestamps, much less what `fromdateiso8601` expects.\r\n* `|` has the lowest precedence other than `;`, so&lt;br&gt;\r\n    `.IDLETIME | tonumber &gt; 60` means&lt;br&gt;\r\n    `.IDLETIME | ( tonumber &gt; 60 )` but you want&lt;br&gt;\r\n    `( .IDLETIME | tonumber ) &gt; 60`.\r\n\r\n---\r\n\r\nWe can start with this:\r\n\r\n```sh\r\njq --arg TSCUT &quot;$( date --date=&#39;5 minutes ago&#39; +%s )&quot; &#39;\r\n   group_by(\r\n      .LOGGEDIN == &quot;0&quot; and\r\n      ( .TIMESTAMP | sub(&quot; &quot;; &quot;T&quot;) + &quot;Z&quot; | fromdateiso8601 ) &lt; $TSCUT and\r\n      ( .IDLETIME | tonumber ) &gt; 60 and\r\n      ( .CPULOAD | tonumber ) &lt; 200\r\n   )\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/QMS-dM8LHo)\r\n\r\nThe above segregates the matching records from those that don&#39;t, but we could end up with any of the following:\r\n\r\n* `[ ]`\r\n* `[ [...matches...] ]`\r\n* `[ [...non-matches...] ]`\r\n* `[ [...non-matches...], [...matches...] ]`\r\n\r\nThis isn&#39;t very useful. As such, I propose the following:\r\n\r\n```sh\r\njq --arg TSCUT &quot;$( date --date=&#39;5 minutes ago&#39; +%s )&quot; &#39;\r\n   map(\r\n      ._f = (\r\n         .LOGGEDIN == &quot;0&quot; and\r\n         ( .TIMESTAMP | sub(&quot; &quot;; &quot;T&quot;) + &quot;Z&quot; | fromdateiso8601 ) &lt; $TSCUT and\r\n         ( .IDLETIME | tonumber ) &gt; 60 and\r\n         ( .CPULOAD | tonumber ) &lt; 200\r\n      )\r\n   ) |\r\n   . as $a |\r\n   {\r\n      &quot;matches&quot;:     [ $a[] | select( ._f       ) | del(._f) ],\r\n      &quot;non-matches&quot;: [ $a[] | select( ._f | not ) | del(._f) ]\r\n   }\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/gbRVJJbRy-)\r\n\r\n---\r\n\r\nI assumed that  `&quot;$( ... )&quot;` means the same thing in `zsh` as it does in the POSIX shell. Adjust as needed.\r\n\r\nThanks to @oguz ismail for pointing out `group_by`, even though I retain my original solution.\r\n",
                "title": "jq select filter chain"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1610012811,
        "creation_date": 1609690352,
        "last_edit_date": 1610012811,
        "question_id": 65552017,
        "body_markdown": "I am having the following array of objects that I would like to filter down. Like this:\r\n\r\n    1. LOGGEDIN == 0\r\n    2. Timestamp older than 5 minutes\r\n    3. IDLETIME &gt; 60 &amp;&amp; CPULOAD &lt; 200\r\n\r\nSo for the second filter I’d like not to consider the objects filtered out on the first filter. And for the third filter I’d like not to consider the objects filtered out on the second filter. I tried to get the selection with jq:\r\n\r\n    1. jq &#39;.[] | select(.LOGGEDIN==&quot;0&quot;)&#39;\r\n    2. jq &#39;.[] | select(.TIMESTAMP | fromdateiso8601 &lt; &#39;$FIVEMINAGO&#39;)&#39;\r\n    3. jq &#39;.[] | select(.IDLETIME |tonumber &gt; 60) | select(.CPULOAD |tonumber &lt; 200)&#39;\r\n\r\nI’d like to wrap these up so that I end up with one array of objects, matching the filters and another array of objects, that do not. I’m on a Mac, zsh.\r\n\r\n    [\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL1XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:45:14&quot;,\r\n        &quot;EMAIL&quot;: &quot;email1@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;0&quot;,\r\n        &quot;IDLETIME&quot;: &quot;122&quot;,\r\n        &quot;CPULOAD&quot;: &quot;2&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL2XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:43:29&quot;,\r\n        &quot;EMAIL&quot;: &quot;email2@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;1&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;0&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL3XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:46:37&quot;,\r\n        &quot;EMAIL&quot;: &quot;email1@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;1&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;0&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL4XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:45:23&quot;,\r\n        &quot;EMAIL&quot;: &quot;email3@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;0&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;13&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL5XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:47:02&quot;,\r\n        &quot;EMAIL&quot;: &quot;email2@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;1&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;0&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL6XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:43:42&quot;,\r\n        &quot;EMAIL&quot;: &quot;email3@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;1&quot;,\r\n        &quot;IDLETIME&quot;: &quot;10&quot;,\r\n        &quot;CPULOAD&quot;: &quot;20&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL7XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:43:29&quot;,\r\n        &quot;EMAIL&quot;: &quot;email4@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;1&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;0&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL8XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:46:02&quot;,\r\n        &quot;EMAIL&quot;: &quot;email4@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;0&quot;,\r\n        &quot;IDLETIME&quot;: &quot;0&quot;,\r\n        &quot;CPULOAD&quot;: &quot;0&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;SERIAL&quot;: &quot;XXXSERIAL9XXX&quot;,\r\n        &quot;TIMESTAMP&quot;: &quot;2020-12-17 18:45:23&quot;,\r\n        &quot;EMAIL&quot;: &quot;email1@mydomain.com&quot;,\r\n        &quot;LOGGEDIN&quot;: &quot;0&quot;,\r\n        &quot;IDLETIME&quot;: &quot;443&quot;,\r\n        &quot;CPULOAD&quot;: &quot;666&quot;,\r\n        &quot;BLOCKED&quot;: &quot;0&quot;\r\n      }\r\n    ]",
        "link": "https://stackoverflow.com/questions/65552017/jq-select-filter-chain",
        "title": "jq select filter chain"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609718256,
                "post_id": 65556130,
                "comment_id": 115903611,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1609718381,
                "creation_date": 1609718381,
                "answer_id": 65556190,
                "question_id": 65556130,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can replace your current `jq` command by the following :\r\n\r\n```bash\r\njq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map({email: ., free: 0, used: 0})&#39;\r\n```\r\n\r\nYou can [try it here](https://jqplay.org/s/5nbgJmJGbo).",
                "title": "jq slurp and add key / value pairs"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1609718381,
        "creation_date": 1609717803,
        "question_id": 65556130,
        "body_markdown": "`$DATA` is a long string containing some Email addresses.\r\n\r\n    echo &quot;$DATA&quot; | grep -Eo &quot;\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Za-z]{2,6}\\b&quot; | sort | uniq | jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1]&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      &quot;email1@mydomain.com&quot;,\r\n      &quot;email2@mydomain.com&quot;,\r\n      &quot;email3@mydomain.com&quot;,\r\n      &quot;email4@mydomain.com&quot;\r\n    ]\r\n\r\nDesired Output:\r\n\r\n    [\r\n      {\r\n        &quot;email&quot;: &quot;email1@mydomain.com&quot;,\r\n        &quot;free&quot;: &quot;0&quot;,\r\n        &quot;used&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email2@mydomain.com&quot;,\r\n        &quot;free&quot;: &quot;0&quot;,\r\n        &quot;used&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email3@mydomain.com&quot;,\r\n        &quot;free&quot;: &quot;0&quot;,\r\n        &quot;used&quot;: &quot;0&quot;\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email4@mydomain.com&quot;,\r\n        &quot;free&quot;: &quot;0&quot;,\r\n        &quot;used&quot;: &quot;0&quot;\r\n      }\r\n    ]\r\n\r\nI guess it should be something like `+= {&quot;free&quot;: &quot;0&quot;}`",
        "link": "https://stackoverflow.com/questions/65556130/jq-slurp-and-add-key-value-pairs",
        "title": "jq slurp and add key / value pairs"
    },
    {
        "tags": [
            "jq",
            "aws-cli"
        ],
        "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": 1,
                "creation_date": 1609729153,
                "post_id": 65557159,
                "comment_id": 115905424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 285519,
                    "reputation": 9627,
                    "user_id": 584239,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/be8a9b2e9d87b13606c3b9e75d26e71d?s=256&d=identicon&r=PG",
                    "display_name": "kumar",
                    "link": "https://stackoverflow.com/users/584239/kumar"
                },
                "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": 1609730059,
                "post_id": 65557159,
                "comment_id": 115905581,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1609733761,
                "post_id": 65557159,
                "comment_id": 115906121,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609731560,
                "creation_date": 1609731560,
                "answer_id": 65557410,
                "question_id": 65557159,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`unique` expects an array as input, so you could tweak your query as follows:\r\n\r\n      [.tasks[] | select(.group | contains( &quot;&#39;$serviceName&#39;&quot;)).containerInstanceArn]\r\n      | unique[]\r\n\r\nNote, however, that it would almost surely be better to pass in the value of `$serviceName` using the jq command-line option `--arg`; it might also be worthwhile checking that you really do want to use `contains`, which can easily cause surprises because of its complex semantics.\r\n",
                "title": "How to get unique value from aws cli when used jq query with contains"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1609742474,
        "creation_date": 1609729065,
        "last_edit_date": 1609742474,
        "question_id": 65557159,
        "body_markdown": "When I run the below command I get this \r\n\r\n    aws ecs describe-tasks --cluster $clusterName   --tasks $tasks | jq -r &#39;.tasks[]| select(.group | contains( &quot;&#39;$serviceName&#39;&quot;)).containerInstanceArn&#39;\r\n\r\noutput:\r\n\r\n&gt; arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7\r\n\r\n&gt; arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7\r\n\r\nI tried something like this\r\n\r\n    aws ecs describe-tasks --cluster $clusterName   --tasks $tasks | jq &#39;.tasks[]| select(.group | contains( &quot;&#39;$serviceName&#39;&quot;)).containerInstanceArn&#39;| jq &#39;.| unique&#39;\r\n\r\nbut get error\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): Cannot iterate over string (&quot;arn:aws:ec...)\r\n\r\n&gt; jq: error (at &lt;stdin&gt;:2): Cannot iterate over string (&quot;arn:aws:ec...)\r\n\r\nwhat is the proper way to get unique value when using `select` with `contains` so that only one vaule come out as the output.\r\n\r\n**Updated with json output** \r\n\r\n    {\r\n        &quot;tasks&quot;: [\r\n            {\r\n                &quot;connectivityAt&quot;: &quot;2021-01-04T08:01:14.585000+05:30&quot;,\r\n                &quot;containerInstanceArn&quot;: &quot;arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7&quot;,\r\n                &quot;group&quot;: &quot;service:cb-myservice1-api-dev-ecs-cb-myservice1-api-man-1839134&quot;,\r\n                &quot;version&quot;: 2\r\n            },\r\n            {\r\n                &quot;connectivityAt&quot;: &quot;2020-12-30T16:47:48.408000+05:30&quot;,\r\n                &quot;containerInstanceArn&quot;: &quot;arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/d5d2a0608134533347563d8383e&quot;,\r\n                &quot;group&quot;: &quot;service:cb-myservice2-api-dev-ecs-cb-myservice2-api-man-1816014&quot;,\r\n                &quot;version&quot;: 2\r\n            },\r\n            {\r\n                &quot;connectivityAt&quot;: &quot;2021-01-04T08:02:35.266000+05:30&quot;,\r\n                &quot;containerInstanceArn&quot;: &quot;arn:aws:ecs:us-east-1:123456:container-instance/my-cluster-dev/ed6292913912344553e236d96cc4fdf7&quot;,\r\n                &quot;group&quot;: &quot;service:cb-myservice1-api-staging-ecs-cb-myservice1-api-man-1839116&quot;,\r\n    \r\n                &quot;version&quot;: 2\r\n            }\r\n        ],\r\n        &quot;failures&quot;: []\r\n    }",
        "link": "https://stackoverflow.com/questions/65557159/how-to-get-unique-value-from-aws-cli-when-used-jq-query-with-contains",
        "title": "How to get unique value from aws cli when used jq query with contains"
    },
    {
        "tags": [
            "json",
            "numbers",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609779508,
                "creation_date": 1609779508,
                "answer_id": 65566618,
                "question_id": 65566508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your goal is to subtract 1 from `key1`, but leave all other values the same, that might look like:\r\n\r\n```\r\njq &#39;.[] |= if .key1? != null then .key1 = .key1 - 1 else . end&#39;\r\n```\r\n\r\nYou don&#39;t need `| numbers` anywhere, insofar as in your input, the only values that exist for `key1` are _already_ numeric.",
                "title": "Modify a numeric value only in dicts where it exists (from within a JSON list)"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1609784405,
                "last_edit_date": 1609784405,
                "creation_date": 1609779828,
                "answer_id": 65566699,
                "question_id": 65566508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To check whether a dictionary has a certain key, you can use the [`has(key)`](https://stedolan.github.io/jq/manual/#has(key)) function. From there on, you can use a regular [if-then-else](https://stedolan.github.io/jq/manual/#if-then-else) block to alter the dictionary (subtract 1 from the value associated with `key1`) if the condition is true or leave it unchanged if the condition is not met.\r\n\r\n```\r\njq &#39;.[] |= if has(&quot;key1&quot;) then .key1 = .key1 - 1 else . end &#39;\r\n```\r\n\r\nI also learned something new (for me) from [@Charles Duffy&#39;s answer](https://stackoverflow.com/a/65566618/827519) :\r\n\r\nThe first transformation was [`.[]`](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]) which helped to iterate over all items in the array. There&#39;s a difference here between using [`|=`](https://stedolan.github.io/jq/manual/#Update-assignment:|=) and [`|`](https://stedolan.github.io/jq/manual/#Pipe:|) : using the first one will update the values in the original input, while the second one in this case would unroll the array, and print the individual array elements.\r\n",
                "title": "Modify a numeric value only in dicts where it exists (from within a JSON list)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1609787346,
                "last_edit_date": 1609787346,
                "creation_date": 1609779927,
                "answer_id": 65566729,
                "question_id": 65566508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close. Select numbers before applying the change, not after.\r\n```\r\n(.[].key1 | numbers) -= 1\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/QvVeUpMeZr)&lt;/sup&gt;",
                "title": "Modify a numeric value only in dicts where it exists (from within a JSON list)"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609826369,
                "last_edit_date": 1609826369,
                "creation_date": 1609785168,
                "answer_id": 65567960,
                "question_id": 65566508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to update the value in place, the simplest solution to the immediate problem would probably be:\r\n```\r\n   .[0].key1 += -1\r\n```\r\nor if counting keystrokes is very important in your assessment of simplicity:\r\n```\r\n   .[0].key1 -= 1\r\n```\r\nIf you wanted to output the adjusted values of all numeric `.key1` values, you could go with:\r\n\r\n    .[] | .key1? | numbers - 1\r\n\r\nThe nature of the general problem being asked is unclear from the question, but if for example you wanted to update all occurrences of numeric `key1` values in the top-level objects in the array, you could go with:\r\n\r\n```\r\n.[] |= if (.key1|type) == &quot;number&quot; then .key1 += -1 else . end\r\n```\r\n\r\nThis of course assumes the array items are all objects; if they are not, you could easily adapt the above accordingly.",
                "title": "Modify a numeric value only in dicts where it exists (from within a JSON list)"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1609830304,
        "creation_date": 1609779011,
        "last_edit_date": 1609830304,
        "question_id": 65566508,
        "body_markdown": "Simplified JSON file looks like this:\r\n```\r\n[\r\n  {\r\n    &quot;key1&quot;: 1,\r\n    &quot;key2&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;key3&quot;: &quot;3&quot;,\r\n    &quot;key4&quot;: 4\r\n  }\r\n]\r\n```\r\nI have no problem with reading numeric values from it.\r\n```\r\njq &quot;.[].\\&quot;key1\\&quot; |numbers&quot; jsonfile\r\n1\r\n```\r\nBut I could not figure out how to modify them. This is what I tried:\r\n```\r\njq &quot;.[].\\&quot;key1\\&quot; -1 |numbers&quot; jsonfile\r\n0\r\njq: error (at jsonstr:1): null (null) and number (1) cannot be subtracted\r\n```\r\n`null` is coming from the second item, which causes the error above.\r\n```\r\njq &quot;.[].\\&quot;key1\\&quot;&quot; jsonfile\r\n1\r\nnull\r\n```\r\nThing what I want is\r\n```\r\n[\r\n  {\r\n    &quot;key1&quot;: 0,\r\n    &quot;key2&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;key3&quot;: &quot;3&quot;,\r\n    &quot;key4&quot;: 4\r\n  }\r\n]\r\n```\r\n\r\nHow do I solve this issue? ",
        "link": "https://stackoverflow.com/questions/65566508/modify-a-numeric-value-only-in-dicts-where-it-exists-from-within-a-json-list",
        "title": "Modify a numeric value only in dicts where it exists (from within a JSON list)"
    },
    {
        "tags": [
            "json",
            "bash",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1609838767,
                "post_id": 65576106,
                "comment_id": 115940335,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1609840050,
                "post_id": 65576106,
                "comment_id": 115940893,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20228860,
                    "reputation": 57,
                    "user_id": 14835975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae390cb5007067e88b51c2914872be68?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kiko",
                    "link": "https://stackoverflow.com/users/14835975/kiko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609841027,
                "post_id": 65576106,
                "comment_id": 115941272,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20228860,
                    "reputation": 57,
                    "user_id": 14835975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae390cb5007067e88b51c2914872be68?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kiko",
                    "link": "https://stackoverflow.com/users/14835975/kiko"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609841170,
                "post_id": 65576106,
                "comment_id": 115941332,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1609841657,
                "post_id": 65576106,
                "comment_id": 115941554,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20228860,
                    "reputation": 57,
                    "user_id": 14835975,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ae390cb5007067e88b51c2914872be68?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Kiko",
                    "link": "https://stackoverflow.com/users/14835975/kiko"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1609842337,
                "post_id": 65576106,
                "comment_id": 115941866,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1609842821,
                "creation_date": 1609842821,
                "answer_id": 65577208,
                "question_id": 65576106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way:\r\n\r\n```sh\r\n$&#160;jq -n --argjson oldvals &quot;$(&lt; file1.json)&quot; --argjson newvals &quot;$(&lt; file2.json)&quot; &#39;\r\n   reduce range($oldvals | length) as $idx\r\n     ($oldvals; .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time)&#39;\r\n[\r\n  {\r\n    &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Bar&quot;,\r\n    &quot;Country&quot;: &quot;Brazil&quot;,\r\n    &quot;Age&quot;: &quot;3&quot;\r\n  },\r\n  {\r\n    &quot;Date_and_Time&quot;: &quot;Mar 31, 2018 14:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n    &quot;Id&quot;: &quot;123456&quot;,\r\n    &quot;Car&quot;: &quot;Ferrari&quot;\r\n  }\r\n]\r\n```",
                "title": "Change a value in a json dictionary from another json BASH"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1609843070,
        "creation_date": 1609838441,
        "last_edit_date": 1609843070,
        "question_id": 65576106,
        "body_markdown": "I&#180;ve a JSON data which is a array of dictionaries with the next syntax:\r\n\r\n```\r\n\r\n[ \r\n     {\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 29, 2017 15:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Bar&quot;,\r\n    &quot;Country&quot;: &quot;Brazil&quot;,\r\n    &quot;Age&quot;: &quot;3&quot;\r\n\r\n},\r\n\r\n{\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n\r\n}\r\n\r\n]\r\n\r\n ```\r\n\r\nAnd I&#39;ve another JSON data with similar syntax EXCEPT the field of **Date_and_Time**. \r\n\r\n\r\n```\r\n\r\n[ \r\n{\r\n  &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Age&quot;: &quot;1&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n},\r\n{\r\n    &quot;Date_and_Time&quot;: &quot;Mar 31, 2018 14:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;Germany&quot;,\r\n     &quot;Id&quot;: &quot;2468&quot;,\r\n     &quot;Genre&quot;: &quot;Male&quot;\r\n\r\n}\r\n]\r\n```\r\n\r\nBoth JSON data have the same number of Date_and_Time fields. What I want to do is to rewrite only the value of the first json for the value of the second json for the **Date_and_Time**\r\n\r\nExpected output:\r\n\r\n```\r\n\r\n[ \r\n     {\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Bar&quot;,\r\n    &quot;Country&quot;: &quot;Brazil&quot;,\r\n    &quot;Age&quot;: &quot;3&quot;\r\n\r\n},\r\n\r\n{\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Mar 31, 2018 14:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n\r\n}\r\n\r\n]\r\n\r\n ```\r\n\r\nI&#39;ve thought something like send but I&#39;d have to do each time manually the change and the perfect thing would be to automatize",
        "link": "https://stackoverflow.com/questions/65576106/change-a-value-in-a-json-dictionary-from-another-json-bash",
        "title": "Change a value in a json dictionary from another json BASH"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1609877570,
                "last_edit_date": 1609877570,
                "creation_date": 1609843086,
                "answer_id": 65577263,
                "question_id": 65577049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I figured it out.\r\n\r\n    jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map({email: split(&quot; &quot;)[1], free: split(&quot; &quot;)[0], used: 0})&#39;",
                "title": "jq split string and map"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609878017,
                "creation_date": 1609878017,
                "answer_id": 65585999,
                "question_id": 65577049,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s almost always better to avoid &quot;slurping&quot; when possible, and it would be more efficient to split on spaces just once:\r\n```\r\njq -R &#39;\r\n  [splits(&quot; +&quot;)]\r\n  | {email: .[1],\r\n     free:  (.[0] | tonumber),\r\n     used: 0 }\r\n&#39; input.txt\r\n```",
                "title": "jq split string and map"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1609878017,
        "creation_date": 1609842174,
        "question_id": 65577049,
        "body_markdown": "I got the following string that I would like to convert to a json array.\r\n\r\n       2 email1@myDomain.com\r\n       1 email2@myDomain.com\r\n       3 email3@myDomain.com\r\n\r\nThis is the jq command:\r\n\r\n    jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map({email: ., free: 0, used: 0})&#39;\r\n\r\nOutput:\r\n\r\n    [\r\n      {\r\n        &quot;email&quot;: &quot;   2 email1@myDomain.com&quot;,\r\n        &quot;free&quot;: 0,\r\n        &quot;used&quot;: 0\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;   1 email2@myDomain.com&quot;,\r\n        &quot;free&quot;: 0,\r\n        &quot;used&quot;: 0\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;   3 email3@myDomain.com&quot;,\r\n        &quot;free&quot;: 0,\r\n        &quot;used&quot;: 0\r\n      }\r\n    ]\r\n\r\nDesired Output:\r\n\r\n    [\r\n      {\r\n        &quot;email&quot;: &quot;email1@myDomain.com&quot;,\r\n        &quot;free&quot;: 2,\r\n        &quot;used&quot;: 0\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email2@myDomain.com&quot;,\r\n        &quot;free&quot;: 1,\r\n        &quot;used&quot;: 0\r\n      },\r\n      {\r\n        &quot;email&quot;: &quot;email3@myDomain.com&quot;,\r\n        &quot;free&quot;: 3,\r\n        &quot;used&quot;: 0\r\n      }\r\n    ]\r\n\r\nCan someone help? I need to split the string on the white space, which I know is possible but I don’t know the exact syntax.",
        "link": "https://stackoverflow.com/questions/65577049/jq-split-string-and-map",
        "title": "jq split string and map"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1609865939,
                "creation_date": 1609865939,
                "answer_id": 65583298,
                "question_id": 65582653,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are looking for `group_by`, not `unique`. After concatenating inputs, group resulting array&#39;s elements by `.EMAIL`, and merge members of each group to get the desired outcome.\r\n```\r\njq -s &#39;add | group_by(.EMAIL) | map(add)&#39;\r\n```",
                "title": "Merge array elements on common field in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1609869881,
        "creation_date": 1609863554,
        "last_edit_date": 1609869881,
        "question_id": 65582653,
        "body_markdown": "I have the following two arrays that I would like to reduce / combine. EMAIL should be unique.\r\n\r\nArray 1:\r\n\r\n    [\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email1@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email4@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email7@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email2@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;3&quot;\r\n      }\r\n    ]\r\n\r\nArray 2:\r\n\r\n    [\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email1@myDomain.com&quot;,\r\n        &quot;FREE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email3@myDomain.com&quot;,\r\n        &quot;FREE&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email4@myDomain.com&quot;,\r\n        &quot;FREE&quot;: &quot;2&quot;\r\n      }\r\n    ]\r\n\r\n`jq -s &#39;add&#39;` combines the array. I did some research on `unique` and `reduce` but I can’t get it to work.\r\n\r\nDesired Output:\r\n\r\n    [\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email1@myDomain.com&quot;,\r\n        &quot;FREE&quot;: &quot;1&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email4@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;,\r\n        &quot;FREE&quot;: &quot;2&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email7@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;1&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email2@myDomain.com&quot;,\r\n        &quot;INUSE&quot;: &quot;3&quot;\r\n      },\r\n      {\r\n        &quot;EMAIL&quot;: &quot;email3@myDomain.com&quot;,\r\n        &quot;FREE&quot;: &quot;2&quot;\r\n      }\r\n    ]\r\n\r\nNote that EMAIL values are unique. Can somebody help?",
        "link": "https://stackoverflow.com/questions/65582653/merge-array-elements-on-common-field-in-jq",
        "title": "Merge array elements on common field in JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1609872384,
                "post_id": 65584633,
                "comment_id": 115955904,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 20332707,
                    "reputation": 19,
                    "user_id": 14914298,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-PBYN6eNe6Ds/AAAAAAAAAAI/AAAAAAAAAAA/AMZuucnupC9b7e4KWgqTeaEynYBtTtXpSQ/s96-c/s256-rj/photo.jpg",
                    "display_name": "Serge Bryant",
                    "link": "https://stackoverflow.com/users/14914298/serge-bryant"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609873062,
                "post_id": 65584633,
                "comment_id": 115956171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609873181,
                "post_id": 65584633,
                "comment_id": 115956221,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1609875953,
                "creation_date": 1609875953,
                "answer_id": 65585561,
                "question_id": 65584633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A modification of the earlier answer might work.\r\n\r\n    jq -r &#39;to_entries[] | &quot;\\(.key) = \\&quot;\\(.value)\\&quot;&quot;&#39;\r\n",
                "title": "How can I use jq to remove quotes from key names and remove braces?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609879102,
                "creation_date": 1609879102,
                "answer_id": 65586215,
                "question_id": 65584633,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tfvars specification is hard to come by, but numbers should not be quoted, `null` is a special case, and arrays are also allowed as values, e.g. https://learn.hashicorp.com/tutorials/terraform/google-cloud-platform-variables?in=terraform/gcp-get-started gives the following as an example:\r\n\r\n    cidrs = [ &quot;10.0.0.0/16&quot;, &quot;10.1.0.0/16&quot; ]\r\n\r\nSo the following should be closer to a general solution:\r\n```\r\njq -r &#39;\r\n  def q:\r\n    if type | IN(&quot;string&quot;, &quot;boolean&quot;) then &quot;\\&quot;\\(tostring)\\&quot;&quot; \r\n    else .\r\n    end;\r\n  to_entries[] | &quot;\\(.key) = \\(.value|q)&quot;\r\n&#39;\r\n```",
                "title": "How can I use jq to remove quotes from key names and remove braces?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1609879102,
        "creation_date": 1609871631,
        "question_id": 65584633,
        "body_markdown": "I&#39;m interested in transforming from json format to tfvars using `jq`, i.e.:\r\n\r\nInput:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;aaa&quot;,\r\n  &quot;bar&quot;: &quot;bbb&quot;,\r\n}\r\n```\r\n\r\nDesired output:\r\n```\r\nfoo = &quot;aaa&quot;\r\nbar = &quot;bbb&quot;\r\n```\r\n\r\nI tried\r\n\r\n```\r\necho &quot;{\\&quot;foo\\&quot;: \\&quot;aaa\\&quot;,\\&quot;bar\\&quot;: \\&quot;bbb\\&quot;}&quot; | jq &#39;.[]&#39;\r\n&quot;aaa&quot;\r\n&quot;bbb&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/65584633/how-can-i-use-jq-to-remove-quotes-from-key-names-and-remove-braces",
        "title": "How can I use jq to remove quotes from key names and remove braces?"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1609884943,
                "post_id": 65586855,
                "comment_id": 115960875,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1609930670,
                "creation_date": 1609930670,
                "answer_id": 65594505,
                "question_id": 65586855,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use jq and pipe the output to printf to format the data as required:\r\n\r\n    jq &#39;.fellowId,.srId,&quot;g2gf2f&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.g2gf2f.f2fAmount,&quot;prioritybelongingf2fAmount&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.g2gf2f.f2fAmount,&quot;netPf2f&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.netPf2f.f2fAmount,&quot;bbelongingf2fAmount&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.bbelongingf2fAmount.f2fAmount,&quot;activitybelongingf2fAmount&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.activitybelongingf2fAmount.f2fAmount,&quot;otherbelongingf2fAmount&quot;,.people.educationHistory[].fee7History[0].belongingf2fAmount.otherbelongingf2fAmount.f2fAmount&#39; file | xargs printf &quot;%s\\t| %s\\t| %s\\t\\t\\t| %.1f\\t\\n\\t|\\t\\t\\t| %s\\t| %.1f\\t\\n\\t|\\t\\t\\t| %s\\t\\t\\t| %.1f\\t\\n\\t|\\t\\t\\t| %s\\t\\t| %.1f\\t\\n\\t|\\t\\t\\t| %s\\t| %.1f\\t\\n\\t|\\t\\t\\t| %s\\t| %.1f\\t\\n&quot;\r\n\r\nOutput:\r\n\r\n    101777  | wfakfjaslkf7kev       | g2gf2f                        | 1247.0\r\n            |                       | prioritybelongingf2fAmount    | 1247.0\r\n            |                       | netPf2f                       | 3743.6\r\n            |                       | bbelongingf2fAmount           | 0.0\r\n            |                       | activitybelongingf2fAmount    | 0.0\r\n            |                       | otherbelongingf2fAmount       | 0.0\r\n\r\n\r\n    ",
                "title": "Extract data from Json using Unix"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1609930773,
        "creation_date": 1609882303,
        "last_edit_date": 1609930773,
        "question_id": 65586855,
        "body_markdown": "I want to extract data from the below JSON file:\r\n\r\n    {\r\n      &quot;fellowId&quot;: 101777,\r\n      &quot;srId&quot;: &quot;wfakfjaslkf7kev&quot;,\r\n      &quot;goId&quot;: &quot;x21akjsdfvg&quot;,\r\n      &quot;people&quot;: {\r\n        &quot;Date&quot;: &quot;2020-10-30&quot;,\r\n        &quot;computerID&quot;: {\r\n          &quot;id&quot;: &quot;772&quot;,\r\n          &quot;nameid&quot;: {\r\n            &quot;name&quot;: &quot;student&quot;,\r\n            &quot;code&quot;: &quot;std&quot;\r\n          }\r\n        },\r\n        &quot;Data&quot;: {\r\n          &quot;personName&quot;: {\r\n            &quot;givenName&quot;: &quot;john&quot;,\r\n            &quot;familyName&quot;: &quot;doe&quot;\r\n          },\r\n          &quot;communication&quot;: {\r\n            &quot;telephones&quot;: [{}],\r\n            &quot;emails&quot;: [{\r\n              &quot;emailid&quot;: &quot;john@doe.com&quot;\r\n            }],\r\n            &quot;ia&quot;: []\r\n          },\r\n          &quot;address&quot;: {\r\n            &quot;lineOne&quot;: &quot;124 Marie Drive&quot;,\r\n            &quot;cityName&quot;: &quot;Lake&quot;,\r\n            &quot;sd1&quot;: {\r\n              &quot;name&quot;: &quot;MA&quot;\r\n            },\r\n            &quot;country&quot;: &quot;LA&quot;,\r\n            &quot;postalCode&quot;: &quot;12345&quot;\r\n          }\r\n        },\r\n        &quot;educationHistory&quot;: [{\r\n          &quot;edu&quot;: &quot;st mary high school&quot;,\r\n          &quot;EntityID&quot;: {\r\n            &quot;EntityID&quot;: &quot;3371&quot;,\r\n            &quot;country&quot;: null\r\n          },\r\n          &quot;sAddress&quot;: {\r\n            &quot;lineOne&quot;: &quot;PO Box 4463&quot;,\r\n            &quot;cityName&quot;: &quot;bridge&quot;,\r\n            &quot;sd1&quot;: {\r\n              &quot;name&quot;: &quot;MA&quot;\r\n            },\r\n            &quot;country&quot;: &quot;LA&quot;,\r\n            &quot;postalCode&quot;: &quot;74525&quot;\r\n          },\r\n          &quot;reopenDate&quot;: &quot;2021-09-01&quot;,\r\n          &quot;workerStatusCode&quot;: {\r\n            &quot;name&quot;: &quot;Active&quot;,\r\n            &quot;code&quot;: &quot;A&quot;\r\n          },\r\n          &quot;durationCourse&quot;: {\r\n            &quot;name&quot;: &quot;Full time&quot;,\r\n            &quot;code&quot;: &quot;Full time&quot;\r\n          },\r\n          &quot;schoolStartDate&quot;: &quot;2020-01-07&quot;,\r\n          &quot;Duration&quot;: &quot;O0U4N2D&quot;,\r\n          &quot;Hours&quot;: 166,\r\n          &quot;feeSummary&quot;: [{\r\n            &quot;startyear&quot;: 2020,\r\n            &quot;fee1&quot;: {\r\n              &quot;f2fAmount&quot;: 9168.0,\r\n              &quot;currency&quot;: &quot;rs&quot;\r\n            },\r\n            &quot;activitybelongingf2fAmount&quot;: [{\r\n              &quot;type&quot;: &quot;tution&quot;,\r\n              &quot;rf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;rTypeCode&quot;: &quot;YTD sent&quot;,\r\n              &quot;rf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;rTypeCode&quot;: &quot;YTD Others&quot;,\r\n              &quot;rf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }],\r\n            &quot;totalf2fAmount&quot;: {\r\n              &quot;f2fAmount&quot;: 9168.0,\r\n              &quot;ccode&quot;: &quot;ben&quot;\r\n            },\r\n            &quot;belongingablef2fAmount&quot;: {\r\n              &quot;f2fAmount&quot;: 7487.2,\r\n              &quot;ccode&quot;: &quot;ben&quot;\r\n            }\r\n          }],\r\n          &quot;fee7History&quot;: [{\r\n            &quot;acadamyReedem&quot;: true,\r\n            &quot;qDIndicator&quot;: null,\r\n            &quot;belongingDate&quot;: &quot;2020-10-30&quot;,\r\n            &quot;belongingPeriod&quot;: {\r\n              &quot;startDate&quot;: &quot;2020-10-01&quot;,\r\n              &quot;endDate&quot;: &quot;2020-10-31&quot;\r\n            },\r\n            &quot;belongingf2fAmount&quot;: {\r\n              &quot;g2gf2f&quot;: {\r\n                &quot;f2fAmount&quot;: 1247.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;prioritybelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 1247.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;netPf2f&quot;: {\r\n                &quot;f2fAmount&quot;: 3743.6,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;bbelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;activitybelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;otherbelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            },\r\n            &quot;durationHours&quot;: &quot;166.0&quot;,\r\n            &quot;BaCode&quot;: {\r\n              &quot;name&quot;: &quot;marks&quot;,\r\n              &quot;code&quot;: null\r\n            },\r\n            &quot;bPRate&quot;: {\r\n              &quot;f2fAmount&quot;: 1247.0,\r\n              &quot;ccode&quot;: &quot;ben&quot;\r\n            },\r\n            &quot;CycleCode&quot;: {\r\n              &quot;name&quot;: &quot;yearly&quot;,\r\n              &quot;code&quot;: &quot;M&quot;\r\n            },\r\n            &quot;belongingDistributions&quot;: [{\r\n              &quot;depositf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 3743.6,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;deAccount&quot;: {\r\n                &quot;transportid&quot;: &quot;260&quot;,\r\n                &quot;studNumber&quot;: &quot;1949&quot;,\r\n                &quot;accountTypeCode&quot;: &quot;geography&quot;\r\n              }\r\n            }],\r\n            &quot;donations&quot;: [{\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;secondary donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 852.16,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;house donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 220.56,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;cloths donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;Social donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 284.21,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;medical donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 66.47,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;uuui donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;food donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }]\r\n          }, {\r\n            &quot;acadamyReedem&quot;: false,\r\n            &quot;qDIndicator&quot;: null,\r\n            &quot;belongingDate&quot;: &quot;2020-10-01&quot;,\r\n            &quot;belongingPeriod&quot;: {\r\n              &quot;startDate&quot;: &quot;2020-09-01&quot;,\r\n              &quot;endDate&quot;: &quot;2020-09-30&quot;\r\n            },\r\n            &quot;belongingf2fAmount&quot;: {\r\n              &quot;g2gf2f&quot;: {\r\n                &quot;f2fAmount&quot;: 1247.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;prioritybelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 1247.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;netPf2f&quot;: {\r\n                &quot;f2fAmount&quot;: 3743.6,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;bbelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;activitybelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;otherbelongingf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            },\r\n            &quot;durationHours&quot;: &quot;0.0&quot;,\r\n            &quot;BaCode&quot;: {\r\n              &quot;name&quot;: &quot;marks&quot;,\r\n              &quot;code&quot;: null\r\n            },\r\n            &quot;bPRate&quot;: {\r\n              &quot;f2fAmount&quot;: 1247.0,\r\n              &quot;ccode&quot;: &quot;ben&quot;\r\n            },\r\n            &quot;CycleCode&quot;: {\r\n              &quot;name&quot;: &quot;yearly&quot;,\r\n              &quot;code&quot;: &quot;M&quot;\r\n            },\r\n            &quot;belongingDistributions&quot;: [{\r\n              &quot;depositf2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 3743.6,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              },\r\n              &quot;deAccount&quot;: {\r\n                &quot;transportid&quot;: &quot;260&quot;,\r\n                &quot;studNumber&quot;: &quot;8149&quot;,\r\n                &quot;accountTypeCode&quot;: &quot;geography&quot;\r\n              }\r\n            }],\r\n            &quot;donations&quot;: [{\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;secondary donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 852.16,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;house donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 220.56,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;cloths donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;Social donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 284.21,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;medical donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 66.47,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;uuui donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }, {\r\n              &quot;dCode&quot;: {\r\n                &quot;name&quot;: &quot;food donations&quot;,\r\n                &quot;code&quot;: null\r\n              },\r\n              &quot;donationoff2fAmount&quot;: {\r\n                &quot;f2fAmount&quot;: 0.0,\r\n                &quot;ccode&quot;: &quot;ben&quot;\r\n              }\r\n            }]\r\n          }]\r\n        }],\r\n        &quot;historySummary&quot;: {\r\n          &quot;availableStay&quot;: 1,\r\n          &quot;includedSourceCount&quot;: 1,\r\n          &quot;availableHistoryMonths&quot;: {\r\n            &quot;DataMonthCount&quot;: 1,\r\n            &quot;qDataMCount&quot;: 0\r\n          }\r\n        },\r\n        &quot;ffsaId&quot;: &quot;21567-4565125-451284512-852741963&quot;,\r\n        &quot;stayProvider&quot;: &quot;usssslad&quot;\r\n      }\r\n    }\r\nExpected Output:\r\n\r\n[![][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/OySi5.png\r\n\r\nIn case the image doesn&#39;t open this is how I want the data once delimited in excel sheet (pipe in below output represent the lines in excel sheet ). I have tried with jq query and was able to extract the data but all my objects got extracted in 1st and 2nd column and not in its respective columns. Need the solution in UNIX only. Also, I need to extract data for all columns and not only the mentioned below. The file is going to be dynamic with n number of rows so the solution is expected to be working for all JSON files (of course the headings remain/ columns remain same, data in rows is only dynamic) :\r\n\r\n```\r\nfellowId | srId            |belongingf2fAmount          | f2fAmount\r\n101777   | wfakfjaslkf7kev | g2gf2f                     |1247.0\r\n         |                 | prioritybelongingf2fAmount |1247.0 \r\n         |                 | netPf2f                    |3743.6\r\n         |                 |bbelongingf2fAmount         |0.0\r\n         |                 |activitybelongingf2fAmount  |0.0\r\n         |                 |otherbelongingf2fAmount     |0.0\r\n```",
        "link": "https://stackoverflow.com/questions/65586855/extract-data-from-json-using-unix",
        "title": "Extract data from Json using Unix"
    },
    {
        "tags": [
            "json",
            "path",
            "slice",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1609905079,
                "post_id": 65589348,
                "comment_id": 115965440,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1609906124,
                "last_edit_date": 1609906124,
                "creation_date": 1609904582,
                "answer_id": 65589904,
                "question_id": 65589348,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the first question:\r\n\r\n    reduce paths(. == &quot;b&quot;) as $p ({}; setpath($p; &quot;b&quot;))\r\n\r\nFor the second:\r\n\r\n    reduce paths(. == &quot;b&quot;) as $p (.; delpaths([$p]))\r\n\r\nor even more succinctly:\r\n\r\n    delpaths( [ paths(. == &quot;b&quot;) ] )\r\n\r\n## Furthermore\r\n\r\nThe first question can also be answered without `reduce`, but to get it right generically requires more verbosity, e.g.:\r\n\r\n    delpaths( [ paths( (. !=&quot;b&quot;) and (type|IN(&quot;object&quot;,&quot;array&quot;) | not) ) ] )",
                "title": "select all keys with given value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1609919295,
        "creation_date": 1609899892,
        "last_edit_date": 1609919295,
        "question_id": 65589348,
        "body_markdown": "With `jq`, how do I select all objects, which may be nested, with a desired value?\r\n\r\nFor example, given the following:\r\n```\r\n{\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;c&quot;: {\r\n        &quot;d&quot;: {\r\n            &quot;e&quot;: &quot;f&quot;,\r\n            &quot;z&quot;: &quot;b&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nHow do I filter down to objects whose value is `&quot;b&quot;`?\r\n```\r\n{\r\n    &quot;a&quot;: &quot;b&quot;,\r\n    &quot;c&quot;: {\r\n        &quot;d&quot;: {\r\n            &quot;z&quot;: &quot;b&quot;\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nConversely, how do I select objects whose value is __not__ `&quot;b&quot;`?\r\n\r\n```\r\n{\r\n    &quot;c&quot;: {\r\n        &quot;d&quot;: {\r\n            &quot;e&quot;: &quot;f&quot;\r\n        }\r\n    }\r\n}\r\n\r\n```\r\n\r\n---\r\n\r\nI&#39;ve attempted at the problem by using the `select` and `walk` functions, but could not get exactly what I wanted.",
        "link": "https://stackoverflow.com/questions/65589348/select-all-keys-with-given-value",
        "title": "select all keys with given value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 76141,
                    "reputation": 818994,
                    "user_id": 218196,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4P5DY.jpg?s=256",
                    "display_name": "Felix Kling",
                    "link": "https://stackoverflow.com/users/218196/felix-kling"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1609928210,
                "post_id": 65593818,
                "comment_id": 115971645,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1611799429,
                "last_edit_date": 1611799429,
                "creation_date": 1609928834,
                "answer_id": 65594035,
                "question_id": 65593818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can get something pretty close with this code:\r\n\r\n    cat output.json | jq &quot;{status: .executions[].status}&quot;\r\n\r\nExplanation: `cat output.json | jq &quot;.executions[].status&quot;` would filter all elements of `executions` for the &quot;status&quot; field, and return the values as a list. But you don&#39;t want a list, you want a collection of field/value pairs. You can make that manually by creating an object with `{key: any query that creates a value}`.\r\n\r\nThe output is:\r\n\r\n    {\r\n      &quot;status&quot;: &quot;RUNNING&quot;\r\n    }\r\n    {\r\n      &quot;status&quot;: &quot;RUNNING&quot;\r\n    }\r\n\r\nIf you want to build strings instead (to get almost the exact output you asked for), you can do it by creating a formatted string with your &quot;status: &quot; text, also containing the query that will be interpolated.\r\n\r\n    cat output.json | jq &#39;@text &quot;status: \\(.executions[].status)&quot;&#39;\r\n\r\nThe output is:\r\n\r\n    &quot;status: RUNNING&quot;\r\n    &quot;status: RUNNING&quot;\r\n\r\n",
                "title": "How to separate JSON keys and values in shell using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1611799429,
        "creation_date": 1609927856,
        "last_edit_date": 1609928291,
        "question_id": 65593818,
        "body_markdown": "I have a json output file which contains the following output. I&#39;m trying to get the value for the &quot;status&quot; keys but it did give me answer as `null` all the time using the following command.\r\n\r\n    cat output.json | jq -r &quot;.status&quot;\r\n\r\noutput.json\r\n\r\n    {\r\n      &quot;executions&quot;: [\r\n        {\r\n          &quot;executionArn&quot;: &quot;execution:job-execution:1ddb41e1-0d71-4dde-9cd0-d55119be334d&quot;,\r\n          &quot;stateMachineArn&quot;: &quot;stateMachine:job-execution&quot;,\r\n          &quot;name&quot;: &quot;jjfjnsldfnowef&quot;,\r\n          &quot;status&quot;: &quot;RUNNING&quot;,\r\n          &quot;startDate&quot;: 1609918173.79\r\n        },\r\n        {\r\n          &quot;executionArn&quot;: &quot;execution:job-execution:c07927bc-d871-4996-a58a-f9c89cbd351f&quot;,\r\n          &quot;stateMachineArn&quot;: &quot;stateMachine:job-execution&quot;,\r\n          &quot;name&quot;: &quot;c07927bc-23jjfnjfjs&quot;,\r\n          &quot;status&quot;: &quot;RUNNING&quot;,\r\n          &quot;startDate&quot;: 1609918124.174\r\n        }\r\n      ]\r\n    }\r\n\r\nCan anyone help me to get that expected output below.\r\n\r\n    &quot;status&quot;: &quot;RUNNING&quot;\r\n    &quot;status&quot;: &quot;RUNNING&quot;",
        "link": "https://stackoverflow.com/questions/65593818/how-to-separate-json-keys-and-values-in-shell-using-jq",
        "title": "How to separate JSON keys and values in shell using jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1609934879,
                "post_id": 65595131,
                "comment_id": 115974505,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1609941101,
                "post_id": 65595131,
                "comment_id": 115977232,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 372779,
                    "reputation": 2014,
                    "user_id": 722034,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/035201f02846b5bc4bac5607b34ac77b?s=256&d=identicon&r=PG",
                    "display_name": "Martin Cleaver",
                    "link": "https://stackoverflow.com/users/722034/martin-cleaver"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610039925,
                "post_id": 65595131,
                "comment_id": 116013148,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610016887,
                "creation_date": 1610016887,
                "answer_id": 65611024,
                "question_id": 65595131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[![jqplay website][1]][1]\r\n\r\nUncheck &quot;Raw Input&quot; and you get a proper output.\r\n\r\n\r\n\r\n  [1]: https://i.sstatic.net/WAwHR.png",
                "title": "JQ: Cannot index string with string &quot;result&quot;"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610100162,
                "creation_date": 1610100162,
                "answer_id": 65626927,
                "question_id": 65595131,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you do not seem to have specified how you want to combine the files, it’s difficult to do more than offer the following guidance:\r\n\r\n1. As you guessed, do not use the -s option\r\n\r\n2. Use `inputs` and the -n command-line option, e.g. as follows:\r\n```\r\nreduce inputs as $in (null; . + $in.result.lead)\r\n```",
                "title": "JQ: Cannot index string with string &quot;result&quot;"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1610100162,
        "creation_date": 1609933278,
        "last_edit_date": 1610044434,
        "question_id": 65595131,
        "body_markdown": "So I have many files that follow this structure. Each contains over 500 lines. \r\n\r\nfile1.json:\r\n```json\r\n{&quot;result&quot;: {&quot;lead&quot;: [{&quot;id&quot;: &quot;1234&quot;, &quot;accountID&quot;: null, &quot;ownerID&quot;: &quot;5678&quot;, &quot;companyName&quot;: &quot;Hello&quot;, &quot;title&quot;: &quot;Manager&quot;, &quot;firstName&quot;: &quot;Nick&quot;, &quot;lastName&quot;: &quot;Name&quot;, &quot;street&quot;: null, &quot;city&quot;: &quot;Somewhere&quot;, &quot;country&quot;: &quot;Canada&quot;, &quot;state&quot;: null, &quot;zipcode&quot;: null, &quot;emailAddress&quot;: &quot;someone@somewhere.com&quot;, &quot;website&quot;: &quot;somewhere.com&quot;, &quot;phoneNumber&quot;: &quot;&quot;, &quot;officePhoneNumber&quot;: null, &quot;phoneNumberExtension&quot;: null, &quot;mobilePhoneNumber&quot;: &quot;&quot;, &quot;faxNumber&quot;: null, &quot;description&quot;: &quot;Website&quot;, &quot;campaignID&quot;: &quot;12345678&quot;, &quot;trackingID&quot;: null, &quot;industry&quot;: null, &quot;active&quot;: &quot;1&quot;, &quot;isQualified&quot;: &quot;1&quot;, &quot;isContact&quot;: &quot;1&quot;, &quot;isCustomer&quot;: &quot;0&quot;, &quot;status&quot;: &quot;3&quot;, &quot;updateTimestamp&quot;: &quot;2020-11-06 09:44:04&quot;, &quot;createTimestamp&quot;: &quot;2018-07-17 15:59:42&quot;, &quot;leadScoreWeighted&quot;: &quot;6&quot;, &quot;leadScore&quot;: &quot;15&quot;, &quot;isUnsubscribed&quot;: &quot;1&quot;, &quot;leadStatus&quot;: &quot;contactWithOpp&quot;, &quot;persona&quot;: &quot;&quot;}]}}\r\n```\r\n\r\nfile2.json\r\n```json\r\n{&quot;result&quot;: {&quot;lead&quot;: [{&quot;id&quot;: &quot;2234&quot;, &quot;accountID&quot;: null, &quot;ownerID&quot;: &quot;5678&quot;, &quot;companyName&quot;: &quot;Hello&quot;, &quot;title&quot;: &quot;Manager&quot;, &quot;firstName&quot;: &quot;Martin&quot;, &quot;lastName&quot;: &quot;Name&quot;, &quot;street&quot;: null, &quot;city&quot;: &quot;Somewhere&quot;, &quot;country&quot;: &quot;Canada&quot;, &quot;state&quot;: null, &quot;zipcode&quot;: null, &quot;emailAddress&quot;: &quot;someone@somewhere.com&quot;, &quot;website&quot;: &quot;somewhere.com&quot;, &quot;phoneNumber&quot;: &quot;&quot;, &quot;officePhoneNumber&quot;: null, &quot;phoneNumberExtension&quot;: null, &quot;mobilePhoneNumber&quot;: &quot;&quot;, &quot;faxNumber&quot;: null, &quot;description&quot;: &quot;Website&quot;, &quot;campaignID&quot;: &quot;12345678&quot;, &quot;trackingID&quot;: null, &quot;industry&quot;: null, &quot;active&quot;: &quot;1&quot;, &quot;isQualified&quot;: &quot;1&quot;, &quot;isContact&quot;: &quot;1&quot;, &quot;isCustomer&quot;: &quot;0&quot;, &quot;status&quot;: &quot;3&quot;, &quot;updateTimestamp&quot;: &quot;2020-11-06 09:44:04&quot;, &quot;createTimestamp&quot;: &quot;2018-07-17 15:59:42&quot;, &quot;leadScoreWeighted&quot;: &quot;6&quot;, &quot;leadScore&quot;: &quot;15&quot;, &quot;isUnsubscribed&quot;: &quot;1&quot;, &quot;leadStatus&quot;: &quot;contactWithOpp&quot;, &quot;persona&quot;: &quot;&quot;}]}}\r\n\r\n```\r\n\r\nInitial JQ:\r\n```jq\r\n.result.lead[].id\r\n```\r\n\r\nThey start:\r\n\r\n    {\r\n      &quot;result&quot;: {\r\n        &quot;lead&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;1234&quot;, \r\n\r\nEach contains an un-named object, containing the result object, containing an array named lead, containing objects.\r\n\r\nI want to combine and process together the multiple files into one. I can consume  various structures (e.g. a different json) or formats (e.g. CSV) as the output, but ideally I&#39;d end up with a one output file.\r\n\r\nJQ and JQPlay says:\r\n```none\r\njq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;result&quot;\r\nexit status 5\r\n```\r\n\r\nI&#39;m sure my error is simple but I can&#39;t see it!\r\n\r\nThanks\r\n\r\nEdit:\r\n\r\n    jq -f do-001-flatten-leads.jq  leads1.json\r\n\r\nThis works. \r\n\r\nBut to process together everything (assuming I&#39;m supposed to slurp):\r\n\r\n    jq -f do-001-flatten-leads.jq -s leads1.json leads2.json\r\n\r\nShows the error messsage &quot;Cannot index string with string &quot;result&quot;\r\n\r\nEDIT: In my prior example (https://jqplay.org/s/Y_UclBq1xa), I wrongly selected &quot;raw&quot; in JQ. I want to select &quot;slurpfiles&quot; but that is not an option.\r\n\r\nIn https://jqplay.org/s/X5XAfDsuV7 I have added two entries assuming that behaves consistently with slurpfiles.  \r\n\r\nFrom https://stackoverflow.com/questions/34778425/memory-usage-of-jqs-slurp-option I&#39;m coming to believe that I ought to avoid slurping, in favour of using multiple inputs. I&#39;m not doing anything that summarizes, only really selecting columns and maybe format so some sort of streaming seems preferable.",
        "link": "https://stackoverflow.com/questions/65595131/jq-cannot-index-string-with-string-result",
        "title": "JQ: Cannot index string with string &quot;result&quot;"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 476555,
                    "reputation": 47257,
                    "user_id": 887539,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/5baef9617bdee6db2f534c118bcbccee?s=256&d=identicon&r=PG",
                    "display_name": "Andreas Louv",
                    "link": "https://stackoverflow.com/users/887539/andreas-louv"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1610029942,
                "post_id": 65614234,
                "comment_id": 116008179,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610086554,
                "last_edit_date": 1610086554,
                "creation_date": 1610030164,
                "answer_id": 65614375,
                "question_id": 65614234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are trying to invoke `myfile.js` as a command. You need this:\r\n\r\n    output=$(cat myfile.js)\r\n\r\ninstead of this:\r\n\r\n    output=$(myfile.js)\r\n\r\nBut even then, your current approach isn&#39;t going to work well if the data has whitespace in it (which it does, based on the sample you posted). I suggest the following alternative:\r\n\r\n    jq -c &#39;.[]&#39; &lt; myfile.js |\r\n    while read -r row\r\n    do\r\n      echo &quot;$row&quot;\r\n    done\r\n\r\nOutput:\r\n\r\n    {&quot;id&quot;:1,&quot;name&quot;:&quot;blah blah&quot;}\r\n    {&quot;id&quot;:2,&quot;name&quot;:&quot;xxx&quot;}\r\n\r\n**Edit:**\r\nIf your data is arising from a previous process invocation, such as `mongo` in your case, you can pipe it directly to `jq` (to remain portable), like this:\r\n\r\n    mongo myfile.js |\r\n    jq -c &#39;.[]&#39; |\r\n    while read -r row\r\n    do\r\n      echo &quot;$row&quot;\r\n    done",
                "title": "How to Iterate over an array of objets using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610090503,
                "last_edit_date": 1610090503,
                "creation_date": 1610048261,
                "answer_id": 65618868,
                "question_id": 65614234,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How can I make jq -c &#39;.[]&#39; &lt; (mongo myfile.js) work? \r\n\r\nIn a bash shell, you would write an expression along the following lines:\r\n\r\n    while read -r line ; do .... done &lt; &lt;(mongo myfile.js | jq -c .[])\r\n\r\nNote that there are two occurrences of &quot;&lt;&quot; in the above expression.\r\n\r\nAlso, the above assumes `mongo` is emitting valid JSON.  If it emits `//`-style comments, those would have somehow to be removed.\r\n\r\n## Comparison with piping into `while`\r\n\r\nIf you use the idiom:\r\n\r\n    ... | while read -r line ; do .... done\r\n\r\nthen the bindings of any variables in `....` will be lost.",
                "title": "How to Iterate over an array of objets using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1610090503,
        "creation_date": 1610029658,
        "last_edit_date": 1610030246,
        "question_id": 65614234,
        "body_markdown": "I have a javascript file which prints a JSON array of objects:\r\n\r\n```json\r\n// myfile.js output\r\n[\r\n  { &quot;id&quot;: 1, &quot;name&quot;: &quot;blah blah&quot;, ... },\r\n  { &quot;id&quot;: 2, &quot;name&quot;: &quot;xxx&quot;, ... },\r\n  ...\r\n]\r\n```\r\n\r\nIn my bash script, I want to iterate through each object.\r\n\r\nI&#39;ve tried following, but it doesn&#39;t work.\r\n```bash\r\n#!/bin/bash\r\n\r\noutput=$(myfile.js)\r\nfor row in $(echo ${output} | jq -c &#39;.[]&#39;); do\r\n  echo $row\r\ndone\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/65614234/how-to-iterate-over-an-array-of-objets-using-jq",
        "title": "How to Iterate over an array of objets using jq"
    },
    {
        "tags": [
            "json",
            "azure-devops",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610055243,
                "creation_date": 1610055243,
                "answer_id": 65620246,
                "question_id": 65619479,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your sample, the invocation:\r\n```\r\njq -r &#39;\r\n  .variables\r\n  | [to_entries[]\r\n     | &quot;\\(.key)=\\&quot;\\(.value.value|tostring)\\&quot;&quot;]\r\n  | &quot;--variables &quot; + join(&quot; &quot;)\r\n&#39; sample.json\r\n```\r\nproduces:\r\n\r\n```\r\n--variables app_container_environment=&quot;dev&quot; aws_region=&quot;us-west-2&quot;\r\n```",
                "title": "How Can I Create a Space-Delimited String from JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610055243,
        "creation_date": 1610051349,
        "last_edit_date": 1610051804,
        "question_id": 65619479,
        "body_markdown": "I am doing some work with **Azure Devops (ADO)** Variable Groups and I would like to query an existing Variable Group to get all its variables to build a list of parameters to send to ADO CLI method.\r\n\r\nHere is the JSON representation of an existing Variable Group:\r\n\r\n```\r\n\r\n{\r\n  &quot;authorized&quot;: true,\r\n  &quot;description&quot;: &quot;test&quot;,\r\n  &quot;name&quot;: &quot;TESTGROUP&quot;,\r\n  &quot;providerData&quot;: null,\r\n  &quot;type&quot;: &quot;Vsts&quot;,\r\n  &quot;variables&quot;: {\r\n    &quot;app_container_environment&quot;: {\r\n      &quot;value&quot;: &quot;dev&quot;\r\n    },\r\n    &quot;aws_region&quot;: {\r\n      &quot;value&quot;: &quot;us-west-2&quot;\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\n**Problem:**\r\nWhat I&#39;d like to do is use **jq** to read each variable definition and extract the variable name and value. Then, I&#39;d build a string prefixed by &quot;**--variables**&quot; followed by a list of all the key/value pairs,  space-delimited as follows:\r\n\r\n**--variables app_container_environment=&quot;dev&quot; aws_region=&quot;us-west-2&quot;**\r\n\r\nNote that the list begins with &quot;**--variables**&quot; followed by a key/value pair delimited by a space between each key/value pair.\r\n\r\nI have tried to use **join** which is kind of close.  But the main problem I&#39;m having is due to the way the JSON is structured. I&#39;m not sure how to refer to the variable name.  The value element is easy to get, but I can&#39;t seem to get it&#39;s parent(e.g. the variable name).  For example, &quot;**us-west-2**&quot; value&#39;s variable name is &quot;**aws_region**&quot;.\r\n\r\nHow would I do this?",
        "link": "https://stackoverflow.com/questions/65619479/how-can-i-create-a-space-delimited-string-from-json",
        "title": "How Can I Create a Space-Delimited String from JSON?"
    },
    {
        "tags": [
            "jq",
            "gitlab-omnibus"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610092922,
                "post_id": 65625174,
                "comment_id": 116027776,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610092536,
                "creation_date": 1610092536,
                "answer_id": 65625235,
                "question_id": 65625174,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `empty` instead of `&quot;&quot;` to solve the problem, but using `select()` to filter out unwanted stream elements is a cleaner solution.\r\n\r\n```sh\r\njq --unbuffered &#39;\r\n   select(\r\n      .remote_ip != null and\r\n      .method == &quot;POST&quot; and\r\n      .path == &quot;/users/sign_in&quot; and\r\n      .action == &quot;create&quot;\r\n   ) |\r\n   .ua + &quot; &quot; + .remote_ip\r\n&#39;\r\n```",
                "title": "Filtering out login logs from Gitlab production_json.log with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1610092536,
        "creation_date": 1610092148,
        "last_edit_date": 1610092430,
        "question_id": 65625174,
        "body_markdown": "I&#39;m trying to filter out login events from the `production_json.log` of a Omnibus GitLab server.\r\n\r\nThus JSON elements that i want to filter look like this:\r\n\r\n    {\r\n      &quot;method&quot;: &quot;POST&quot;,\r\n      &quot;path&quot;: &quot;/users/sign_in&quot;,\r\n      &quot;format&quot;: &quot;html&quot;,\r\n      &quot;controller&quot;: &quot;SessionsController&quot;,\r\n      &quot;action&quot;: &quot;create&quot;,\r\n      &quot;status&quot;: 302,\r\n      &quot;duration&quot;: 146.22,\r\n      &quot;view&quot;: 0,\r\n      &quot;db&quot;: 16.64,\r\n      &quot;location&quot;: &quot;https://maschm.ddnss.de/&quot;,\r\n      &quot;time&quot;: &quot;2021-01-05T11:44:30.180Z&quot;,\r\n      &quot;params&quot;: [\r\n        {\r\n          &quot;key&quot;: &quot;utf8&quot;,\r\n          &quot;value&quot;: &quot;✓&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;authenticity_token&quot;,\r\n          &quot;value&quot;: &quot;[FILTERED]&quot;\r\n        },\r\n        {\r\n          &quot;key&quot;: &quot;user&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;login&quot;: &quot;root&quot;,\r\n            &quot;password&quot;: &quot;[FILTERED]&quot;,\r\n            &quot;remember_me&quot;: &quot;0&quot;\r\n          }\r\n        }\r\n      ],\r\n      &quot;remote_ip&quot;: &quot;46.86.21.18&quot;,\r\n      &quot;user_id&quot;: 1,\r\n      &quot;username&quot;: &quot;root&quot;,\r\n      &quot;ua&quot;: &quot;Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15&quot;,\r\n      &quot;queue_duration&quot;: 7.3,\r\n      &quot;correlation_id&quot;: &quot;JtnY93e2ti8&quot;\r\n    }\r\n\r\nI only want output for such elements.\r\n\r\n`jq` is new to me. I&#39;m using this command now:\r\n\r\n    sudo tail -f /var/log/gitlab/gitlab-rails/production_json.log | \r\n    jq --unbuffered &#39;\r\n       if .remote_ip != null and .method == &quot;POST&quot; and\r\n          .path == &quot;/users/sign_in&quot; and .action == &quot;create&quot;\r\n       then\r\n          .ua + &quot; &quot; + .remote_ip else &quot;&quot;\r\n       end\r\n    &#39;\r\n\r\nThe output looks like this:\r\n\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/14.0.2 Safari/605.1.15 46.86.21.18&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n    &quot;&quot;\r\n\r\nI have two questions: \r\n\r\n1. How can i avoid the `&quot;&quot;` output (there should be no output for other JSON elements)?\r\n2. Is `if` the correct `jq` statement for filtering?   ",
        "link": "https://stackoverflow.com/questions/65625174/filtering-out-login-logs-from-gitlab-production-json-log-with-jq",
        "title": "Filtering out login logs from Gitlab production_json.log with jq"
    },
    {
        "tags": [
            "javascript",
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8926262,
                    "reputation": 9077,
                    "user_id": 6660638,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/pd7Py.png?s=256",
                    "display_name": "Epsi95",
                    "link": "https://stackoverflow.com/users/6660638/epsi95"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1610111038,
                "post_id": 65629369,
                "comment_id": 116035329,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610112709,
                "post_id": 65629369,
                "comment_id": 116036164,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610135169,
                "post_id": 65629369,
                "comment_id": 116046354,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610135431,
                "post_id": 65629369,
                "comment_id": 116046440,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610111719,
                "creation_date": 1610111719,
                "answer_id": 65629708,
                "question_id": 65629369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "supposed You&#180;ve already have the data into those arrays json1, json2 and will build json3\r\n\r\n    const json3 = json1.map( \r\n        ( element, index) =&gt; { \r\n              const newData =  json2[index]\r\n              return { \r\n               ...element , \r\n               &quot;Date_and_Time&quot; : newData[&quot;Date_and_Time&quot;] ,\r\n               } \r\n              }\r\n         )\r\n\r\nGive it a look [here][1] \r\n\r\n\r\n  [1]: https://repl.it/join/ycgdafnn-bokomoko",
                "title": "Modify a value comparing two json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610112213,
                "creation_date": 1610112213,
                "answer_id": 65629839,
                "question_id": 65629369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A python version, that also loads and writes files\r\n\r\n    import json\r\n    \r\n    file1 = json.loads(open(&quot;file1.json&quot;).read())\r\n    file2 = json.loads(open(&quot;file2.json&quot;).read())\r\n    \r\n    def change_field(a,b,f):\r\n      a[f]=b[f]\r\n      return a\r\n    \r\n    file3 = list(map(lambda x: change_field(x[1],file2[x[0]],&quot;Date_and_Time&quot;), enumerate(file1)))\r\n    \r\n    with open(&quot;file3.json&quot;,&quot;wt&quot;) as f:\r\n      f.write(json.dumps(file3, indent=4))\r\n\r\n",
                "title": "Modify a value comparing two json"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610131874,
                "creation_date": 1610131874,
                "answer_id": 65634819,
                "question_id": 65629369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq version summary:\r\n\r\nIt is basically all there except for the file input part.\r\n\r\n    $ jq -s &#39;.[0] as $oldvals\r\n             |.[1] as $newvals\r\n             |reduce range($oldvals|length) as $idx\r\n             (\r\n               $oldvals;\r\n               .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time\r\n             )&#39; file1.json file2.json &gt; file3.json\r\n\r\n",
                "title": "Modify a value comparing two json"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610140850,
                "creation_date": 1610140850,
                "answer_id": 65636581,
                "question_id": 65629369,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here with his permission is @oguzismail&#39;s excellent answer:\r\n\r\n    jq &#39;\r\n      input as $in\r\n      | reduce range(length) as $i (.;\r\n          .[$i].Date_and_Time = $in[$i].Date_and_Time)\r\n    &#39; f1 f2 \r\n\r\nThe important point is that the -s slurp command-line option can be easily avoided, as it should be whenever possible if efficiency is a consideration.\r\n\r\nThe above formulation, however, is a tiny bit subtle as it depends on the somewhat non-obvious fact that when `input` is used without the -n command-line option, it evaluates to the *second* JSON entity presented as input.  In the present case, that would be the JSON entity in f2; the top-level `.` by contrast evaluates to the JSON entity in f1. \r\n\r\nSo here&#39;s an alternative and perhaps more intuitive presentation of much the same program:\r\n```\r\njq -n &#39;\r\n  input as $f2\r\n  | input\r\n  | reduce range(length) as $i (.;\r\n      .[$i].Date_and_Time = $f2[$i].Date_and_Time)\r\n&#39; f2 f1 \r\n",
                "title": "Modify a value comparing two json"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1610140850,
        "creation_date": 1610110516,
        "question_id": 65629369,
        "body_markdown": "\r\n\r\nI&#180;ve a JSON data which is a array of dictionaries with the next syntax:\r\n\r\n**file1.json**\r\n```\r\n[ \r\n     {\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 29, 2017 15:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Bar&quot;,\r\n    &quot;Country&quot;: &quot;Brazil&quot;,\r\n    &quot;Age&quot;: &quot;3&quot;\r\n\r\n},\r\n\r\n{\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n\r\n}\r\n\r\n]\r\n```\r\n\r\nAnd I&#39;ve another JSON data with similar syntax EXCEPT the field of **Date_and_Time**.\r\n\r\n**file2.json**\r\n```\r\n[ \r\n{\r\n  &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Age&quot;: &quot;1&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n},\r\n{\r\n    &quot;Date_and_Time&quot;: &quot;Mar 31, 2018 14:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;Germany&quot;,\r\n     &quot;Id&quot;: &quot;2468&quot;,\r\n     &quot;Genre&quot;: &quot;Male&quot;\r\n\r\n}\r\n]\r\n```\r\n\r\nBoth JSON data have the same number of Date_and_Time fields. What I want to do is to rewrite only the value of the first json for the value of the second json for the Date_and_Time\r\n\r\nExpected output: **file3.json**\r\n\r\n```\r\n[ \r\n     {\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Dec 31, 2017 17:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Bar&quot;,\r\n    &quot;Country&quot;: &quot;Brazil&quot;,\r\n    &quot;Age&quot;: &quot;3&quot;\r\n\r\n},\r\n\r\n{\r\n\r\n    &quot;Date_and_Time&quot;: &quot;Mar 31, 2018 14:35:37&quot;,\r\n    &quot;Componente&quot;: &quot;Foo&quot;,\r\n    &quot;Country&quot;: &quot;France&quot;,\r\n     &quot;Id&quot;: &quot;123456&quot;,\r\n     &quot;Car&quot;: &quot;Ferrari&quot;\r\n\r\n}\r\n\r\n]\r\n```\r\n\r\nI dont have preference about what to use as long as it works. I have thought using jq but it didn&#39;t work because of this:\r\n\r\n\r\n```\r\njq -n --argjson oldvals &quot;$(&lt; file1.json)&quot; --argjson newvals &quot;$(&lt; file2.json)&quot; &#39;    reduce range($oldvals | length) as $idx      ($oldvals; .[$idx].Date_and_Time = $newvals[$idx].Date_and_Time)&#39; &gt; file3.json\r\n\r\n```\r\n\r\nit got the next message \r\n\r\n```/usr/bin/jq: the list of argument is too long```",
        "link": "https://stackoverflow.com/questions/65629369/modify-a-value-comparing-two-json",
        "title": "Modify a value comparing two json"
    },
    {
        "tags": [
            "command-line-arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1610260516,
                "last_edit_date": 1610260516,
                "creation_date": 1610218770,
                "answer_id": 65646463,
                "question_id": 65646331,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to specify the jq program to run:\r\n\r\n    jq . my_file.json\r\n\r\n## jq -h\r\n\r\nThe usage line produced by jq -h:\r\n\r\n    Usage:\tjq [options] &lt;jq filter&gt; [file...]\r\n\r\nNote that the summary produced by invoking jq with the -h option does not (currently) provide a complete listing of the options.  For the supported options, see the jq manual: https://stedolan.github.io/jq/manual/\r\n\r\nTwo undocumented options of note are:\r\n\r\n    --debug-dump-disasm\r\n    --debug-trace\r\n\r\n\r\n## `jq .`\r\n\r\nUnder certain circumstances, `jq .` can be abbreviated to `jq` but it&#39;s always safe to use the full form; a good rule of thumb is: if in doubt, do so.",
                "title": "how to pass json file name to jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1659736134,
        "creation_date": 1610217990,
        "last_edit_date": 1659736134,
        "question_id": 65646331,
        "body_markdown": "currently I call\r\n\r\n```\r\ncat my_file.json | jq\r\n```\r\n\r\nto pretty print json data. I am a bit surprised that I can&#39;t do\r\n\r\nI would like to avoid the extra `cat`; i.e.,\r\n\r\n```\r\njq my_file.json\r\n```\r\n\r\nCan I specify a file name?",
        "link": "https://stackoverflow.com/questions/65646331/how-to-pass-json-file-name-to-jq",
        "title": "how to pass json file name to jq?"
    },
    {
        "tags": [
            "json",
            "bash",
            "youtube",
            "jq",
            "youtube-dl"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1610231508,
                "creation_date": 1610231508,
                "answer_id": 65648285,
                "question_id": 65648221,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To emit the strings without quotation marks, simply use the `-r` command-line option.\r\n\r\nTo add the headers, you could modify your filter as follows:\r\n\r\n```\r\n&quot;- TITLE -&quot;, .title,\r\n&quot;- CHANNEL -&quot;, .uploader,\r\n&quot;- CHANNEL URL -&quot;, .webpage_url\r\n```\r\n\r\n(It would probably be simpler to put this in a file rather than trying to squeeze it (with all the necessary escapes) on the command line.)\r\n",
                "title": "Youtube-dl - Extract metadata/json information to text file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1610252706,
        "creation_date": 1610231030,
        "last_edit_date": 1610252706,
        "question_id": 65648221,
        "body_markdown": "Im trying to use jq to extract information from Youtube json information with youtube-dl and format the output to look good.\r\n\r\nExample with output\r\n\r\n`youtube-dl -j https://www.youtube.com/watch?v=TWeRJdrpxEU | jq &quot;.title, .uploader, .webpage_url&quot;`\r\n```\r\n&quot;Cruising – Vendredi (No Copyright Music)&quot;\r\n&quot;Audio Library — Music for content creators&quot;\r\n&quot;https://www.youtube.com/watch?v=TWeRJdrpxEU&quot;\r\n```\r\n\r\nI do not like the &quot; in the output but if I ignore them and try to add extra lines with echo this it dont work and give error below. Youtube-dl work fine in other use cases for me.\r\n\r\n`youtube-dl -j https://www.youtube.com/watch?v=TWeRJdrpxEU | echo TITLE | jq &quot;.title&quot; | echo CHANNEL | jq &quot;.uploader&quot;`\r\n```\r\nparse error: Invalid numeric literal at line 2, column 0\r\nparse error: Invalid numeric literal at line 2, column 0\r\nTraceback (most recent call last):\r\n  File &quot;/usr/local/bin/youtube-dl&quot;, line 33, in &lt;module&gt;\r\n    sys.exit(load_entry_point(&#39;youtube-dl==2021.1.8&#39;, &#39;console_scripts&#39;, &#39;youtube-dl&#39;)())\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/__init__.py&quot;, line 474, in main\r\n    _real_main(argv)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/__init__.py&quot;, line 464, in _real_main\r\n    retcode = ydl.download(all_urls)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 2028, in download\r\n    res = self.extract_info(\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 796, in extract_info\r\n    return self.__extract_info(url, ie, download, extra_info, process)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 803, in wrapper\r\n    return func(self, *args, **kwargs)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 835, in __extract_info\r\n    return self.process_ie_result(ie_result, download, extra_info)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 869, in process_ie_result\r\n    return self.process_video_result(ie_result, download=download)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 1654, in process_video_result\r\n    self.process_info(new_info)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 1764, in process_info\r\n    self.__forced_printings(info_dict, filename, incomplete=False)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 1736, in __forced_printings\r\n    self.to_stdout(json.dumps(info_dict))\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 517, in to_stdout\r\n    self._write_string(output, self._screen_file)\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/YoutubeDL.py&quot;, line 506, in _write_string\r\n    write_string(s, out=out, encoding=self.params.get(&#39;encoding&#39;))\r\n  File &quot;/usr/local/Cellar/youtube-dl/2021.1.8/libexec/lib/python3.9/site-packages/youtube_dl/utils.py&quot;, line 3180, in write_string\r\n    out.buffer.write(byt)\r\nBrokenPipeError: [Errno 32] Broken pipe\r\n```\r\n\r\nThis is the output style I&#39;m after.\r\n```\r\n- TITLE -\r\nCruising – Vendredi (No Copyright Music)\r\n\r\n- CHANNEL -\r\nAudio Library — Music for content creators\r\n\r\n- CHANNEL URL -\r\nhttps://www.youtube.com/watch?v=TWeRJdrpxEU\r\n```",
        "link": "https://stackoverflow.com/questions/65648221/youtube-dl-extract-metadata-json-information-to-text-file",
        "title": "Youtube-dl - Extract metadata/json information to text file"
    },
    {
        "tags": [
            "json",
            "select",
            "timestamp",
            "max",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610262436,
                "post_id": 65650703,
                "comment_id": 116073327,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4049582,
                    "reputation": 103,
                    "user_id": 3329659,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/d3434c9885add66126509d40445f1780?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "PopSmith",
                    "link": "https://stackoverflow.com/users/3329659/popsmith"
                },
                "reply_to_user": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610263096,
                "post_id": 65650703,
                "comment_id": 116073437,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610262262,
                "creation_date": 1610262262,
                "answer_id": 65650846,
                "question_id": 65650703,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As I understand the question, a reasonable solution would be as follows, assuming the -n command-line option is used:\r\n```\r\n[inputs.envelope\r\n | {source, \r\n    message: .dataMessage.message,\r\n    timestamp: .dataMessage.timestamp}]\r\n| group_by(.source)\r\n| [ .[] | max_by(.timestamp) | {source, message} ]\r\n```\r\n\r\nThis at least produces the expected results, and pays attention to the &quot;timestamps&quot;.",
                "title": "Get last unique JSON inputs in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1610264313,
        "creation_date": 1610260620,
        "last_edit_date": 1610264293,
        "question_id": 65650703,
        "body_markdown": "I&#39;m looking to pull the latest (by timestamp) source and message from some JSON data. I tried to get jq to pull only the latest unique message based on the source but can&#39;t quite figure it out.\r\n\r\nExample source data is:\r\n\r\n    {&quot;envelope&quot;:{&quot;source&quot;:&quot;+13101234567&quot;,&quot;sourceDevice&quot;:1,&quot;relay&quot;:null,&quot;timestamp&quot;:1610256979995,&quot;dataMessage&quot;:{&quot;timestamp&quot;:1610256979995,&quot;message&quot;:&quot;Yes&quot;,&quot;expiresInSeconds&quot;:0,&quot;reaction&quot;:null,&quot;quote&quot;:null,&quot;mentions&quot;:[],&quot;attachments&quot;:[],&quot;groupInfo&quot;:null},&quot;syncMessage&quot;:null,&quot;callMessage&quot;:null,&quot;receiptMessage&quot;:null}}\r\n    {&quot;envelope&quot;:{&quot;source&quot;:&quot;+13102345678&quot;,&quot;sourceDevice&quot;:1,&quot;relay&quot;:null,&quot;timestamp&quot;:1610256985623,&quot;dataMessage&quot;:{&quot;timestamp&quot;:1610256985623,&quot;message&quot;:&quot;1&quot;,&quot;expiresInSeconds&quot;:0,&quot;reaction&quot;:null,&quot;quote&quot;:null,&quot;mentions&quot;:[],&quot;attachments&quot;:[],&quot;groupInfo&quot;:null},&quot;syncMessage&quot;:null,&quot;callMessage&quot;:null,&quot;receiptMessage&quot;:null}}\r\n    {&quot;envelope&quot;:{&quot;source&quot;:&quot;+13102345678&quot;,&quot;sourceDevice&quot;:1,&quot;relay&quot;:null,&quot;timestamp&quot;:1610256987736,&quot;dataMessage&quot;:{&quot;timestamp&quot;:1610256987736,&quot;message&quot;:&quot;3&quot;,&quot;expiresInSeconds&quot;:0,&quot;reaction&quot;:null,&quot;quote&quot;:null,&quot;mentions&quot;:[],&quot;attachments&quot;:[],&quot;groupInfo&quot;:null},&quot;syncMessage&quot;:null,&quot;callMessage&quot;:null,&quot;receiptMessage&quot;:null}}\r\n    {&quot;envelope&quot;:{&quot;source&quot;:&quot;+13101234567&quot;,&quot;sourceDevice&quot;:1,&quot;relay&quot;:null,&quot;timestamp&quot;:1610256990731,&quot;dataMessage&quot;:{&quot;timestamp&quot;:1610256990731,&quot;message&quot;:&quot;4&quot;,&quot;expiresInSeconds&quot;:0,&quot;reaction&quot;:null,&quot;quote&quot;:null,&quot;mentions&quot;:[],&quot;attachments&quot;:[],&quot;groupInfo&quot;:null},&quot;syncMessage&quot;:null,&quot;callMessage&quot;:null,&quot;receiptMessage&quot;:null}}\r\n    {&quot;envelope&quot;:{&quot;source&quot;:&quot;+13105678901&quot;,&quot;sourceDevice&quot;:1,&quot;relay&quot;:null,&quot;timestamp&quot;:1610256990731,&quot;dataMessage&quot;:{&quot;timestamp&quot;:1610256990731,&quot;message&quot;:&quot;4&quot;,&quot;expiresInSeconds&quot;:0,&quot;reaction&quot;:null,&quot;quote&quot;:null,&quot;mentions&quot;:[],&quot;attachments&quot;:[],&quot;groupInfo&quot;:null},&quot;syncMessage&quot;:null,&quot;callMessage&quot;:null,&quot;receiptMessage&quot;:null}}\r\n\r\nFor this example, the result should be:\r\n\r\n    [{&quot;source&quot;:&quot;+13102345678&quot;,&quot;message&quot;:&quot;3&quot;},{&quot;source&quot;:&quot;+13101234567&quot;,&quot;message&quot;:&quot;4&quot;},{&quot;source&quot;:&quot;+13105678901&quot;,&quot;message&quot;:&quot;4&quot;}]\r\n\r\nUsing `.envelope.source,.envelope.dataMessage.message` gets the information without the headers but piping it into `unique[]` says &quot;Cannot iterate over string&quot; on [jqplay][1].\r\n\r\n\r\n  [1]: https://jqplay.org/s/bn5WYbOcZx",
        "link": "https://stackoverflow.com/questions/65650703/get-last-unique-json-inputs-in-bash",
        "title": "Get last unique JSON inputs in bash"
    },
    {
        "tags": [
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1610320897,
                "last_edit_date": 1610320897,
                "creation_date": 1610288438,
                "answer_id": 65654280,
                "question_id": 65651244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For relatively smaller input streams, you can &quot;slurp&quot; the objects and combine them into one array using the `add` function and the `-s` command-line option:\r\n\r\n\r\n```none\r\njq --slurp &#39;add | map(select(.file | contains(&quot;q2c&quot;))) | add&#39;\r\n```",
                "title": "jq merge objects after find in array"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1661316228,
                "last_edit_date": 1661316228,
                "creation_date": 1610311325,
                "answer_id": 65658303,
                "question_id": 65651244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is an efficient solution. Rather than using the -s command-line option, it requires using the -n option:\r\n```\r\nreduce (inputs[] | select(.file|contains(&quot;q2c&quot;))) as $in (null;\r\n  .[$in.file] += $in)\r\n| .[]\r\n```\r\n\r\nIt is space-efficient because it does not require slurping the inputs, and it is time-efficient because (a) it does not use `group_by`, the implementation of which requires sorting, and (b) jq implements key-lookup efficiently.\r\n## Similar formulation using `GROUPS_BY`\r\n\r\nAs defined here, GROUPS_BY is similar to the built-in filter `group_by` but (a) does not entail a sort; (b) requires that `f` evaluates to a string; and (c) emits a stream of the groups:\r\n\r\n```\r\ndef GROUPS_BY(stream; f):\r\n  reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\r\n\r\nGROUPS_BY(inputs[] | select(.file|contains(&quot;q2c&quot;)); .file)\r\n| add\r\n```\r\n",
                "title": "jq merge objects after find in array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1661316228,
        "creation_date": 1610266070,
        "question_id": 65651244,
        "body_markdown": "A generated config file (from ls) results in\r\n```\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/College Louise Mich&#232;le 402.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;-90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/College PLUM 4 A.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;-90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/College RS 4 D.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;-90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n[\r\n    {\r\n        &quot;file&quot;: &quot;PDF/Q College.pdf&quot;,\r\n        &quot;rotation&quot;: &quot;90&quot;,\r\n        &quot;fiducial&quot;: &quot;false&quot;\r\n    }\r\n]\r\n[\r\n    {\r\n        &quot;file&quot;: &quot;PDF/Test_q2c.pdf&quot;,\r\n        &quot;rotation&quot;: &quot;90&quot;,\r\n        &quot;fiducial&quot;: &quot;true&quot;,\r\n        &quot;nopdf&quot;: &quot;true&quot;\r\n    }\r\n]\r\n[\r\n    {\r\n        &quot;file&quot;: &quot;PDF/Test_q2c.pdf&quot;,\r\n        &quot;rotation&quot;: &quot;90&quot;,\r\n        &quot;fiducial&quot;: &quot;true&quot;,\r\n        &quot;x&quot;:&quot;false&quot;\r\n    }\r\n]\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/Test q2b.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/Test questionnaires.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/XCollege Bourail 4 B pdf.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;-90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;file&quot;: &quot;PDF/test rotate.pdf&quot;,\r\n    &quot;rotation&quot;: &quot;90&quot;,\r\n    &quot;fiducial&quot;: false\r\n  }\r\n]\r\n```\r\nI need to extract each object using filename as key, which is done by\r\n```\r\njq -r &quot;.[] | select(.file | contains(&quot;q2c&quot;))&quot;\r\n```\r\n\r\nUnfortunately, there are conflicts and when objects are not unique, I need to merge them.\r\nfor instance\r\nobtained answer:\r\n```\r\n{\r\n  &quot;file&quot;: &quot;PDF/Test_q2c.pdf&quot;,\r\n  &quot;rotation&quot;: &quot;90&quot;,\r\n  &quot;fiducial&quot;: &quot;true&quot;,\r\n  &quot;nopdf&quot;: &quot;true&quot;\r\n}\r\n{\r\n  &quot;file&quot;: &quot;PDF/Test_q2c.pdf&quot;,\r\n  &quot;rotation&quot;: &quot;90&quot;,\r\n  &quot;fiducial&quot;: &quot;true&quot;,\r\n  &quot;x&quot;:&quot;false&quot;\r\n}\r\n```\r\n\r\nexpected answer\r\n```\r\n{\r\n  &quot;file&quot;: &quot;PDF/Test_q2c.pdf&quot;,\r\n  &quot;rotation&quot;: &quot;90&quot;,\r\n  &quot;fiducial&quot;: &quot;true&quot;,\r\n  &quot;nopdf&quot;: &quot;true&quot;,\r\n  &quot;x&quot;:&quot;false&quot;\r\n}\r\n```\r\n\r\nI try with the ``.|group_by(.file)[]|add`` but get no success...\r\nthanks in advance.\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65651244/jq-merge-objects-after-find-in-array",
        "title": "jq merge objects after find in array"
    },
    {
        "tags": [
            "kubernetes",
            "yaml",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610273750,
                "post_id": 65652129,
                "comment_id": 116075395,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17457174,
                    "reputation": 1323,
                    "user_id": 12655717,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7e2753f63b7141df846fc58416b18182?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Frederik",
                    "link": "https://stackoverflow.com/users/12655717/frederik"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610275103,
                "post_id": 65652129,
                "comment_id": 116075730,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1507688,
                    "reputation": 597,
                    "user_id": 1410677,
                    "user_type": "registered",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/0424d8b7d39d49ab4d5ddbeb13daa0cf?s=256&d=identicon&r=PG",
                    "display_name": "cvoigt",
                    "link": "https://stackoverflow.com/users/1410677/cvoigt"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1610275557,
                "post_id": 65652129,
                "comment_id": 116075827,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13863020,
                    "reputation": 163362,
                    "user_id": 10008173,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bc86d913c15f3b126673faa654e9668c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "David Maze",
                    "link": "https://stackoverflow.com/users/10008173/david-maze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610282725,
                "post_id": 65652129,
                "comment_id": 116077808,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17457174,
                    "reputation": 1323,
                    "user_id": 12655717,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/7e2753f63b7141df846fc58416b18182?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Frederik",
                    "link": "https://stackoverflow.com/users/12655717/frederik"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610291763,
                "post_id": 65652129,
                "comment_id": 116080517,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1610345245,
                "post_id": 65652129,
                "comment_id": 116093272,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1610287707,
                "last_edit_date": 1610287707,
                "creation_date": 1610287425,
                "answer_id": 65654119,
                "question_id": 65652129,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`yq`](https://kislyuk.github.io/yq/), you can simply write:\r\n\r\n```\r\nyq -y &#39;.spec.template.spec.containers[0].image = &quot;foo:latest&quot;&#39; pod.yml\r\n```\r\n\r\nWhich produces:\r\n\r\n```\r\napiVersion: apps/v1\r\nkind: Deployment\r\nmetadata:\r\n  labels:\r\n    app: myapp\r\n  name: myapp-deployment\r\nspec:\r\n  replicas: 1\r\n  template:\r\n    spec:\r\n      containers:\r\n        - name: myapp\r\n          image: foo:latest\r\n```\r\n\r\nBut I would use [kustomize](https://kustomize.io/) for something like this, as @DavidMaze suggested.",
                "title": "How to replace Image with jq in Kubernetes Deployment?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1610287707,
        "creation_date": 1610273684,
        "last_edit_date": 1610283882,
        "question_id": 65652129,
        "body_markdown": "How can I replace the Image used in a Kubernetes Deployment manifest with jq?\r\n\r\nFor example:  \r\n\r\n    apiVersion: apps/v1\r\n    kind: Deployment\r\n    metadata:\r\n      labels:\r\n        app: myapp\r\n      name: myapp-deployment\r\n    spec:\r\n      replicas: 1\r\n      template:\r\n        spec:\r\n          containers:\r\n          - name: myapp\r\n            image: myapp:v1\r\nI tried using something like this `jq &#39;.spec.template.spec.containers[0].image = &quot;myapp:v2&quot;&#39;`. However, it always ends with a syntax or parse error.",
        "link": "https://stackoverflow.com/questions/65652129/how-to-replace-image-with-jq-in-kubernetes-deployment",
        "title": "How to replace Image with jq in Kubernetes Deployment?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1293198,
                    "reputation": 19192,
                    "user_id": 1244884,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79435cc2571ffa23dfcef703f8d762e0?s=256&d=identicon&r=PG",
                    "display_name": "customcommander",
                    "link": "https://stackoverflow.com/users/1244884/customcommander"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610385602,
                "post_id": 65670810,
                "comment_id": 116110630,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610385969,
                "last_edit_date": 1610385969,
                "creation_date": 1610383051,
                "answer_id": 65670947,
                "question_id": 65670810,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you only need to extract the emails from `.criteria.from` then this filter is enough as far as I can tell:\r\n\r\n```lang-none\r\njq --raw-output &#39;.filter[].criteria.from&#39; file.json\r\n```\r\n\r\nIf some objects don&#39;t have a criteria object then you can filter out nulls with:\r\n\r\n```lang-none\r\njq --raw-output &#39;.filter[].criteria.from | select(. != null)&#39; file.json\r\n```\r\n\r\nIf you want to keep the emails equal to `&quot;mail@domain1.com&quot;`:\r\n\r\n\r\n```lang-none\r\njq --raw-output &#39;.filter[].criteria.from | select(. == &quot;mail@domain1.com&quot;)&#39; file.json\r\n```\r\n\r\nIf you want to keep the emails that start with `&quot;mail@&quot;`:\r\n\r\n```lang-none\r\njq --raw-output &#39;.filter[].criteria.from | select(. != null) | select(startswith(&quot;mail@&quot;))&#39; file.json\r\n```",
                "title": "Extract nested properties from an array of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1610439768,
                "last_edit_date": 1610439768,
                "creation_date": 1610419559,
                "answer_id": 65677356,
                "question_id": 65670810,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I would like to extract emails values \r\n\r\nThere is a wide spectrum of possible answers, with these\r\namongst the least specific with respect to where in the JSON the email addresses occur:\r\n\r\n```\r\n.. | objects | .from | select(type==&quot;string&quot;)\r\n```\r\n```\r\n.. | strings | select(test(&quot;@([a-z0-9]+[.])+[a-z]+$&quot;))\r\n```",
                "title": "Extract nested properties from an array of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1610439768,
        "creation_date": 1610382575,
        "last_edit_date": 1610394855,
        "question_id": 65670810,
        "body_markdown": "I have the following JSON file :\r\n\r\n    {\r\n      &quot;filter&quot;: [\r\n        {\r\n          &quot;id&quot;: &quot;id_1&quot;,\r\n          &quot;criteria&quot;: {\r\n            &quot;from&quot;: &quot;mail@domain1.com&quot;,\r\n            &quot;subject&quot;: &quot;subject_1&quot;\r\n          },\r\n          &quot;action&quot;: {\r\n            &quot;addLabelIds&quot;: [\r\n              &quot;Label_id_1&quot;\r\n            ],\r\n            &quot;removeLabelIds&quot;: [\r\n              &quot;INBOX&quot;,\r\n              &quot;SPAM&quot;\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;id&quot;: &quot;id_2&quot;,\r\n          &quot;criteria&quot;: {\r\n            &quot;from&quot;: &quot;mail@domain2.com&quot;,\r\n            &quot;subject&quot;: &quot;subject_1&quot;\r\n          },\r\n          &quot;action&quot;: {\r\n            &quot;addLabelIds&quot;: [\r\n              &quot;Label_id_2&quot;\r\n            ],\r\n            &quot;removeLabelIds&quot;: [\r\n              &quot;INBOX&quot;,\r\n              &quot;SPAM&quot;\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nAnd I would like to extract emails values : **mail@domain1.com** and **mail@domain2.com**\r\n\r\nI have tried this command:\r\n\r\n    jq --raw-output &#39;.filter[] | select(.criteria.from | test(&quot;mail&quot;; &quot;i&quot;)) | .id&#39;\r\n\r\nBut does not work, I get this error :\r\n\r\n    jq: error (at &lt;stdin&gt;:1206): null (null) cannot be matched, as it is\r\n    not a string exit status 5\r\n\r\nAnother point : how to display the value of &quot;id&quot; key, where &quot;from&quot; key value = mail@domain1.com ?\r\n\r\nSo in my file id = id_1\r\n\r\nDo you have an idea ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/65670810/extract-nested-properties-from-an-array-of-objects",
        "title": "Extract nested properties from an array of objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "associative-array"
        ],
        "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": 1610433335,
                "post_id": 65678915,
                "comment_id": 116123606,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1610438964,
                "last_edit_date": 1610438964,
                "creation_date": 1610435488,
                "answer_id": 65679425,
                "question_id": 65678915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can reduce associative array with *for* loop and pipe it to `jq`:\r\n```bash\r\nfor i in &quot;${!animals[@]}&quot;; do\r\n    echo &quot;$i&quot;\r\n    echo &quot;${animals[$i]}&quot;\r\ndone |\r\njq -n -R --arg mcD &quot;$mcD&quot; --arg eei &quot;$eei&quot; &#39;reduce inputs as $i ({onThisFarm: [], mcD: $mcD, eei: $eei}; .onThisFarm[0] += {($i): (input | tonumber ? // .)})&#39;\r\n```",
                "title": "create json from bash variable and associative array"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1610582966,
                "last_edit_date": 1610582966,
                "creation_date": 1610440016,
                "answer_id": 65680299,
                "question_id": 65678915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that none of the keys or values in the &quot;animals&quot; array contains newline characters:\r\n\r\n```\r\nfor i in &quot;${!animals[@]}&quot;\r\ndo\r\n  printf &quot;%s\\n%s\\n&quot;  &quot;${i}&quot; &quot;${animals[$i]}&quot;\r\ndone | jq -nR --arg oldMcD &quot;$mcD&quot; --arg eei &quot;$eei&quot; &#39;\r\n  def to_o:\r\n    . as $in\r\n    | reduce range(0;length;2) as $i ({}; \r\n        .[$in[$i]]= $in[$i+1]);\r\n\r\n  {$oldMcD, \r\n   $eei,\r\n   onthisfarm: [inputs] | to_o}\r\n&#39;\r\n```\r\n\r\nNotice the trick whereby `{$x}` in effect expands to `{(x): $x}`\r\n\r\n### Using &quot;\\u0000&quot; as the separator\r\n\r\nIf any of the keys or values contains a newline character, you could tweak the above so that &quot;\\u0000&quot; is used as the separator:\r\n\r\n```\r\nfor i in &quot;${!animals[@]}&quot;\r\ndo\r\n    printf &quot;%s\\0%s\\0&quot;  &quot;${i}&quot;  &quot;${animals[$i]}&quot;\r\ndone | jq -sR --arg oldMcD &quot;$mcD&quot; --arg eei &quot;$eei&quot; &#39;\r\n def to_o:\r\n   . as $in\r\n   | reduce range(0;length;2) as $i ({};\r\n       .[$in[$i]]= $in[$i+1]);\r\n\r\n  {$oldMcD, \r\n   $eei,\r\n   onthisfarm: split(&quot;\\u0000&quot;) | to_o }\r\n&#39;\r\n\r\n```\r\n***Note: The above assumes jq version 1.5 or later.***\r\n",
                "title": "create json from bash variable and associative array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1610582966,
        "creation_date": 1610432543,
        "last_edit_date": 1610489236,
        "question_id": 65678915,
        "body_markdown": "Lets say I have the following declared in bash:\r\n```\r\nmcD=&quot;had_a_farm&quot;\r\neei=&quot;eeieeio&quot;\r\ndeclare -A animals=( [&quot;duck&quot;]=&quot;quack_quack&quot; [&quot;cow&quot;]=&quot;moo_moo&quot; [&quot;pig&quot;]=&quot;oink_oink&quot; )\r\n```\r\nand I want the following json:\r\n```\r\n{\r\n  &quot;oldMcD&quot;: &quot;had a farm&quot;,\r\n  &quot;eei&quot;: &quot;eeieeio&quot;,\r\n  &quot;onThisFarm&quot;:[\r\n    {\r\n      &quot;duck&quot;: &quot;quack_quack&quot;,\r\n      &quot;cow&quot;: &quot;moo_moo&quot;,\r\n      &quot;pig&quot;: &quot;oink_oink&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nNow I know I could do this with an echo, printf, or assign text to a variable, but lets assume ```animals``` is actually very large and it would be onerous to do so. I could also loop through my variables and associative array and create a variable as I&#39;m doing so. I could write either of these solutions, but both seem like the ***&quot;wrong way&quot;***. Not to mention its obnoxious to deal with the last item in ```animals```, after which I do not want a &quot;,&quot;.\r\n\r\nI&#39;m thinking the right solution uses jq, but I&#39;m having a hard time finding much documentation and examples on how to use this tool to write jsons (especially those that are nested) rather than parse them.\r\n\r\nHere is what I came up with:\r\n```\r\njq -n --arg mcD &quot;$mcD&quot; --arg eei &quot;$eei&quot; --arg duck &quot;${animals[&#39;duck&#39;]}&quot; --arg cow &quot;${animals[&#39;cow&#39;]}&quot; --arg pig &quot;${animals[&#39;pig&#39;]}&quot; &#39;{onThisFarm:[ { pig: $pig, cow: $cow, duck: $duck } ], eei: $eei, oldMcD: $mcD }&#39;\r\n```\r\nProduces the desired result. In reality, I don&#39;t really care about the order of the keys in the json, but it&#39;s still annoying that the input for jq has to go backwards to get it in the desired order. Regardless, this solution is clunky and was not any easier to write than simply declaring a string variable that looks like a json (and would be impossible with larger associative arrays). How can I build a json like this in an efficient, logical manner?\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/65678915/create-json-from-bash-variable-and-associative-array",
        "title": "create json from bash variable and associative array"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1610473205,
                "post_id": 65688908,
                "comment_id": 116142452,
                "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": 1610473219,
                "post_id": 65688908,
                "comment_id": 116142465,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610546723,
                "last_edit_date": 1610546723,
                "creation_date": 1610473317,
                "answer_id": 65689142,
                "question_id": 65688908,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This isn&#39;t a problem with `jq`, it&#39;s a problem with using unquoted expansions (of which your code currently contains several). You&#39;d have it with _any_ input source.\r\n\r\nWhen you want to store a list of items, store them in an array.\r\n---\r\n\r\nTargeting modern bash (4.0+):\r\n\r\n```\r\n#!/usr/bin/env bash\r\ncase $BASH_VERSION in\r\n  &#39;&#39;|[0123].*) echo &quot;ERROR: bash 4.0+ required&quot; &gt;&amp;2; exit 1;;\r\nesac\r\n\r\nmapfile -t newValue &lt; &lt;(\r\n  jq -r &#39;.order_items[].print_locations[].location_art&#39; response_1.json\r\n)\r\n\r\nfor item in &quot;${newValue[@]}&quot;; do\r\n    echo &quot;New value 2: ${item}&quot;\r\ndone\r\n```\r\n\r\n---\r\n\r\nTargeting legacy bash (including 3.2), and taking advantage of better error handling available with `read -a`:\r\n\r\n```\r\n#!/usr/bin/env bash\r\n[ -n &quot;$BASH_VERSION&quot; ] || { echo &quot;ERROR: bash required&quot; &gt;&amp;2; exit 1; }\r\n\r\nIFS=$&#39;\\n&#39; read -r -d &#39;&#39; -a newValue &lt; &lt;(\r\n  jq -r &#39;.order_items[].print_locations[].location_art&#39; response_1.json \\\r\n    &amp;&amp; printf &#39;\\0&#39;\r\n) || { echo &quot;jq failed; aborting&quot; &gt;&amp;2; exit 1; }\r\n\r\nfor item in &quot;${newValue[@]}&quot;; do\r\n    echo &quot;New value 2: ${item}&quot;\r\ndone\r\n```",
                "title": "JQ with shell to get JSON array dont return in one item for value with spaces"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1610546723,
        "creation_date": 1610472358,
        "last_edit_date": 1610530143,
        "question_id": 65688908,
        "body_markdown": "I am using MacOS JQ tool to get JSON array parsed using Shell script that is retuned via API hence i cant modify the JSON value from Key with any &quot;&quot;&quot;&quot; and \\ or in. The &lt;filename.json&gt; | JQ .[] command returns the array split into multiple items rather one for one &quot;Value&quot;. How to write JQ Command to ensure that the returned parse value including special character, whitespace is not trimmed or splitted to new item of array.\r\n\r\n**Sample API response and not local file that I can edit.** \r\n\r\n```json\r\n{\r\n   &quot;location_preview&quot;:&quot;http://somedomain.com/link_to_your_preview.png&quot;,\r\n   &quot;location_name&quot;:&quot;Full Back&quot;,\r\n   &quot;location_art&quot;:&quot;EQWEQW wqeqweqwe @#@!#!@# qweqwewqe&quot;,\r\n   &quot;location_preview_1&quot;:&quot;http://somedomain.com/link_to_your_preview.png&quot;\r\n}{\r\n   &quot;location_preview&quot;:&quot;http://somedomain.com/link_to_your_preview.png&quot;,\r\n   &quot;location_name&quot;:&quot;Full Back&quot;,\r\n   &quot;location_art&quot;:&quot;This is space string&quot;,\r\n   &quot;location_preview_1&quot;:&quot;http://somedomain.com/link_to_your_preview.png&quot;\r\n}{\r\n   &quot;location_preview&quot;:&quot;http://yrtrtytry.com/link_to_your_preview.png&quot;,\r\n   &quot;location_name&quot;:&quot;Full Back&quot;,\r\n   &quot;location_art&quot;:&quot; http://ytyrtytry.com/link_to_your_artwork.png&quot;,\r\n   &quot;location_preview_1&quot;:&quot;http://somedomain.com/link_to_your_preview.png&quot;\r\n}{\r\n   &quot;location_preview&quot;:&quot;http://eqweqw.com/link_to_your_preview.png&quot;,\r\n   &quot;location_name&quot;:&quot;Full Back&quot;,\r\n   &quot;location_art&quot;:&quot; http://weqweqw.com/link_to_your_artwork.png&quot;,\r\n   &quot;location_preview_1&quot;:&quot;http://weqweqw.com/link_to_your_preview.png&quot;\r\n}\r\n```\r\n\r\nWhen I return the element and want to loop using for loop the item with space value in the key will go into different array item and not as one string with spaces. \r\n\r\nExample:  for &quot;location_art&quot;:&quot;This is space string&quot; --&gt; The value is getting split which I don&#39;t want. How to fix this issue.\r\n\r\nMy code snippet:\r\n\r\n```bash\r\nnewValue=$(cat response_1.json | jq &#39;.order_items[].print_locations[].location_art&#39;)\r\n\r\nfor item in $newValue;\r\ndo\r\n    echo &quot;New value 2: &quot; ${item}\r\ndone\r\n```\r\n\r\n```none\r\nNew value 2:  http://weqweqw.com/link_to_your_artwork.png&quot;\r\nNew value 2:  &quot;\r\nNew value 2:  http://sdasdassd.com/link_to_your_artwork.png&quot;\r\nNew value 2:  &quot;\r\nNew value 2:  http://dasdas.com/link_to_your_artwork.png&quot;\r\nNew value 2:  &quot;EQWEQW\r\nNew value 2:  wqeqweqwe\r\nNew value 2:  @#@!#!@#\r\nNew value 2:  qweqwewqe&quot;\r\nNew value 2:  &quot;EQWEQW\r\nNew value 2:  wqeqweqwe\r\nNew value 2:  @#@!#!@#\r\nNew value 2:  qweqwewqe&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/65688908/jq-with-shell-to-get-json-array-dont-return-in-one-item-for-value-with-spaces",
        "title": "JQ with shell to get JSON array dont return in one item for value with spaces"
    },
    {
        "tags": [
            "json",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1610507621,
                "last_edit_date": 1610507621,
                "creation_date": 1610507317,
                "answer_id": 65695122,
                "question_id": 65694712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A straightforward solution would be to test for `null`, e.g.\r\n```\r\n[.[]\r\n | {author, title}\r\n | .author |= if . then map(.family) else [] end\r\n]\r\n``` \r\n\r\nor similarly:\r\n```\r\nmap({author: (.author \r\n              | if type == &quot;array&quot; \r\n                then map(.family) \r\n                else [] end),\r\n     title} )\r\n```\r\n\r\n",
                "title": "Handling nulls in nested object maps with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1610508093,
        "creation_date": 1610503711,
        "last_edit_date": 1610508093,
        "question_id": 65694712,
        "body_markdown": "I&#39;m just learning jq, and a bit stumped here.  Suppose I&#39;ve got a file entitled `testcite.json` like this: \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;JoeSchmoe2020&quot;,\r\n        &quot;abstract&quot;: &quot;Here&#39;s some junk&quot;,\r\n        &quot;author&quot;: [\r\n          {\r\n            &quot;family&quot;: &quot;Scmoe&quot;,\r\n            &quot;given&quot;: &quot;Joe&quot;\r\n          },\r\n          {\r\n            &quot;family&quot;: &quot;Smith&quot;,\r\n            &quot;given&quot;: &quot;Sally&quot;\r\n          }\r\n        ],\r\n        &quot;title&quot;: &quot;I wrote words!&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;EdithJones2020&quot;,\r\n        &quot;abstract&quot;: &quot;It&#39;s an abstract&quot;,\r\n        &quot;author&quot;: [\r\n          {\r\n            &quot;family&quot;: &quot;Jones&quot;,\r\n            &quot;given&quot;: &quot;Edith&quot;\r\n          },\r\n          {\r\n            &quot;family&quot;: &quot;Wilson&quot;,\r\n            &quot;given&quot;: &quot;Eric&quot;\r\n          }\r\n        ],\r\n        &quot;title&quot;: &quot;These are more words!&quot;\r\n      }\r\n    ]\r\n\r\nand suppose what I want to convert it to is something like this: \r\n\r\n    [\r\n      {\r\n        &quot;author&quot;: [\r\n          &quot;Scmoe&quot;,\r\n          &quot;Smith&quot;\r\n        ],\r\n        &quot;title&quot;: &quot;I wrote words!&quot;\r\n      },\r\n      {\r\n        &quot;author&quot;: [\r\n          &quot;Jones&quot;,\r\n          &quot;Wilson&quot;\r\n        ],\r\n        &quot;title&quot;: &quot;These are more words!&quot;\r\n      }\r\n    ]\r\n\r\n\r\nThe following command works to get me what I want... so long as there aren&#39;t any nulls. \r\n\r\n    cat testcite.json | jq &#39;[.[] | {author: .author | map(.family), title}]&#39;\r\n\r\n\r\nBut the moment there&#39;s a null, this blows up.  Suppose I change my JSON: \r\n\r\n    [\r\n      {\r\n        &quot;id&quot;: &quot;JoeSchmoe2020&quot;,\r\n        &quot;abstract&quot;: &quot;Here&#39;s some junk&quot;,\r\n        &quot;author&quot;: [\r\n          {\r\n            &quot;family&quot;: &quot;Scmoe&quot;,\r\n            &quot;given&quot;: &quot;Joe&quot;\r\n          },\r\n          {\r\n            &quot;family&quot;: &quot;Smith&quot;,\r\n            &quot;given&quot;: &quot;Sally&quot;\r\n          }\r\n        ],\r\n        &quot;title&quot;: &quot;I wrote words!&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: &quot;EdithJones2020&quot;,\r\n        &quot;abstract&quot;: &quot;It&#39;s an abstract&quot;,\r\n        &quot;author&quot;: null,\r\n        &quot;title&quot;: &quot;These are more words!&quot;\r\n      }\r\n    ]\r\n\r\nthen when I run the same command, what I would expect to get would be something like \r\n\r\n    [\r\n      {\r\n        &quot;author&quot;: [\r\n          &quot;Scmoe&quot;,\r\n          &quot;Smith&quot;\r\n        ],\r\n        &quot;title&quot;: &quot;I wrote words!&quot;\r\n      },\r\n      {\r\n        &quot;author&quot;: [],\r\n        &quot;title&quot;: &quot;These are more words!&quot;\r\n      }\r\n    ]\r\n\r\n(I&#39;d also be happy with a null in place of the empty list).\r\n\r\nUnfortunately, instead, I get the error: \r\n\r\n`jq: error (at &lt;stdin&gt;:23): Cannot iterate over null (null)` \r\n\r\nI&#39;ve tried scattering in question marks: \r\n\r\n`cat testcite.json | jq &#39;[.[] | {author: .author | map(.family?), title}]&#39;` just produces the same error. \r\n\r\n`cat testcite.json | jq &#39;[.[] | {author: .author | map(.family)?, title}]&#39;` produces a syntax error:\r\n\r\n    jq: error: syntax error, unexpected &#39;?&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    [.[] | {author: .author | map(.family)?, title}]\r\n    jq: 1 compile error\r\n\r\n\r\nIs there any way I can get the value extraction to just handle nulls sensibly?\r\n",
        "link": "https://stackoverflow.com/questions/65694712/handling-nulls-in-nested-object-maps-with-jq",
        "title": "Handling nulls in nested object maps with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1711642243,
                "last_edit_date": 1711642243,
                "creation_date": 1610562295,
                "answer_id": 65707749,
                "question_id": 65707623,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ does that for you and populates an internal variable called `ENV` with the result, which can be exported to a shell variable like so:\r\n```\r\nvar=$(jq -n &#39;$ENV&#39;)\r\n```\r\nTo remove junk variables like `_`, `SHLVL`, etc. from the list you can use the [`del`](https://stedolan.github.io/jq/manual/#del(path_expression)) function.\r\n```\r\nvar=$(jq -n &#39;$ENV | del(._, .SHLVL)&#39;)\r\n```",
                "title": "Export environment variables to JSON in Bash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 8,
        "last_activity_date": 1711642243,
        "creation_date": 1610561768,
        "last_edit_date": 1611033564,
        "question_id": 65707623,
        "body_markdown": "The environment variables can be printed by using `export` or `printenv` in bash, but how can we convert the output into JSON format and then store them in a variable.",
        "link": "https://stackoverflow.com/questions/65707623/export-environment-variables-to-json-in-bash",
        "title": "Export environment variables to JSON in Bash"
    }
]